blob: 38216ccf2d47411d2719be3d7949b40dfb64fe73 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
# libc/s08 Makefile
srcdir = .
top_builddir = ../../..
LIB_TYPE = RANLIB
SCC = $(top_builddir)/bin/sdcc -ms08
SAS = $(top_builddir)/bin/sdas6808
# override PORTDIR defined by super (parent) makefile
override PORTDIR = ../build/s08
include $(srcdir)/../incl.mk
HC08_FLOAT = $(COMMON_FLOAT)
HC08_INT = $(COMMON_INT) \
_divsint.c \
_divuint.c \
_modsint.c \
_moduint.c
HC08_LONG = $(COMMON_LONG) \
_mullong.c \
_divulong.c
HC08_LONGLONG = $(COMMON_LONGLONG) \
_rrulonglong.c \
_rrslonglong.c \
_rlulonglong.c \
_rlslonglong.c \
_mullonglong.c \
_divslonglong.c \
_divulonglong.c \
_modslonglong.c \
_modulonglong.c
HC08_SDCC = $(COMMON_SDCC) \
_itoa.c \
_ltoa.c \
_spx.c \
_startup.c \
_strlen.c \
_strcmp.c \
_strcpy.c \
__memcpy.c \
memcpy.c \
_memmove.c \
_heap.c \
sprintf.c \
vprintf.c
HC08SOURCES = $(addprefix ../,$(HC08_FLOAT) $(HC08_INT) $(HC08_LONG) $(HC08_LONGLONG) $(HC08_SDCC))
HC08OBJECTS = $(patsubst %.c,%.rel,$(HC08_FLOAT) $(HC08_INT) $(HC08_LONG) $(HC08_LONGLONG) $(HC08_SDCC))
OBJ = _ret.rel _mulint.rel _setjmp.rel
LIB = s08.lib
CC = $(SCC)
AS = $(SAS)
ASFLAGS = -plosgff
CFLAGS = -I$(srcdir)/../../include -I. --std-c11
all: $(PORTDIR)/$(LIB)
$(PORTDIR)/$(LIB): $(OBJ) $(HC08OBJECTS) Makefile
ifeq ($(LIB_TYPE), SDCCLIB)
rm -f $@; \
$(top_builddir)/bin/sdcclib -a $@ $(OBJ) $(HC08OBJECTS)
else
ifeq ($(LIB_TYPE), AR)
$(top_builddir)/bin/sdar -rcSD $@ $(OBJ) $(HC08OBJECTS)
else
ifeq ($(LIB_TYPE), RANLIB)
$(top_builddir)/bin/sdar -rcD $@ $(OBJ) $(HC08OBJECTS)
else
rm -f $@
for i in $(basename $(OBJ) $(HC08OBJECTS)); do echo $$i >>$@; done
cp $(OBJ) $(HC08OBJECTS) $(PORTDIR)
endif
endif
endif
%.rel: %.c
$(CC) $(CFLAGS) -c $<
%.rel: ../%.c
$(CC) $(CFLAGS) -c $<
clean:
rm -f *.rel *.sym *.lst *~ $(CLEANSPEC) *.dump* *.asm *.lib
distclean: clean
rm -f Makefile
|