mirror of
https://github.com/cc65/cc65.git
synced 2024-11-18 15:05:14 +00:00
47bceb0eab
foreach isn't needed because make automatically iterates through lists of words when substituting patterns.
66 lines
1.3 KiB
Makefile
66 lines
1.3 KiB
Makefile
# Makefile for the disassembler regression tests
|
|
|
|
ifneq ($(shell echo),)
|
|
CMD_EXE = 1
|
|
endif
|
|
|
|
ifdef CMD_EXE
|
|
EXE = .exe
|
|
MKDIR = mkdir $(subst /,\,$1)
|
|
RMDIR = -rmdir /q /s $(subst /,\,$1)
|
|
else
|
|
EXE =
|
|
MKDIR = mkdir -p $1
|
|
RMDIR = $(RM) -r $1
|
|
endif
|
|
|
|
ifdef QUIET
|
|
.SILENT:
|
|
endif
|
|
|
|
CL65 := $(if $(wildcard ../../bin/cl65*),../../bin/cl65,cl65)
|
|
DA65 := $(if $(wildcard ../../bin/da65*),../../bin/da65,da65)
|
|
|
|
WORKDIR = ../../testwrk/dasm
|
|
|
|
ISEQUAL = ../../testwrk/isequal$(EXE)
|
|
|
|
CC = gcc
|
|
CFLAGS = -O2
|
|
|
|
START = --start-addr 0x8000
|
|
|
|
.PHONY: all clean
|
|
|
|
SOURCES := $(wildcard *.s)
|
|
BINS = $(SOURCES:%disass.s=$(WORKDIR)/%reass.bin)
|
|
CPUS = $(SOURCES:%-disass.s=%)
|
|
|
|
all: $(BINS)
|
|
|
|
$(WORKDIR):
|
|
$(call MKDIR,$(WORKDIR))
|
|
|
|
$(ISEQUAL): ../isequal.c | $(WORKDIR)
|
|
$(CC) $(CFLAGS) -o $@ $<
|
|
|
|
define DISASS_template
|
|
|
|
$(WORKDIR)/$1-disass.bin: $1-disass.s | $(WORKDIR)
|
|
$(CL65) --cpu $1 -t none $(START) -o $$@ $$<
|
|
|
|
$(WORKDIR)/$1-reass.s: $(WORKDIR)/$1-disass.bin
|
|
$(DA65) --cpu $1 $(START) -o $$@ $$<
|
|
|
|
$(WORKDIR)/$1-reass.bin: $(WORKDIR)/$1-reass.s $(ISEQUAL)
|
|
$(if $(QUIET),echo dasm/$1-reass.bin)
|
|
$(CL65) --cpu $1 -t none $(START) -o $$@ $$<
|
|
$(ISEQUAL) $(WORKDIR)/$1-disass.bin $$@
|
|
|
|
endef # DISASS_template
|
|
|
|
$(foreach cpu,$(CPUS),$(eval $(call DISASS_template,$(cpu))))
|
|
|
|
clean:
|
|
@$(call RMDIR,$(WORKDIR))
|