Some hc08 related updates that I missed earlier
[fw/sdcc] / support / regression / ports / hc08 / spec.mk
1 # path to uCsim
2 UCHC08A = $(SDCC_DIR)/sim/ucsim/hc08.src/shc08
3 UCHC08B = $(SDCC_DIR)/bin/shc08
4
5 UCHC08 = $(shell if [ -f $(UCHC08A) ]; then echo $(UCHC08A); else echo $(UCHC08B); fi)
6
7 SDCCFLAGS +=-mhc08 --less-pedantic --out-fmt-ihx -DREENTRANT=
8 #SDCCFLAGS +=--less-pedantic -DREENTRANT=reentrant
9
10 OBJEXT = .rel
11 EXEEXT = .ihx
12
13 EXTRAS = $(PORTS_DIR)/$(PORT)/testfwk$(OBJEXT) $(PORTS_DIR)/$(PORT)/support$(OBJEXT)
14
15 # Rule to link into .ihx
16 #%$(EXEEXT): %$(OBJEXT) $(EXTRAS)
17
18 %$(EXEEXT): %.c $(EXTRAS)
19         $(SDCC) $(SDCCFLAGS) $< $(EXTRAS) -o $@
20
21 %$(OBJEXT): %.asm
22         $(SDCC_DIR)/bin/as-hc08 -plosgff $<
23
24 %$(OBJEXT): %.c
25         $(SDCC) $(SDCCFLAGS) -c $< -o $@
26
27 $(PORTS_DIR)/$(PORT)/%$(OBJEXT): fwk/lib/%.c
28         $(SDCC) $(SDCCFLAGS) -c $< -o $@
29
30 # run simulator with 10 seconds timeout
31 %.out: %$(EXEEXT) fwk/lib/timeout
32         mkdir -p `dirname $@`
33         -fwk/lib/timeout 10 $(UCHC08) -t32 $< < $(PORTS_DIR)/$(PORT)/uCsim.cmd > $@ \
34           || echo -e --- FAIL: \"timeout, simulation killed\" in $(<:$(EXEEXT)=.c)"\n"--- Summary: 1/1/1: timeout >> $@
35         -grep -n FAIL $@ /dev/null || true
36
37 fwk/lib/timeout: fwk/lib/timeout.c
38
39 _clean:
40         rm -f ports/$(PORT)/testfwk.asm ports/$(PORT)/*.lst ports/$(PORT)/*.rel ports/$(PORT)/*.sym
41