2022-02-19 12:44:20 +01:00
|
|
|
# Makefile for the assembler 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
|
|
|
|
|
|
|
|
CA65 := $(if $(wildcard ../../../bin/ca65*),../../../bin/ca65,ca65)
|
|
|
|
LD65 := $(if $(wildcard ../../../bin/ld65*),../../../bin/ld65,ld65)
|
|
|
|
|
|
|
|
WORKDIR = ../../../testwrk/asm/listing
|
|
|
|
|
|
|
|
ISEQUAL = ../../../testwrk/isequal$(EXE)
|
|
|
|
|
|
|
|
CC = gcc
|
|
|
|
CFLAGS = -O2
|
|
|
|
|
|
|
|
.PHONY: all clean
|
|
|
|
|
|
|
|
LISTING_SRC := $(wildcard *.s)
|
|
|
|
LISTING_TESTS = $(LISTING_SRC:%.s=%)
|
|
|
|
LISTING_BINS = $(LISTING_SRC:%.s=$(WORKDIR)/%.bin)
|
|
|
|
|
|
|
|
all: $(LISTING_BINS)
|
|
|
|
|
|
|
|
$(WORKDIR):
|
|
|
|
$(call MKDIR,$(WORKDIR))
|
|
|
|
|
|
|
|
$(ISEQUAL): ../../isequal.c | $(WORKDIR)
|
|
|
|
$(CC) $(CFLAGS) -o $@ $<
|
|
|
|
|
|
|
|
|
|
|
|
define LISTING_template
|
|
|
|
|
2022-06-18 23:38:18 +02:00
|
|
|
$(WORKDIR)/$1.bin: $1.s $(ISEQUAL)
|
2022-02-19 12:44:20 +01:00
|
|
|
$(if $(QUIET),echo asm/$1.bin)
|
|
|
|
|
2022-03-03 14:03:01 +08:00
|
|
|
# compile without generating listing
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.err),)
|
2022-06-16 20:57:53 +02:00
|
|
|
$(CA65) -t none -o $$(@:.bin=.o) $$< > $$(@:.bin=.err) 2>&1
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.no-ld65),)
|
2022-02-19 12:44:20 +01:00
|
|
|
$(LD65) -t none -o $$@ $$(@:.bin=.o) none.lib
|
2022-06-18 22:22:27 +02:00
|
|
|
endif
|
|
|
|
else
|
|
|
|
$(CA65) -t none -o $$(@:.bin=.o) $$< > $$(@:.bin=.err) 2>&1 || true
|
|
|
|
ifeq ($(wildcard $1.no-ld65),)
|
|
|
|
$(LD65) -t none -o $$@ $$(@:.bin=.o) none.lib || true
|
|
|
|
endif
|
|
|
|
endif
|
2022-02-19 12:44:20 +01:00
|
|
|
|
2022-06-16 20:57:53 +02:00
|
|
|
ifneq ($(wildcard $1.err-ref),)
|
|
|
|
$(ISEQUAL) $1.err-ref $$(@:.bin=.err)
|
2022-06-18 21:04:36 +02:00
|
|
|
else
|
2022-06-18 23:38:18 +02:00
|
|
|
$(ISEQUAL) --empty $$(@:.bin=.err)
|
2022-06-16 20:57:53 +02:00
|
|
|
endif
|
|
|
|
|
2022-02-19 12:44:20 +01:00
|
|
|
ifneq ($(wildcard $1.bin-ref),)
|
2022-06-18 23:38:18 +02:00
|
|
|
$(ISEQUAL) --binary $1.bin-ref $$@
|
2022-02-19 12:44:20 +01:00
|
|
|
endif
|
|
|
|
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.err),)
|
2022-06-18 23:38:18 +02:00
|
|
|
$(CA65) -t none -l $$(@:.bin=.lst) -o $$(@:.bin=.list-o) $$< > $$(@:.bin=.list-err) 2>&1
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.no-ld65),)
|
2022-06-18 21:04:36 +02:00
|
|
|
$(LD65) -t none -o $$(@:.bin=.list-bin) $$(@:.bin=.list-o) none.lib > $$(@:.bin=.ld65-err) 2>&1
|
2022-06-18 22:22:27 +02:00
|
|
|
endif
|
|
|
|
else
|
2022-06-18 23:38:18 +02:00
|
|
|
$(CA65) -t none -l $$(@:.bin=.lst) -o $$(@:.bin=.list-o) $$< > $$(@:.bin=.list-err) 2>&1 || true
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.no-ld65),)
|
|
|
|
$(LD65) -t none -o $$(@:.bin=.list-bin) $$(@:.bin=.list-o) none.lib > $$(@:.bin=.ld65-err) 2>&1 || true
|
|
|
|
endif
|
|
|
|
endif
|
2022-02-19 12:44:20 +01:00
|
|
|
|
2022-06-16 20:57:53 +02:00
|
|
|
ifneq ($(wildcard $1.err-ref),)
|
|
|
|
$(ISEQUAL) $1.err-ref $$(@:.bin=.list-err)
|
2022-06-18 21:04:36 +02:00
|
|
|
else
|
2022-06-18 23:38:18 +02:00
|
|
|
$(ISEQUAL) --empty $$(@:.bin=.list-err)
|
2022-06-18 21:04:36 +02:00
|
|
|
endif
|
|
|
|
|
2022-06-18 22:22:27 +02:00
|
|
|
ifneq ($(wildcard $(WORKDIR)/$1.ld65-err),)
|
2022-06-18 21:04:36 +02:00
|
|
|
ifneq ($(wildcard $1.ld65err-ref),)
|
|
|
|
$(ISEQUAL) $1.ld65err-ref $$(@:.bin=.ld65-err)
|
|
|
|
else
|
2022-06-18 23:38:18 +02:00
|
|
|
$(ISEQUAL) --empty $$(@:.bin=.ld65-err)
|
2022-06-16 20:57:53 +02:00
|
|
|
endif
|
2022-06-18 22:22:27 +02:00
|
|
|
endif
|
2022-06-16 20:57:53 +02:00
|
|
|
|
2022-03-03 14:03:01 +08:00
|
|
|
# check if the result bin is the same as without listing file
|
2022-06-18 22:22:27 +02:00
|
|
|
ifeq ($(wildcard $1.err),)
|
2022-02-19 12:44:20 +01:00
|
|
|
$(ISEQUAL) $$@ $$(@:.bin=.list-bin)
|
2022-06-18 22:22:27 +02:00
|
|
|
endif
|
2022-02-19 12:44:20 +01:00
|
|
|
|
|
|
|
ifneq ($(wildcard $1.list-ref),)
|
2022-03-03 14:03:01 +08:00
|
|
|
# we have a reference file, compare that, too
|
2022-02-19 12:44:20 +01:00
|
|
|
|
2022-03-03 14:03:01 +08:00
|
|
|
# remove first line which contains a version number
|
2022-06-19 22:42:44 +02:00
|
|
|
$(ISEQUAL) --skip=1 $1.list-ref $$(@:.bin=.lst)
|
2022-02-19 12:44:20 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
endef # LISTING_template
|
|
|
|
|
|
|
|
|
|
|
|
$(foreach listing,$(LISTING_TESTS),$(eval $(call LISTING_template,$(listing))))
|
|
|
|
|
|
|
|
|
|
|
|
$(WORKDIR)/%.o: %.s | $(WORKDIR)
|
|
|
|
$(CA65) -l $(@:.o=.lst) -o $@ $<
|
|
|
|
|
|
|
|
clean:
|
|
|
|
@$(call RMDIR,$(WORKDIR))
|