×

Apparatus and method for non-serializing split locks

  • US 10,102,000 B2
  • Filed: 04/01/2016
  • Issued: 10/16/2018
  • Est. Priority Date: 04/01/2016
  • Status: Active Grant
First Claim
Patent Images

1. A processor comprising:

  • a plurality of cores to execute instructions, each core comprising a core cache to cache data during instruction execution;

    a shared cache to be shared by two or more of the plurality of cores;

    a locking agent on a first core to initiate a split lock operation in response to detecting a transaction targeting two cache lines, the split lock comprising a first lock preventing more than one split lock operation being performed at once, and a second lock and third lock for each of the two cache lines, the locking agent to transmit a request for the two cache lines to be set to an Exclusive state, wherein to initiate the split lock operation, the locking agent is to transmit a request for the split lock operation to a lock master, the lock master to transmit a response to the locking agent to grant the split lock operation upon determining no other split lock operation is present;

    at least one coherence enforcement engine to receive the request from the locking agent and to responsively cause any copies of the two cache lines in other cores to be invalidated;

    the locking agent to permit the transaction targeting the two cache lines to complete upon receipt of an indication that the cache lines are in the Exclusive state and, upon completion of the transaction, to transmit an indication that the transaction is complete to the coherence enforcement engine.

View all claims
  • 1 Assignment
Timeline View
Assignment View
    ×
    ×