playPingPong(shm, 4, 5, true, "PingPongCASLEFT");
}
static void playPingPong(SharedHashMap<String, BondVOInterface> shm, double _coupon, double _coupon2, boolean setFirst, final String desc) {
BondVOInterface bond1 = newDirectReference(BondVOInterface.class);
BondVOInterface bond2 = newDirectReference(BondVOInterface.class);
BondVOInterface bond3 = newDirectReference(BondVOInterface.class);
BondVOInterface bond4 = newDirectReference(BondVOInterface.class);
shm.acquireUsing("369604101", bond1);
shm.acquireUsing("369604102", bond2);
shm.acquireUsing("369604103", bond3);
shm.acquireUsing("369604104", bond4);
System.out.printf("\n\n" + desc + ": Timing 1 x off-heap operations on /dev/shm/RDR_DIM_Mock\n");
if (setFirst) {
bond1.setCoupon(_coupon);
bond2.setCoupon(_coupon);
bond3.setCoupon(_coupon);
bond4.setCoupon(_coupon);
}
int timeToCallNanoTime = 30;
int runs = 1000000;
long[] timings = new long[runs];
for (int j = 0; j < 10; j++) {
for (int i = 0; i < runs; i++) {
long _start = System.nanoTime(); //
while (!bond1.compareAndSwapCoupon(_coupon, _coupon2)) ;
while (!bond2.compareAndSwapCoupon(_coupon, _coupon2)) ;
while (!bond3.compareAndSwapCoupon(_coupon, _coupon2)) ;
while (!bond4.compareAndSwapCoupon(_coupon, _coupon2)) ;
timings[i] = (System.nanoTime() - _start - timeToCallNanoTime) / 4;
}
Arrays.sort(timings);
System.out.printf("#%d: compareAndSwapCoupon() 50/90/99%%tile was %,d / %,d / %,d%n",