Files
ghidra-xtensa/Makefile
Sebastian Schmidt 9e34a2b211 Initial commit
2019-06-22 15:04:45 +02:00

55 lines
1.6 KiB
Makefile

# Assume we are in Ghidra/Processors/subdir
GHIDRA_DIR ?= $(shell readlink -f $(CURDIR)/../../..)
SLEIGH ?= $(GHIDRA_DIR)/support/sleigh
PERL ?= perl
# -x turns on parser debugging (SleighCompile)
# -u print warnings for unnecessary pcode instructions (SleighCompile)
# -l report pattern conflicts (SleighCompile)
# -n print warnings for all NOP constructors (SleighCompile)
# -t print warnings for dead temporaries (SleighCompile)
# -e enforce use of 'local' keyword for temporaries (SleighCompile)
# -f print warnings for unused token fields (SleighCompile)
SLEIGH_ARGS := -x -u -l -n -t -e -f
LANGDIR := data/languages
# Must start with slaspec.
SLA_SRCS := $(LANGDIR)/xtensa.slaspec $(wildcard $(LANGDIR)/xtensa*.sinc)
SLA := $(LANGDIR)/xtensa.sla
MANDIR := data/manuals
IDX := $(MANDIR)/xtensa.idx
# Targets
.PHONY: all
all: check-ghidra $(SLA) $(IDX)
.PHONY: check-ghidra
check-ghidra:
@if [ ! -d $(GHIDRA_DIR)/Ghidra ]; then \
echo "Your Ghidra installation directory could not be determined." >&2; \
echo "Please re-run make with GHIDRA_DIR set to the root of your Ghidra installation." >&2; \
exit 1; \
fi
$(SLA): $(SLA_SRCS)
$(SLEIGH) $(SLEIGH_ARGS) $< $@
$(IDX): $(SLA_SRCS)
mkdir -p $(MANDIR)
$(PERL) mkindex.pl $^ > $@
release.zip: clean all
mkdir -p release/Xtensa/$(LANGDIR)
cp -r $(LANGDIR)/xtensa* release/Xtensa/$(LANGDIR)
mkdir -p release/Xtensa/$(MANDIR)
cp -r $(MANDIR)/*.idx release/Xtensa/$(MANDIR)
cp Module.manifest release/Xtensa
cd release && zip -r ../$@ .
.PHONY: clean
clean:
rm -rf $(SLA) $(IDX) release release.zip