GP-7 Added handling of MULTI_EQUAL pcode op while finding constant

resource ids.
This commit is contained in:
emteere 2024-04-30 21:53:25 -04:00
parent 772694c13c
commit 09bd2bebe0
2 changed files with 7 additions and 6 deletions

View file

@ -694,10 +694,10 @@ public class WindowsResourceReference extends GhidraScript {
followToParam(constUse, defUseList, highFunction, def.getInput(0), doneSet);
return;
case PcodeOp.MULTIEQUAL:
followToParam(constUse, defUseList, highFunction, def.getInput(0), doneSet);
@SuppressWarnings("unchecked")
ArrayList<PcodeOp> splitUseList = (ArrayList<PcodeOp>) defUseList.clone();
followToParam(constUse, splitUseList, highFunction, def.getInput(1), doneSet);
for (int i = 0; i < def.getNumInputs(); i++) {
ArrayList<PcodeOp> splitUseList = new ArrayList<>(defUseList);
followToParam(constUse, splitUseList, highFunction, def.getInput(i), doneSet);
}
return;
case PcodeOp.CAST:
// Cast will expose more Pcode, and could be attached to the same address!
@ -707,7 +707,8 @@ public class WindowsResourceReference extends GhidraScript {
followToParam(constUse, defUseList, highFunction, def.getInput(0), doneSet);
return;
case PcodeOp.INDIRECT:
if (def.getOutput().getAddress().equals(def.getInput(0).getAddress())) {
Varnode output = def.getOutput();
if (output.getAddress().equals(def.getInput(0).getAddress())) {
followToParam(constUse, defUseList, highFunction, def.getInput(0), doneSet);
return;
}

View file

@ -145,7 +145,7 @@ public class WindowsResourceReferenceScriptTest extends AbstractGhidraHeadedInte
addr(0x01001f3b, pgm), addr(0x0100398f, pgm), addr(0x01003ade, pgm),
addr(0x01003aec, pgm), addr(0x01003ad0, pgm), addr(0x010039c5, pgm),
addr(0x01003d45, pgm), addr(0x0100385b, pgm), addr(0x01003d36, pgm),
addr(0x01003920, pgm), addr(0x0100390e, pgm) };
addr(0x01003920, pgm), addr(0x0100390e, pgm), addr(0x01003932, pgm) };
return winmineTestAddrs;
}