mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-04 18:29:37 +02:00
Merge remote-tracking branch 'origin/patch'
Conflicts: Ghidra/Debug/Framework-TraceModeling/src/main/java/ghidra/trace/database/DBTraceUtils.java
This commit is contained in:
commit
045efef45c
3 changed files with 20 additions and 9 deletions
|
@ -19,7 +19,8 @@ import java.lang.reflect.Field;
|
|||
import java.net.MalformedURLException;
|
||||
import java.net.URL;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.*;
|
||||
import java.util.Iterator;
|
||||
import java.util.Objects;
|
||||
import java.util.function.BiConsumer;
|
||||
import java.util.function.Consumer;
|
||||
|
||||
|
|
|
@ -295,7 +295,9 @@ public class DBTraceMemorySpace
|
|||
if (state == null) {
|
||||
throw new NullPointerException();
|
||||
}
|
||||
|
||||
var l = new Object() {
|
||||
boolean changed;
|
||||
};
|
||||
new AddressRangeMapSetter<Entry<TraceAddressSnapRange, TraceMemoryState>, TraceMemoryState>() {
|
||||
@Override
|
||||
protected AddressRange getRange(Entry<TraceAddressSnapRange, TraceMemoryState> entry) {
|
||||
|
@ -324,6 +326,8 @@ public class DBTraceMemorySpace
|
|||
@Override
|
||||
protected Entry<TraceAddressSnapRange, TraceMemoryState> put(AddressRange range,
|
||||
TraceMemoryState value) {
|
||||
// This should not get called if the range is already the desired state
|
||||
l.changed = true;
|
||||
if (value != TraceMemoryState.UNKNOWN) {
|
||||
stateMapSpace.put(new ImmutableTraceAddressSnapRange(range, snap), value);
|
||||
}
|
||||
|
@ -331,8 +335,10 @@ public class DBTraceMemorySpace
|
|||
}
|
||||
}.set(start, end, state);
|
||||
|
||||
trace.setChanged(new TraceChangeRecord<>(TraceMemoryStateChangeType.CHANGED, this,
|
||||
new ImmutableTraceAddressSnapRange(start, end, snap, snap), state));
|
||||
if (l.changed) {
|
||||
trace.setChanged(new TraceChangeRecord<>(TraceMemoryStateChangeType.CHANGED, this,
|
||||
new ImmutableTraceAddressSnapRange(start, end, snap, snap), state));
|
||||
}
|
||||
}
|
||||
|
||||
protected void checkState(TraceMemoryState state) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue