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 | |
---|
11 | RELS=$(ARCH)/rtems-cpu.rel |
---|
12 | |
---|
13 | # C source names, if any, go here -- minus the .c |
---|
14 | # Normally cpu_asm and rtems are assembly files |
---|
15 | C_PIECES=cpu rtems |
---|
16 | C_FILES=$(C_PIECES:%=%.c) |
---|
17 | C_O_FILES=$(C_PIECES:%=${ARCH}/%.o) |
---|
18 | |
---|
19 | H_FILES=$(srcdir)/cpu.h $(srcdir)/a29ktypes.h |
---|
20 | |
---|
21 | # H_FILES that get installed externally |
---|
22 | # a29k.h is handled separately |
---|
23 | EXTERNAL_H_FILES = $(srcdir)/asm.h $(srcdir)/amd.ah $(srcdir)/pswmacro.ah $(srcdir)/register.ah |
---|
24 | |
---|
25 | # Assembly source names, if any, go here -- minus the .s |
---|
26 | # Normally cpu_asm and rtems are assembly files |
---|
27 | S_PIECES=cpu_asm sig |
---|
28 | S_FILES=$(S_PIECES:%=%.s) |
---|
29 | S_O_FILES=$(S_FILES:%.s=${ARCH}/%.o) |
---|
30 | |
---|
31 | SRCS=$(C_FILES) $(CC_FILES) $(H_FILES) $(S_FILES) $(EXTERNAL_H_FILES) |
---|
32 | OBJS=$(C_O_FILES) $(CC_O_FILES) $(S_O_FILES) |
---|
33 | |
---|
34 | include $(RTEMS_ROOT)/make/custom/$(RTEMS_BSP).cfg |
---|
35 | include $(RTEMS_ROOT)/make/leaf.cfg |
---|
36 | |
---|
37 | # |
---|
38 | # (OPTIONAL) Add local stuff here using += |
---|
39 | # |
---|
40 | |
---|
41 | DEFINES += |
---|
42 | CPPFLAGS += |
---|
43 | CFLAGS += $(CFLAGS_OS_V) |
---|
44 | |
---|
45 | LD_PATHS += |
---|
46 | LD_LIBS += |
---|
47 | LDFLAGS += |
---|
48 | |
---|
49 | # |
---|
50 | # Add your list of files to delete here. The config files |
---|
51 | # already know how to delete some stuff, so you may want |
---|
52 | # to just run 'make clean' first to see what gets missed. |
---|
53 | # 'make clobber' already includes 'make clean' |
---|
54 | # |
---|
55 | |
---|
56 | CLEAN_ADDITIONS += |
---|
57 | CLOBBER_ADDITIONS += |
---|
58 | |
---|
59 | all: ${ARCH} $(SRCS) preinstall $(OBJS) $(RELS) |
---|
60 | $(INSTALL_VARIANT) -m 444 $(RELS) ${PROJECT_RELEASE}/lib |
---|
61 | |
---|
62 | $(ARCH)/rtems-cpu.rel: $(OBJS) |
---|
63 | $(make-rel) |
---|
64 | |
---|
65 | # Install the program(s), appending _g or _p as appropriate. |
---|
66 | # for include files, just use $(INSTALL) |
---|
67 | |
---|
68 | preinstall: $(PROJECT_INCLUDE)/rtems/score/a29k.h \ |
---|
69 | $(PROJECT_INCLUDE)/rtems/score/targopts.h \ |
---|
70 | ${PROJECT_RELEASE}/lib/bsp_specs |
---|
71 | $(INSTALL) -m 444 ${H_FILES} $(PROJECT_INCLUDE)/rtems/score |
---|
72 | # we will share the basic cpu file |
---|
73 | $(INSTALL) -m 444 ${EXTERNAL_H_FILES} $(PROJECT_INCLUDE) |
---|
74 | |
---|
75 | $(PROJECT_INCLUDE)/rtems/score/a29k.h: a29k.h |
---|
76 | $(SED) -e 's?REPLACE_THIS_WITH_THE_CPU_MODEL?$(RTEMS_CPU_MODEL)?' \ |
---|
77 | -e 's?REPLACE_THIS_WITH_THE_BSP?$(RTEMS_BSP)?' \ |
---|
78 | < $< >$(ARCH)/a29k.h.tmp |
---|
79 | $(INSTALL) -m 444 $(ARCH)/a29k.h.tmp $@ |
---|
80 | |
---|
81 | $(PROJECT_INCLUDE)/rtems/score/targopts.h: $(ARCH)/targopts.h-tmp |
---|
82 | $(INSTALL) -m 444 $(ARCH)/targopts.h-tmp $@ |
---|
83 | |
---|
84 | # $(ARCH)/targopts.h-tmp rule is in leaf.cfg |
---|
85 | |
---|
86 | ${PROJECT_RELEASE}/lib/bsp_specs: $(ARCH)/bsp_specs.tmp |
---|
87 | $(INSTALL) -m 444 $(ARCH)/bsp_specs.tmp $@ |
---|
88 | |
---|
89 | # $(ARCH)/bsp_specs.tmp rule is in leaf.cfg |
---|