summaryrefslogtreecommitdiff
path: root/device/lib/s08/Makefile
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