include more changes for x86_64
[people/indolent/gpxe.git/.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 # Location to place generated files
18 #
19 BIN             := bin
20
21 # If no architecture is specified in Config or on the command-line,
22 # use that of the build machine.
23 #
24 ifndef ARCH
25 ARCH            := $(shell uname -m | sed -e s,i[3456789]86,i386,)
26 endif
27
28 # handle x86_64 like i386, but set -m32 option for 32bit code only
29 ifeq ($(ARCH),x86_64)
30 ARCH            := i386
31 CFLAGS          += -m32
32 ASFLAGS         += --32
33 LDFLAGS         += -m elf_i386
34 endif
35
36 # Drag in architecture-specific Config
37 #
38 MAKEDEPS        += arch/$(ARCH)/Config
39 include arch/$(ARCH)/Config
40
41 # If invoked with no build target, print out a helpfully suggestive
42 # message.
43 #
44 noargs : blib $(BIN)/NIC
45         @echo '===================================================='
46         @echo
47         @echo ' *** WARNING: THE INSTRUCTIONS BELOW DO NOT FULLY WORK YET !!!  ***'
48         @echo ' ***                    PLEASE STAY TUNED                       ***' 
49         @echo
50         @echo 'No target specified. To specify a target, do: '
51         @echo
52         @echo '    make bin/<rom-name>.<output-format> '
53         @echo
54         @echo 'where <output-format> is one of {$(MEDIA) }'
55         @echo
56         @echo 'or: '
57         @echo
58         @echo '    make all<output-format>s'
59         @echo
60         @echo 'to generate all possible images of format <output-format>'
61         @echo
62         @echo 'For example, '
63         @echo
64         @echo '    make allroms '
65         @echo
66         @echo 'will generate all possible .rom (rom burnable) images, and'
67         @echo
68         @echo '    make alldsks'
69         @echo
70         @echo 'will generate all possible .dsk (bootable floppy) images, or'
71         @echo
72         @echo '===================================================='
73         @exit 1
74
75 # Locations of utilities
76 #
77 HOST_CC         ?= gcc
78 CPP             ?= gcc -E -Wp,-Wall
79 RM              ?= rm -f
80 TOUCH           ?= touch
81 MKDIR           ?= mkdir
82 CP              ?= cp
83 PERL            ?= /usr/bin/perl
84 CC              ?= $(CROSS_COMPILE)gcc
85 AS              ?= $(CROSS_COMPILE)as
86 LD              ?= $(CROSS_COMPILE)ld
87 SIZE            ?= $(CROSS_COMPILE)size
88 AR              ?= $(CROSS_COMPILE)ar
89 RANLIB          ?= $(CROSS_COMPILE)ranlib
90 OBJCOPY         ?= $(CROSS_COMPILE)objcopy
91 NM              ?= $(CROSS_COMPILE)nm
92 OBJDUMP         ?= $(CROSS_COMPILE)objdump
93 PARSEROM        ?= $(PERL) ./util/parserom.pl
94 MAKEROM         ?= $(PERL) ./util/makerom.pl
95 MKCONFIG        ?= $(PERL) ./util/mkconfig.pl
96 SYMCHECK        ?= $(PERL) ./util/symcheck.pl
97 SORTOBJDUMP     ?= $(PERL) ./util/sortobjdump.pl
98 NRV2B           ?= ./util/nrv2b
99 ZBIN            ?= ./util/zbin
100 DOXYGEN         ?= doxygen
101
102 # Common flags
103 #
104 CFLAGS          += -I include -I arch/$(ARCH)/include -I . -DARCH=$(ARCH)
105 CFLAGS          += -Os -ffreestanding
106 CFLAGS          += -Wall -W
107 CFLAGS          += -g
108 CFLAGS          += $(EXTRA_CFLAGS)
109 ASFLAGS         += $(EXTRA_ASFLAGS)
110 LDFLAGS         += $(EXTRA_LDFLAGS)
111
112 ifneq ($(NO_WERROR),1)
113 CFLAGS          += -Werror
114 endif
115
116 # CFLAGS for specific object types
117 #
118 CFLAGS_c        += 
119 CFLAGS_S        += -DASSEMBLY
120
121 # Base object name of the current target
122 #
123 OBJECT          = $(firstword $(subst ., ,$(@F)))
124
125 # CFLAGS for specific object files.  You can define
126 # e.g. CFLAGS_rtl8139, and have those flags automatically used when
127 # compiling bin/rtl8139.o.
128 #
129 OBJ_CFLAGS      = $(CFLAGS_$(OBJECT)) -DOBJECT=$(subst -,_,$(OBJECT))
130 $(BIN)/%.flags :
131         @echo $(OBJ_CFLAGS)
132
133 # Rules for specific object types.
134 #
135 COMPILE_c       = $(CC) $(CFLAGS) $(CFLAGS_c) $(OBJ_CFLAGS)
136 RULE_c          = $(Q)$(COMPILE_c) -c $< -o $@
137 RULE_c_to_dbg%.o = $(Q)$(COMPILE_c) -Ddebug_$(OBJECT)=$* -c $< -o $@
138 RULE_c_to_c     = $(Q)$(COMPILE_c) -E -c $< > $@
139 RULE_c_to_s     = $(Q)$(COMPILE_c) -S -g0 -c $< -o $@ 
140
141 PREPROCESS_S    = $(CPP) $(CFLAGS) $(CFLAGS_S) $(OBJ_CFLAGS)
142 ASSEMBLE_S      = $(AS) $(ASFLAGS)
143 RULE_S          = $(Q)$(PREPROCESS_S) $< | $(ASSEMBLE_S) -o $@
144 RULE_S_to_s     = $(Q)$(PREPROCESS_S) $< > $@
145
146 DEBUG_TARGETS   += dbg%.o c s
147
148 # SRCDIRS lists all directories containing source files.
149 #
150 SRCDIRS         += libgcc
151 SRCDIRS         += core
152 SRCDIRS         += proto
153 SRCDIRS         += net net/tcp net/udp
154 SRCDIRS         += image
155 SRCDIRS         += drivers/bus
156 SRCDIRS         += drivers/net
157 SRCDIRS         += drivers/block
158 SRCDIRS         += drivers/scsi
159 SRCDIRS         += drivers/ata
160 SRCDIRS         += drivers/nvs
161 SRCDIRS         += drivers/bitbash
162 SRCDIRS         += interface/pxe
163 SRCDIRS         += tests
164 SRCDIRS         += crypto crypto/axtls crypto/matrixssl
165 SRCDIRS         += hci hci/commands hci/tui
166 SRCDIRS         += hci/mucurses hci/mucurses/widgets
167 SRCDIRS         += usr
168
169 # NON_AUTO_SRCS lists files that are excluded from the normal
170 # automatic build system.
171 #
172 NON_AUTO_SRCS   += core/elf_loader.c
173 NON_AUTO_SRCS   += drivers/net/prism2.c
174
175 # Rules for finalising files.  TGT_MAKEROM_FLAGS is defined as part of
176 # the automatic build system and varies by target; it includes the
177 # "-p 0x1234,0x5678" string to set the PCI IDs.
178 #
179 FINALISE_rom    = $(MAKEROM) $(MAKEROM_FLAGS) $(TGT_MAKEROM_FLAGS) \
180                   -i$(IDENT) -s 0 $@
181
182 # Some ROMs require specific flags to be passed to makerom.pl
183 #
184 MAKEROM_FLAGS_3c503 = -3
185
186 # Drag in architecture-specific Makefile
187 #
188 MAKEDEPS        += arch/$(ARCH)/Makefile
189 include arch/$(ARCH)/Makefile
190
191 # Drag in the automatic build system and other housekeeping functions
192 MAKEDEPS        += Makefile.housekeeping
193 include Makefile.housekeeping