1 | # |
---|
2 | # $Id$ |
---|
3 | # |
---|
4 | |
---|
5 | @SET_MAKE@ |
---|
6 | srcdir = @srcdir@ |
---|
7 | VPATH = @srcdir@ |
---|
8 | RTEMS_ROOT = @top_srcdir@ |
---|
9 | PROJECT_ROOT = @PROJECT_ROOT@ |
---|
10 | RTEMS_GAS_CODE16 = @RTEMS_GAS_CODE16@ |
---|
11 | |
---|
12 | PGMS=${ARCH}/start.o ${ARCH}/start16.bin |
---|
13 | |
---|
14 | # C source names, if any, go here -- minus the .c |
---|
15 | C_PIECES= |
---|
16 | C_FILES=$(C_PIECES:%=%.c) |
---|
17 | C_O_FILES=$(C_PIECES:%=${ARCH}/%.o) |
---|
18 | |
---|
19 | H_FILES= |
---|
20 | |
---|
21 | # Assembly source names, if any, go here -- minus the .S |
---|
22 | S_PIECES=start16 start |
---|
23 | S_FILES=$(S_PIECES:%=%.S) |
---|
24 | S_O_FILES=$(S_FILES:%.S=${ARCH}/%.o) |
---|
25 | |
---|
26 | SRCS=$(C_FILES) $(H_FILES) $(S_FILES) |
---|
27 | OBJS=$(C_O_FILES) $(S_O_FILES) |
---|
28 | |
---|
29 | include $(RTEMS_ROOT)/make/custom/$(RTEMS_BSP).cfg |
---|
30 | include $(RTEMS_ROOT)/make/leaf.cfg |
---|
31 | |
---|
32 | # |
---|
33 | # (OPTIONAL) Add local stuff here using += |
---|
34 | # |
---|
35 | |
---|
36 | ifeq ($(RTEMS_GAS_CODE16),yes) |
---|
37 | CPPFLAGS += -DNEW_GAS |
---|
38 | endif |
---|
39 | CFLAGS += |
---|
40 | |
---|
41 | LD_PATHS += |
---|
42 | LD_LIBS += |
---|
43 | LDFLAGS += |
---|
44 | |
---|
45 | # |
---|
46 | # Add your list of files to delete here. The config files |
---|
47 | # already know how to delete some stuff, so you may want |
---|
48 | # to just run 'make clean' first to see what gets missed. |
---|
49 | # 'make clobber' already includes 'make clean' |
---|
50 | # |
---|
51 | |
---|
52 | CLEAN_ADDITIONS += |
---|
53 | CLOBBER_ADDITIONS += |
---|
54 | |
---|
55 | all: ${ARCH} $(SRCS) $(OBJS) $(PGMS) |
---|
56 | $(INSTALL_VARIANT) -m 555 ${PGMS} ${PROJECT_RELEASE}/lib |
---|
57 | |
---|
58 | # Install the program(s), appending _g or _p as appropriate. |
---|
59 | # for include files, just use $(INSTALL) |
---|
60 | |
---|
61 | LINKCMDS=$(srcdir)/../startup/linkcmds |
---|
62 | |
---|
63 | ${ARCH}/start16.o: start16.s |
---|
64 | sed -e 's/\/\/.*$$//' < $< | $(CPP) $(ASMFLAGS) -I. -I$(srcdir) \ |
---|
65 | -DASM -DHEADERADDR=$(HEADERADDR) - > $*.i |
---|
66 | $(AS) $(ASMFLAGS) -o $@ $*.i |
---|
67 | |
---|
68 | ${ARCH}/start16.bin: ${ARCH}/start16.o |
---|
69 | $(LD) -N -T $(LINKCMDS) -Ttext $(START16ADDR) -e start16 -nostdlib \ |
---|
70 | --oformat=elf32-i386 -o $(basename $@).obj $(basename $@).o |
---|
71 | $(OBJCOPY) -O binary $(basename $@).obj $@ |
---|