/*
* This file is part of the Jikes RVM project (http://jikesrvm.org).
*
* This file is licensed to You under the Eclipse Public License (EPL);
* You may not use this file except in compliance with the License. You
* may obtain a copy of the License at
*
* http://www.opensource.org/licenses/eclipse-1.0.php
*
* See the COPYRIGHT.txt file distributed with this work for information
* regarding copyright ownership.
*/
package org.mmtk.harness.scheduler.rawthreads;
import java.util.ArrayList;
import java.util.List;
import org.mmtk.harness.lang.Trace;
import org.mmtk.harness.lang.Trace.Item;
import org.vmmagic.pragma.Uninterruptible;
/**
* Simple lock.
*/
@Uninterruptible
public class RawLock extends org.mmtk.harness.scheduler.Lock {
private boolean isHeld = false;
private final RawThreadModel model;
private List<RawThread> waitList = new ArrayList<RawThread>();
/** Create a new lock (with given name) */
public RawLock(RawThreadModel model, String name) {
super(name);
this.model = model;
}
/**
* Try to acquire a lock and wait until acquired.
*/
@Override
public void acquire() {
while (isHeld) {
Trace.trace(Item.SCHEDULER,"Yielded onto lock queue ");
model.yield(waitList);
}
isHeld = true;
}
/**
* Perform sanity checks on the lock. For debugging.
*
* @param w Identifies the code location in the debugging output.
*/
@Override
public void check(int w) {
System.err.println("[" + name + "] AT " + w + " held by " + holder);
}
/**
* Release the lock.
*/
@Override
public void release() {
isHeld = false;
model.makeRunnable(waitList);
}
int threadsWaiting() {
return waitList.size();
}
}