summaryrefslogtreecommitdiffstats
path: root/c/src/exec/score/cpu/powerpc/Makefile.in
blob: 114ca43be37c146a72ea2084cf6c3b2f53db7470 (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
#
#  $Id$
#

@SET_MAKE@
srcdir = @srcdir@
top_srcdir = @top_srcdir@
VPATH=@srcdir@

RELS=$(ARCH)/rtems-cpu.rel

# C source names, if any, go here -- minus the .c
#  Normally cpu_asm and rtems are assembly files
C_PIECES=cpu
C_FILES=$(C_PIECES:%=%.c)
C_O_FILES=$(C_PIECES:%=${ARCH}/%.o)

H_FILES=$(srcdir)/cpu.h $(srcdir)/ppctypes.h

# H_FILES that get installed externally
# ppc.h is handled separately
EXTERNAL_H_FILES = $(srcdir)/asm.h

# Assembly source names, if any, go here -- minus the .s
#  Normally cpu_asm and rtems are assembly files
S_PIECES=cpu_asm rtems
S_FILES=$(S_PIECES:%=%.s)
S_O_FILES=$(S_FILES:%.s=${ARCH}/%.o)

SRCS=$(C_FILES) $(CC_FILES) $(H_FILES) $(S_FILES) $(EXTERNAL_H_FILES) 
OBJS=$(C_O_FILES) $(CC_O_FILES) $(S_O_FILES)

include $(RTEMS_CUSTOM)
include $(PROJECT_ROOT)/make/leaf.cfg

#
# (OPTIONAL) Add local stuff here using +=
#

DEFINES  +=
CPPFLAGS +=
CFLAGS   += $(CFLAGS_OS_V)

LD_PATHS  +=
LD_LIBS   +=
LDFLAGS   +=

#
# Add your list of files to delete here.  The config files
#  already know how to delete some stuff, so you may want
#  to just run 'make clean' first to see what gets missed.
#  'make clobber' already includes 'make clean'
#

CLEAN_ADDITIONS +=
CLOBBER_ADDITIONS +=

all:	${ARCH} $(SRCS) preinstall $(OBJS) $(RELS)

$(ARCH)/rtems-cpu.rel: $(OBJS)
	$(make-rel)

$(ARCH)/cpu_asm.o: irq_stub.s

# Install the program(s), appending _g or _p as appropriate.
# for include files, just use $(INSTALL)
install:  all

preinstall: ${PROJECT_RELEASE}/include/rtems/score/ppc.h \
            ${PROJECT_RELEASE}/include/rtems/score/targopts.h \
            ${PROJECT_RELEASE}/lib/bsp_specs
	$(INSTALL) -m 444 ${H_FILES} ${PROJECT_RELEASE}/include/rtems/score
# we will share the basic cpu file
	$(INSTALL) -m 444 ${EXTERNAL_H_FILES} ${PROJECT_RELEASE}/include
# make a link in case we are not compiling in the source directory
	test -f irq_stub.s || $(LN) -s $(srcdir)/irq_stub.s irq_stub.s

${PROJECT_RELEASE}/include/rtems/score/ppc.h: ppc.h
	 $(SED) -e 's?REPLACE_THIS_WITH_THE_CPU_MODEL?$(RTEMS_CPU_MODEL)?' \
	        -e 's?REPLACE_THIS_WITH_THE_BSP?$(RTEMS_BSP)?' \
      < $< >$(ARCH)/ppc.h.tmp
	$(INSTALL) -m 444 $(ARCH)/ppc.h.tmp $@

${PROJECT_RELEASE}/include/rtems/score/targopts.h: $(ARCH)/targopts.h-tmp
	$(INSTALL) -m 444 $(ARCH)/targopts.h-tmp $@

# $(ARCH)/targopts.h-tmp rule is in leaf.cfg

${PROJECT_RELEASE}/lib/bsp_specs: $(ARCH)/bsp_specs.tmp
	$(INSTALL) -m 444 $(ARCH)/bsp_specs.tmp $@

# $(ARCH)/bsp_specs.tmp rule is in leaf.cfg