Merge of Fredrik Hultin command_line
[people/xl0/gpxe.git] / src / Makefile
1 # Initialise variables that get added to throughout the various Makefiles
2 #
3 MAKEDEPS        := Makefile .toolcheck
4 SRCDIRS         :=
5 SRCS            :=
6 NON_AUTO_SRCS   :=
7 DRIVERS         :=
8 ROMS            :=
9 MEDIA           :=
10 NON_AUTO_MEDIA  :=
11
12 # Grab the central Config file.
13 #
14 MAKEDEPS        += Config
15 include Config
16
17 # If no architecture is specified in Config or on the command-line,
18 # use that of the build machine.
19 #
20 ifndef ARCH
21 ARCH            := $(shell uname -m | sed -e s,i[3456789]86,i386,)
22 endif
23
24 # Drag in architecture-specific Config
25 #
26 MAKEDEPS        += arch/$(ARCH)/Config
27 include arch/$(ARCH)/Config
28
29 # If invoked with no build target, print out a helpfully suggestive
30 # message.
31 #
32 noargs :
33         @echo '===================================================='
34         @echo 'No target specified. To specify a target, do: '
35         @echo
36         @echo '    $(MAKE) bin/<rom-name>.<output-format> '
37         @echo
38         @echo 'where <output-format> is one of [z]{$(MEDIA) }'
39         @echo
40         @echo 'or: '
41         @echo
42         @echo '    $(MAKE) all<output-format>s'
43         @echo
44         @echo 'to generate all possible images of format <output-format>'
45         @echo
46         @echo 'For example, '
47         @echo
48         @echo '    make allzroms '
49         @echo
50         @echo 'will generate all possible .zrom (rom burnable) images, and'
51         @echo
52         @echo '    make allzdsks'
53         @echo
54         @echo 'will generate all possible .zdsk (bootable floppy) images, or'
55         @echo
56         @echo '===================================================='
57         @exit 1
58
59 # Locations of utilities
60 #
61 HOST_CC         ?= gcc
62 CPP             ?= gcc -E -Wp,-Wall
63 RM              ?= rm -f
64 TOUCH           ?= touch
65 MKDIR           ?= mkdir
66 PERL            ?= /usr/bin/perl
67 CC              ?= $(CROSS_COMPILE)gcc
68 AS              ?= $(CROSS_COMPILE)as
69 LD              ?= $(CROSS_COMPILE)ld
70 SIZE            ?= $(CROSS_COMPILE)size
71 AR              ?= $(CROSS_COMPILE)ar
72 RANLIB          ?= $(CROSS_COMPILE)ranlib
73 OBJCOPY         ?= $(CROSS_COMPILE)objcopy
74 NM              ?= $(CROSS_COMPILE)nm
75 OBJDUMP         ?= $(CROSS_COMPILE)objdump
76 PARSEROM        ?= $(PERL) ./util/parserom.pl
77 MAKEROM         ?= $(PERL) ./util/makerom.pl
78 MKCONFIG        ?= $(PERL) ./util/mkconfig.pl
79 SYMCHECK        ?= $(PERL) ./util/symcheck.pl
80 SORTOBJDUMP     ?= $(PERL) ./util/sortobjdump.pl
81 NRV2B           ?= ./util/nrv2b
82 DOXYGEN         ?= doxygen
83
84 # Location to place generated files
85 #
86 BIN             ?= bin
87
88 # Common flags
89 #
90 CFLAGS          += -I include -I arch/$(ARCH)/include -I . -DARCH=$(ARCH)
91 CFLAGS          += -Os -ffreestanding
92 CFLAGS          += -Wall -W
93 CFLAGS          += -g
94 CFLAGS          += -DCONSOLE_DUAL -DCOMCONSOLE=0x3F8 -DCONSPEED=9600
95 CFLAGS          += $(EXTRA_CFLAGS)
96 ASFLAGS         += $(EXTRA_ASFLAGS)
97 LDFLAGS         += $(EXTRA_LDFLAGS)
98
99 # CFLAGS for specific object types
100 #
101 CFLAGS_c        += 
102 CFLAGS_S        += -DASSEMBLY
103
104 # Base object name of the current target
105 #
106 OBJECT          = $(firstword $(subst ., ,$(@F)))
107
108 # CFLAGS for specific object files.  You can define
109 # e.g. CFLAGS_rtl8139, and have those flags automatically used when
110 # compiling bin/rtl8139.o.
111 #
112 OBJ_CFLAGS      = $(CFLAGS_$(OBJECT)) -DOBJECT=$(subst -,_,$(OBJECT))
113 $(BIN)/%.flags :
114         @echo $(OBJ_CFLAGS)
115
116 # Rules for specific object types.
117 #
118 COMPILE_c       = $(CC) $(CFLAGS) $(CFLAGS_c) $(OBJ_CFLAGS)
119 RULE_c          = $(COMPILE_c) -c $< -o $@
120 RULE_c_to_dbg.o = $(COMPILE_c) -Ddebug_$(OBJECT) -c $< -o $@
121 RULE_c_to_dbg2.o = $(COMPILE_c) -Ddebug_$(OBJECT)=2 -c $< -o $@
122 RULE_c_to_c     = $(COMPILE_c) -E -c $< > $@
123 RULE_c_to_s     = $(COMPILE_c) -S -g0 -c $< -o $@ 
124
125 PREPROCESS_S    = $(CPP) $(CFLAGS) $(CFLAGS_S) $(OBJ_CFLAGS)
126 ASSEMBLE_S      = $(AS) $(ASFLAGS)
127 RULE_S          = $(PREPROCESS_S) $< | $(ASSEMBLE_S) -o $@
128 RULE_S_to_s     = $(PREPROCESS_S) $< > $@
129
130 DEBUG_TARGETS   += dbg2.o dbg.o c s
131
132 # SRCDIRS lists all directories containing source files.
133 #
134 SRCDIRS         += core
135 SRCDIRS         += proto
136 SRCDIRS         += net net/uip net/tcp net/udp
137 #SRCDIRS                += image
138 SRCDIRS         += drivers/bus
139 SRCDIRS         += drivers/net
140 SRCDIRS         += drivers/block
141 SRCDIRS         += drivers/scsi
142 SRCDIRS         += drivers/ata
143 SRCDIRS         += drivers/nvs
144 SRCDIRS         += drivers/bitbash
145 SRCDIRS         += interface/pxe
146 SRCDIRS         += tests
147 SRCDIRS         += crypto
148 SRCDIRS         += hci/mucurses
149 SRCDIRS         += commandline
150 SRCDIRS         += commandline/commands
151
152 # NON_AUTO_SRCS lists files that are excluded from the normal
153 # automatic build system.
154 #
155 NON_AUTO_SRCS   += core/elf_loader.c
156 NON_AUTO_SRCS   += drivers/net/prism2.c
157
158 # Rules for finalising files.  TGT_MAKEROM_FLAGS is defined as part of
159 # the automatic build system and varies by target; it includes the
160 # "-p 0x1234,0x5678" string to set the PCI IDs.
161 #
162 FINALISE_rom    = $(MAKEROM) $(MAKEROM_FLAGS) $(TGT_MAKEROM_FLAGS) \
163                   -i$(IDENT) $@
164
165 # Some ROMs require specific flags to be passed to makerom.pl
166 #
167 MAKEROM_FLAGS_3c503 = -3
168
169 # Drag in architecture-specific Makefile
170 #
171 MAKEDEPS        += arch/$(ARCH)/Makefile
172 include arch/$(ARCH)/Makefile
173
174 # Drag in the automatic build system and other housekeeping functions
175 MAKEDEPS        += Makefile.housekeeping
176 include Makefile.housekeeping