/*
FullRegisterWriteTracker.java
(c) 2012-2013 Edward Swartz
All rights reserved. This program and the accompanying materials
are made available under the terms of the Eclipse Public License v1.0
which accompanies this distribution, and is available at
http://www.eclipse.org/legal/epl-v10.html
*/
package v9t9.common.machine;
import java.util.ArrayList;
import java.util.BitSet;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
/**
* Track a series of changes to a set of registers.
* @author ejs
*
*/
public class FullRegisterWriteTracker extends BaseRegisterWriteTracker {
private List<Long> changes = new ArrayList<Long>(1024);
public FullRegisterWriteTracker(IRegisterAccess access, int baseReg, BitSet regbits) {
super(access, baseReg, regbits);
}
public FullRegisterWriteTracker(IRegisterAccess access) {
super(access);
}
/* (non-Javadoc)
* @see v9t9.common.machine.BaseRegisterWriteTracker#clearChanges()
*/
@Override
public void clearChanges() {
synchronized (changes) {
changes.clear();
}
}
/* (non-Javadoc)
* @see v9t9.common.machine.BaseRegisterWriteTracker#record(int, int)
*/
@Override
protected void record(int reg, int value) {
synchronized (changes) {
long ent = ((long) reg) << 32;
ent |= (value & 0xffffffffL);
changes.add(ent);
}
}
/**
* Get the changes, as they occurred, in order. Caller may modify
* but cannot own the list.
* @return the changes, as <integer32: reg> | <integer32: value>
*/
public List<Long> getChanges() {
return changes;
}
/**
* Get the changes, sorted by register key. Only the last
* change to each register is mentioned.
* Caller may modify.
* @return the changes
*/
public Map<Integer, Integer> getChangeMap() {
synchronized (changes) {
Map<Integer, Integer> map = new TreeMap<Integer, Integer>();
for (Long ent : changes) {
map.put((int) (ent >> 32), (int)(ent & 0xffffffff));
}
return map;
}
}
}