| CPC G06F 12/128 (2013.01) [G06F 9/3001 (2013.01); G06F 9/30043 (2013.01); G06F 9/30047 (2013.01); G06F 9/546 (2013.01); G06F 11/1064 (2013.01); G06F 12/0215 (2013.01); G06F 12/0238 (2013.01); G06F 12/0292 (2013.01); G06F 12/0802 (2013.01); G06F 12/0804 (2013.01); G06F 12/0806 (2013.01); G06F 12/0811 (2013.01); G06F 12/0815 (2013.01); G06F 12/082 (2013.01); G06F 12/0853 (2013.01); G06F 12/0855 (2013.01); G06F 12/0864 (2013.01); G06F 12/0884 (2013.01); G06F 12/0888 (2013.01); G06F 12/0891 (2013.01); G06F 12/0895 (2013.01); G06F 12/0897 (2013.01); G06F 12/12 (2013.01); G06F 12/121 (2013.01); G06F 12/126 (2013.01); G06F 12/127 (2013.01); G06F 13/1605 (2013.01); G06F 13/1642 (2013.01); G06F 13/1673 (2013.01); G06F 13/1689 (2013.01); G06F 15/8069 (2013.01); G11C 5/066 (2013.01); G11C 7/10 (2013.01); G11C 7/1015 (2013.01); G11C 7/106 (2013.01); G11C 7/1075 (2013.01); G11C 7/1078 (2013.01); G11C 7/1087 (2013.01); G11C 7/222 (2013.01); G11C 29/42 (2013.01); G11C 29/44 (2013.01); G06F 2212/1016 (2013.01); G06F 2212/1021 (2013.01); G06F 2212/1024 (2013.01); G06F 2212/1041 (2013.01); G06F 2212/1044 (2013.01); G06F 2212/301 (2013.01); G06F 2212/454 (2013.01); G06F 2212/603 (2013.01); G06F 2212/6032 (2013.04); G06F 2212/6042 (2013.01); G06F 2212/608 (2013.01); G06F 2212/62 (2013.01)] | 19 Claims |

|
1. A device comprising:
a cache that includes:
a first interface configured to couple to a set of processor cores and associated with a first data path;
a second interface configured to couple to the set of processor cores and associated with a second data path;
a cache memory that includes a set of entries divided into a set of ways; and
a cache controller coupled to the first interface, the second interface, and the cache memory, wherein the cache controller is configured to:
receive a first memory operation associated with the first data path;
determine that the first memory operation is associated with data eviction;
determine, based on a first pointer value, a first way of the set of ways for the data eviction associated with the first memory operation;
receive a second memory operation associated with the second data path;
determine whether the second memory operation conflicts with the data eviction associated with the first memory operation; and
based on the second memory operation conflicting with the data eviction,
determine a second way of the set of ways for the data eviction associated with the first memory operation based on a second pointer value; and
increment each of the first pointer value and the second pointer value twice.
|