mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-05 19:42:36 +02:00
parent
69292c546f
commit
b6b609cfac
10 changed files with 53 additions and 46 deletions
|
@ -24,9 +24,7 @@ import ghidra.app.plugin.assembler.sleigh.parse.AssemblyParser;
|
|||
import ghidra.app.plugin.assembler.sleigh.sem.*;
|
||||
import ghidra.app.plugin.assembler.sleigh.tree.AssemblyParseBranch;
|
||||
import ghidra.app.plugin.processors.sleigh.SleighLanguage;
|
||||
import ghidra.asm.wild.sem.DefaultWildAssemblyResolvedPatterns;
|
||||
import ghidra.asm.wild.sem.WildAssemblyResolvedPatterns;
|
||||
import ghidra.asm.wild.sem.WildAssemblyTreeResolver;
|
||||
import ghidra.asm.wild.sem.*;
|
||||
import ghidra.program.model.address.Address;
|
||||
import ghidra.program.model.listing.Program;
|
||||
|
||||
|
|
|
@ -22,13 +22,11 @@ import ghidra.app.plugin.assembler.sleigh.AbstractSleighAssemblerBuilder;
|
|||
import ghidra.app.plugin.assembler.sleigh.SleighAssemblerBuilder;
|
||||
import ghidra.app.plugin.assembler.sleigh.grammars.AssemblyGrammar;
|
||||
import ghidra.app.plugin.assembler.sleigh.grammars.AssemblySentential;
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.AbstractAssemblyResolutionFactory;
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.AssemblyPatternBlock;
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.AssemblyResolvedBackfill;
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.*;
|
||||
import ghidra.app.plugin.assembler.sleigh.symbol.*;
|
||||
import ghidra.app.plugin.assembler.sleigh.util.DbgTimer.DbgCtx;
|
||||
import ghidra.app.plugin.languages.sleigh.InputContextScraper;
|
||||
import ghidra.app.plugin.processors.sleigh.Constructor;
|
||||
import ghidra.app.plugin.processors.sleigh.SleighLanguage;
|
||||
import ghidra.app.plugin.processors.sleigh.*;
|
||||
import ghidra.app.plugin.processors.sleigh.pattern.DisjointPattern;
|
||||
import ghidra.asm.wild.grammars.WildAssemblyProduction;
|
||||
import ghidra.asm.wild.sem.WildAssemblyResolutionFactory;
|
||||
|
@ -51,7 +49,7 @@ public class WildSleighAssemblerBuilder
|
|||
extends AbstractSleighAssemblerBuilder<WildAssemblyResolvedPatterns, WildSleighAssembler> {
|
||||
|
||||
protected final Map<AssemblySymbol, AssemblyNonTerminal> wildNTs = new HashMap<>();
|
||||
protected final Set<AssemblyPatternBlock> inputContexts;
|
||||
protected Set<AssemblyPatternBlock> inputContexts;
|
||||
|
||||
/**
|
||||
* Construct a builder for the given language
|
||||
|
@ -65,8 +63,19 @@ public class WildSleighAssemblerBuilder
|
|||
*/
|
||||
public WildSleighAssemblerBuilder(SleighLanguage lang) {
|
||||
super(lang);
|
||||
InputContextScraper scraper = new InputContextScraper(lang);
|
||||
this.inputContexts = scraper.scrapeInputContexts();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void generateAssembler() throws SleighException {
|
||||
super.generateAssembler();
|
||||
buildInputContexts();
|
||||
}
|
||||
|
||||
protected void buildInputContexts() {
|
||||
try (DbgCtx dc = dbg.start("Building input contexts")) {
|
||||
InputContextScraper scraper = new InputContextScraper(lang);
|
||||
this.inputContexts = scraper.scrapeInputContexts();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -86,10 +86,6 @@ public abstract class AbstractSleighAssemblerBuilder< //
|
|||
* @throws SleighException if there's an issue accessing the language
|
||||
*/
|
||||
protected void generateAssembler() throws SleighException {
|
||||
if (generated) {
|
||||
return;
|
||||
}
|
||||
generated = true;
|
||||
try {
|
||||
buildGrammar();
|
||||
grammar.verify();
|
||||
|
@ -106,15 +102,23 @@ public abstract class AbstractSleighAssemblerBuilder< //
|
|||
}
|
||||
}
|
||||
|
||||
private void checkGenerateAssembler() throws SleighException {
|
||||
if (generated) {
|
||||
return;
|
||||
}
|
||||
generated = true;
|
||||
generateAssembler();
|
||||
}
|
||||
|
||||
@Override
|
||||
public A getAssembler(AssemblySelector selector) {
|
||||
generateAssembler();
|
||||
checkGenerateAssembler();
|
||||
return newAssembler(selector);
|
||||
}
|
||||
|
||||
@Override
|
||||
public A getAssembler(AssemblySelector selector, Program program) {
|
||||
generateAssembler();
|
||||
checkGenerateAssembler();
|
||||
return newAssembler(selector, program);
|
||||
}
|
||||
|
||||
|
|
|
@ -17,7 +17,8 @@ package ghidra.app.plugin.assembler.sleigh.sem;
|
|||
|
||||
import java.math.BigInteger;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.*;
|
||||
import java.util.Arrays;
|
||||
import java.util.Iterator;
|
||||
import java.util.concurrent.atomic.AtomicLong;
|
||||
|
||||
import ghidra.app.plugin.assembler.sleigh.expr.MaskedLong;
|
||||
|
|
|
@ -15,16 +15,11 @@
|
|||
*/
|
||||
package ghidra.app.plugin.languages.sleigh;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.HashSet;
|
||||
import java.util.Set;
|
||||
import java.util.*;
|
||||
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.AssemblyDefaultContext;
|
||||
import ghidra.app.plugin.assembler.sleigh.sem.AssemblyPatternBlock;
|
||||
import ghidra.app.plugin.processors.sleigh.Constructor;
|
||||
import ghidra.app.plugin.processors.sleigh.ContextChange;
|
||||
import ghidra.app.plugin.processors.sleigh.ContextCommit;
|
||||
import ghidra.app.plugin.processors.sleigh.SleighLanguage;
|
||||
import ghidra.app.plugin.processors.sleigh.*;
|
||||
import ghidra.app.plugin.processors.sleigh.pattern.DisjointPattern;
|
||||
import ghidra.app.plugin.processors.sleigh.symbol.SubtableSymbol;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue