Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/patch'
Browse files Browse the repository at this point in the history
Conflicts:
	Ghidra/Debug/Framework-TraceModeling/src/main/java/ghidra/trace/database/memory/DBTraceMemorySpace.java
  • Loading branch information
ghidra1 committed Feb 28, 2022
2 parents e4dde8c + bb30c21 commit 2d3f68c
Show file tree
Hide file tree
Showing 5 changed files with 67 additions and 24 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -969,7 +969,7 @@ protected void doToggleBreakpointsAt(String title, ActionContext context) {
*/
Trace trace = getTraceFromContext(context);
boolean mapped = breakpointService.anyMapped(bs, trace);
Enablement toggled = en.getToggled(mapped);
Enablement toggled = en.getToggled(mapped && trace == null);
if (toggled.enabled) {
breakpointService.enableAll(bs, trace).exceptionally(ex -> {
breakpointError(title, "Could not enable breakpoints", ex);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@
package ghidra.app.plugin.core.debug.gui.pcode;

import java.awt.*;
import java.awt.font.FontRenderContext;
import java.awt.geom.AffineTransform;
import java.math.BigInteger;
import java.util.*;
import java.util.List;
Expand Down Expand Up @@ -65,6 +67,8 @@
import ghidra.util.table.column.AbstractGColumnRenderer;

public class DebuggerPcodeStepperProvider extends ComponentProviderAdapter {
private static final FontRenderContext METRIC_FRC =
new FontRenderContext(new AffineTransform(), false, false);
private static final String BACKGROUND_COLOR = "Background Color";
private static final String ADDRESS_COLOR = "Address Color";
private static final String CONSTANT_COLOR = "Constant Color";
Expand Down Expand Up @@ -458,6 +462,12 @@ protected void recomputeStyle() {
pcodeTableModel.fireTableDataChanged();
}

protected int computeSeqColWidth(JLabel renderer) {
Font font = renderer.getFont();
Insets insets = renderer.getBorder().getBorderInsets(renderer);
return (int) font.getStringBounds("00", METRIC_FRC).getWidth() + insets.left + insets.right;
}

protected void buildMainPanel() {
JPanel pcodePanel = new JPanel(new BorderLayout());
pcodeTable = new GhidraTable(pcodeTableModel);
Expand Down Expand Up @@ -486,9 +496,11 @@ protected void buildMainPanel() {

TableColumnModel pcodeColModel = pcodeTable.getColumnModel();
TableColumn seqCol = pcodeColModel.getColumn(PcodeTableColumns.SEQUENCE.ordinal());
seqCol.setCellRenderer(new CounterBackgroundCellRenderer());
seqCol.setMinWidth(24);
seqCol.setMaxWidth(24);
CounterBackgroundCellRenderer seqColRenderer = new CounterBackgroundCellRenderer();
seqCol.setCellRenderer(seqColRenderer);
int seqColWidth = computeSeqColWidth(seqColRenderer);
seqCol.setMinWidth(seqColWidth);
seqCol.setMaxWidth(seqColWidth);
TableColumn codeCol = pcodeColModel.getColumn(PcodeTableColumns.CODE.ordinal());
codeCol.setCellRenderer(new PcodeCellRenderer());
//codeCol.setPreferredWidth(75);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -499,6 +499,20 @@ public void testActionToggleBreakpointTrace() throws Exception {
dynamicCtx(trace, addr(trace, 0x55550123)), true);

waitForPass(() -> assertEquals(Enablement.ENABLED, lb.computeEnablementForTrace(trace)));

lb.disable();
waitForPass(() -> assertEquals(Enablement.DISABLED, lb.computeEnablementForTrace(trace)));

performAction(breakpointMarkerPlugin.actionToggleBreakpoint,
dynamicCtx(trace, addr(trace, 0x55550123)), true);

waitForPass(
() -> assertEquals(Enablement.ENABLED_DISABLED, lb.computeEnablementForTrace(trace)));

performAction(breakpointMarkerPlugin.actionToggleBreakpoint,
dynamicCtx(trace, addr(trace, 0x55550123)), true);

waitForPass(() -> assertEquals(Enablement.DISABLED, lb.computeEnablementForTrace(trace)));
}

protected void testActionSetBreakpointProgram(DockingAction action,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,8 @@
import ghidra.trace.model.Trace.*;
import ghidra.trace.model.memory.*;
import ghidra.trace.model.thread.TraceThread;
import ghidra.trace.util.DefaultTraceTimeViewport;
import ghidra.trace.util.TraceChangeRecord;
import ghidra.trace.util.TraceViewportSpanIterator;
import ghidra.util.*;
import ghidra.util.AddressIteratorAdapter;
import ghidra.util.database.*;
Expand Down Expand Up @@ -93,6 +93,8 @@ public class DBTraceMemorySpace implements Unfinished, TraceMemorySpace, DBTrace
.build()
.asMap();

protected final DefaultTraceTimeViewport viewport;

public DBTraceMemorySpace(DBTraceMemoryManager manager, DBHandle dbh, AddressSpace space,
DBTraceSpaceEntry ent) throws IOException, VersionException {
this.manager = manager;
Expand Down Expand Up @@ -127,6 +129,8 @@ public DBTraceMemorySpace(DBTraceMemoryManager manager, DBHandle dbh, AddressSpa
true);
this.blocksByOffset =
blockStore.getIndex(OffsetSnap.class, DBTraceMemoryBlockEntry.LOCATION_COLUMN);

this.viewport = new DefaultTraceTimeViewport(trace);
}

private void regionCacheEntryRemoved(
Expand Down Expand Up @@ -375,9 +379,7 @@ public TraceMemoryState getState(long snap, Address address) {

@Override
public Entry<Long, TraceMemoryState> getViewState(long snap, Address address) {
TraceViewportSpanIterator spit = new TraceViewportSpanIterator(trace, snap);
while (spit.hasNext()) {
Range<Long> span = spit.next();
for (Range<Long> span : viewport.getOrderedSpans(snap)) {
TraceMemoryState state = getState(span.upperEndpoint(), address);
switch (state) {
case KNOWN:
Expand All @@ -403,9 +405,7 @@ public Entry<TraceAddressSnapRange, TraceMemoryState> getMostRecentStateEntry(lo
@Override
public Entry<TraceAddressSnapRange, TraceMemoryState> getViewMostRecentStateEntry(long snap,
Address address) {
TraceViewportSpanIterator spit = new TraceViewportSpanIterator(trace, snap);
while (spit.hasNext()) {
Range<Long> span = spit.next();
for (Range<Long> span: viewport.getOrderedSpans(snap)) {
Entry<TraceAddressSnapRange, TraceMemoryState> entry =
stateMapSpace.reduce(TraceAddressSnapRangeQuery.mostRecent(address, span))
.firstEntry();
Expand Down Expand Up @@ -738,9 +738,8 @@ public int getViewBytes(long snap, Address start, ByteBuffer buf) {
}
Map<AddressRange, Long> sources = new TreeMap<>();
AddressSet remains = new AddressSet(toRead);
TraceViewportSpanIterator spit = new TraceViewportSpanIterator(trace, snap);
spans: while (spit.hasNext()) {
Range<Long> span = spit.next();

spans: for (Range<Long> span : viewport.getOrderedSpans(snap)) {
Iterator<AddressRange> arit =
getAddressesWithState(span, s -> s == TraceMemoryState.KNOWN).iterator(start, true);
while (arit.hasNext()) {
Expand All @@ -765,15 +764,19 @@ public int getViewBytes(long snap, Address start, ByteBuffer buf) {
int offset = (int) rng.getMinAddress().subtract(toRead.getMinAddress());
int length = (int) rng.getLength();
buf.limit(pos + offset + length);
buf.position(pos + offset);
while (buf.position() < pos + offset) {
buf.put((byte) 0); // fill gaps with 0
}
int read = getBytes(ent.getValue(), rng.getMinAddress(), buf);
if (read < length) {
break;
}
}
// We "got it all", even if there were gaps in "KNOWN"
buf.limit(lim);
buf.position(pos + len);
while (buf.position() < pos + len) {
buf.put((byte) 0); // fill final gap with 0
}
return len;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -100,22 +100,20 @@ public void domainObjectClosed() {
}

protected final Trace trace;
protected final TraceTimeManager timeManager;
/**
* NB: This is the syncing object for the viewport. If there's even a chance an operation may
* need the DB's lock, esp., considering user callbacks, then it must <em>first</em> acquire the
* DB lock.
* NB: This is also the syncing object for the viewport. If there's even a chance an operation
* may need the DB's lock, esp., considering user callbacks, then it must <em>first</em> acquire
* the DB lock.
*/
protected final List<Range<Long>> ordered = new ArrayList<>();
protected final List<Range<Long>> ordered = new ArrayList<>(List.of(Range.singleton(0L)));
protected final RangeSet<Long> spanSet = TreeRangeSet.create();
protected final ForSnapshotsListener listener = new ForSnapshotsListener();
protected final ListenerSet<Runnable> changeListeners = new ListenerSet<>(Runnable.class);

protected long snap;
protected long snap = 0;

public DefaultTraceTimeViewport(Trace trace) {
this.trace = trace;
this.timeManager = trace.getTimeManager();
trace.addCloseListener(listener);
trace.addListener(listener);
}
Expand Down Expand Up @@ -266,7 +264,7 @@ protected void refreshSnapRanges() {
RangeSet<Long> spanSet = TreeRangeSet.create();
List<Range<Long>> ordered = new ArrayList<>();
try (LockHold hold = trace.lockRead()) {
collectForkRanges(timeManager, snap, spanSet, ordered);
collectForkRanges(trace.getTimeManager(), snap, spanSet, ordered);
}
synchronized (this.ordered) {
this.spanSet.clear();
Expand All @@ -279,6 +277,9 @@ protected void refreshSnapRanges() {
}

public void setSnap(long snap) {
if (this.snap == snap) {
return;
}
this.snap = snap;
refreshSnapRanges();
}
Expand Down Expand Up @@ -329,6 +330,19 @@ public boolean isForked() {
}
}

public List<Range<Long>> getOrderedSpans() {
synchronized (ordered) {
return List.copyOf(ordered);
}
}

public List<Range<Long>> getOrderedSpans(long snap) {
synchronized (ordered) {
setSnap(snap);
return getOrderedSpans();
}
}

@Override
public List<Long> getOrderedSnaps() {
synchronized (ordered) {
Expand Down

0 comments on commit 2d3f68c

Please sign in to comment.