Satisfying memory ordering requirements between partial reads and non-snoop accesses
First Claim
1. An apparatus comprising:
- a controller to interface between at least a first processor to recognize a first instruction set and second processor to recognize a second instruction set that is different from the first instruction set, the controller comprising interface logic to couple to a link comprising a plurality of lanes;
the interface logic to;
receive a snoop invalidate message, wherein the snoop invalidate message corresponds to a particular cache line; and
send a writeback message responsive to the snoop invalidate message, wherein the writeback message is to indicate a write to a home agent associated with the particular cache line and cause a transition of the particular cache line from a modified cache coherency state to an invalid cache coherency state.
0 Assignments
0 Petitions
Accused Products
Abstract
A method and apparatus for preserving memory ordering in a cache coherent link based interconnect in light of partial and non-coherent memory accesses is herein described. In one embodiment, partial memory accesses, such as a partial read, is implemented utilizing a Read Invalidate and/or Snoop Invalidate message. When a peer node receives a Snoop Invalidate message referencing data from a requesting node, the peer node is to invalidate a cache line associated with the data and is not to directly forward the data to the requesting node. In one embodiment, when the peer node holds the referenced cache line in a Modified coherency state, in response to receiving the Snoop Invalidate message, the peer node is to writeback the data to a home node associated with the data.
-
Citations
6 Claims
-
1. An apparatus comprising:
-
a controller to interface between at least a first processor to recognize a first instruction set and second processor to recognize a second instruction set that is different from the first instruction set, the controller comprising interface logic to couple to a link comprising a plurality of lanes; the interface logic to; receive a snoop invalidate message, wherein the snoop invalidate message corresponds to a particular cache line; and send a writeback message responsive to the snoop invalidate message, wherein the writeback message is to indicate a write to a home agent associated with the particular cache line and cause a transition of the particular cache line from a modified cache coherency state to an invalid cache coherency state.
-
-
2. A method comprising:
-
receiving at a particular coherency agent, a snoop invalidate message, wherein the snoop invalidate message corresponds to a partial read of a particular cache line by another coherency agent; and generating a writeback message in response to the snoop invalidate message, wherein the writeback message is to indicate a write to a home agent associated with the particular cache line and cause a transition of the particular cache line from a modified cache coherency state to an invalid cache coherency state.
-
-
3. A system comprising:
-
cache coherent memory; a first device comprising a first coherency agent to send a read invalidate message, wherein the read invalidate message corresponds to a particular cache line of the cache coherent memory; a second device comprising a second coherency agent to receive a snoop invalidate message associated with the read invalidate message and generate a writeback message associated with the read invalidate message; and a third device comprising a home agent to receive the writeback message and perform a write to the particular cache line based on the writeback message, wherein the writeback message is to cause a transition of the particular cache line from a modified cache coherency state to an invalid cache coherency state. - View Dependent Claims (4, 5, 6)
-
Specification