From 7e70d7821113f809c0ca13e4174b6a367241f286 Mon Sep 17 00:00:00 2001 From: sei-eschwartz <50171988+sei-eschwartz@users.noreply.github.com> Date: Thu, 6 Apr 2023 12:57:17 -0400 Subject: [PATCH] Improve error messages during hornification (#39) --- .../tools/ghihorn/hornifer/GhiHornifier.java | 2 +- .../horn/expression/PcodeExpression.java | 22 +++++++++++++++++-- 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/src/main/java/kaiju/tools/ghihorn/hornifer/GhiHornifier.java b/src/main/java/kaiju/tools/ghihorn/hornifer/GhiHornifier.java index 31983d8..d84022a 100644 --- a/src/main/java/kaiju/tools/ghihorn/hornifer/GhiHornifier.java +++ b/src/main/java/kaiju/tools/ghihorn/hornifer/GhiHornifier.java @@ -799,7 +799,7 @@ protected void hornifyCfg(final HornProgram hornProgram, final HornFunction horn // Go through each pcode operation and add it as an expression for // this block for (final PcodeOp pcode : vertex.getEntity().getPcode()) { - PcodeExpression pcX = new PcodeExpression(pcode); + PcodeExpression pcX = new PcodeExpression(pcode, vertex.getLocator()); pcX.getUseVariables().forEach(newBlock::addUseVariable); pcX.getDefVariables().forEach(newBlock::addDefVariable); newBlock.addExpression(pcode, pcX); diff --git a/src/main/java/kaiju/tools/ghihorn/hornifer/horn/expression/PcodeExpression.java b/src/main/java/kaiju/tools/ghihorn/hornifer/horn/expression/PcodeExpression.java index 59dd085..06a16b2 100644 --- a/src/main/java/kaiju/tools/ghihorn/hornifer/horn/expression/PcodeExpression.java +++ b/src/main/java/kaiju/tools/ghihorn/hornifer/horn/expression/PcodeExpression.java @@ -6,6 +6,7 @@ import com.microsoft.z3.BoolExpr; import com.microsoft.z3.Expr; import com.microsoft.z3.Sort; +import ghidra.program.model.address.Address; import ghidra.program.model.pcode.HighVariable; import ghidra.program.model.pcode.PcodeOp; import ghidra.program.model.pcode.Varnode; @@ -32,6 +33,7 @@ public class PcodeExpression implements HornExpression { private HornVariable outVariable; private HornExpression operation; private final PcodeOp pcode; + private Address address; /** * @param defVariables @@ -39,6 +41,12 @@ public class PcodeExpression implements HornExpression { * @param inVariables * @param outVariable */ + + public PcodeExpression(PcodeOp pcode, Address address) { + this(pcode); + this.address = address; + } + public PcodeExpression(PcodeOp pcode) { this.defVariables = new ArrayList<>(); @@ -47,13 +55,23 @@ public PcodeExpression(PcodeOp pcode) { this.outVariable = null; this.operation = null; this.pcode = pcode; + this.address = null; // First the I/O variables must be computed try { computeIOVariables(); } catch (Exception e) { - Msg.error(this, "Failed to generate variables for p-code: " + pcode); - throw new GhiHornException("Failed to generate variables for p-code: " + pcode + ". This is an issue with Ghidra's HighConstant class"); + StringBuilder errorMessage = new StringBuilder("Failed to generate variables for p-code"); + if (this.address != null) { + errorMessage.append(" at address " + this.address + ":"); + } else { + errorMessage.append(":"); + } + errorMessage.append(pcode); + errorMessage.append(", exception: " + e.getMessage()); + errorMessage.append(". This is an issue with Ghidra's HighConstant class."); + Msg.error(this, errorMessage); + throw new GhiHornException(errorMessage.toString()); } // Second the operations need to be generated from the I/O variables. This will