2003-06-17 18:51:06 +02:00
|
|
|
## This is Architecture independant part of the makefile
|
|
|
|
|
2003-06-24 18:07:07 +02:00
|
|
|
uses HAVE_OPTION_TABLE
|
2003-06-17 18:51:06 +02:00
|
|
|
|
|
|
|
makedefine CPP:= $(CC) -no-gcc -x assembler-with-cpp -DASSEMBLY -E
|
|
|
|
makedefine LIBGCC_FILE_NAME := $(shell $(CC) -print-libgcc-file-name)
|
|
|
|
makedefine GCC_INC_DIR := $(shell $(CC) -print-search-dirs | sed -ne "s/install: \(.*\)/\1include/gp")
|
|
|
|
|
|
|
|
makedefine CPPFLAGS := -I$(TOP)/src/include -I$(TOP)/src/arch/$(ARCH)/include -I$(GCC_INC_DIR) $(CPUFLAGS)
|
|
|
|
makedefine ROMCCPPFLAGS := -D__ROMCC__=0 -D__ROMCC_MINOR__=23
|
|
|
|
makedefine CFLAGS := $(CPU_OPT) $(CPPFLAGS) -Os -nostdinc -nostdlib -fno-builtin -Wall
|
|
|
|
|
|
|
|
makedefine HOSTCFLAGS:= -Os -Wall
|
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule ldscript.ld
|
|
|
|
depends "ldoptions $(LDSUBSCRIPTS-1)"
|
|
|
|
action "echo \"INCLUDE ldoptions\" > $@ ; for file in $(LDSUBSCRIPTS-1) ; do echo \"INCLUDE $$file\" >> $@ ; done"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
#makerule cpuflags
|
|
|
|
# depends "Makefile.settings"
|
|
|
|
# action "perl -e 'print \"CPUFLAGS :=\n\"; foreach $$var (split(\" \", $$ENV{VARIABLES})) { if (exists($$ENV{$$var})) { print \"CPUFLAGS += -D$$var\" . (length($$ENV{$$var})?\"=\x27$$ENV{$$var}\x27\":\"\") .\"\n\"} else { print \"CPUFLAGS += -U$$var\n\"} }' > $@"
|
|
|
|
#end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
#makerule ldoptions
|
|
|
|
# depends "Makefile.settings"
|
|
|
|
# action "perl -e 'foreach $$var (split(\" \", $$ENV{VARIABLES})) { if ($$ENV{$$var} =~ m/^(0x[0-9a-fA-F]+|0[0-7]+|[0-9]+)$$/) { print \"$$var = $$ENV{$$var};\n\"; }}' > $@"
|
|
|
|
#end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule linuxbios.strip
|
|
|
|
depends "linuxbios"
|
|
|
|
action "$(OBJCOPY) -O binary linuxbios linuxbios.strip"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule linuxbios_c.o
|
|
|
|
depends "$(DRIVER) linuxbios.a $(LIBGCC_FILE_NAME)"
|
|
|
|
action "$(CC) -nostdlib -r -o $@ c_start.o $(DRIVER) linuxbios.a $(LIBGCC_FILE_NAME)"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule linuxbios_c
|
|
|
|
depends "linuxbios_c.o $(TOP)/src/config/linuxbios_c.ld ldoptions"
|
|
|
|
action "$(CC) -nostdlib -nostartfiles -static -o $@ -T $(TOP)/src/config/linuxbios_c.ld linuxbios_c.o"
|
|
|
|
action "$(CROSS_COMPILE)nm -n linuxbios_c | sort > linuxbios_c.map"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
|
|
|
##
|
|
|
|
## By default compress the C part of linuxbios
|
|
|
|
##
|
|
|
|
makedefine LINUXBIOS_PAYLOAD-$(CONFIG_COMPRESS):=linuxbios_payload.nrv2b
|
|
|
|
makedefine LINUXBIOS_PAYLOAD-$(CONFIG_UNCOMPRESSED):=linuxbios_payload.bin
|
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule linuxbios_payload.bin
|
|
|
|
depends "linuxbios_c"
|
|
|
|
action "$(OBJCOPY) -O binary $< $@"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule linuxbios_payload.nrv2b
|
|
|
|
depends "linuxbios_payload.bin nrv2b"
|
|
|
|
action "./nrv2b e $< $@"
|
|
|
|
end
|
|
|
|
|
|
|
|
makerule linuxbios_payload
|
|
|
|
depends "$(LINUXBIOS_PAYLOAD-1)"
|
|
|
|
action "cp $(LINUXBIOS_PAYLOAD-1) linuxbios_payload"
|
|
|
|
end
|
|
|
|
|
|
|
|
makerule linuxbios
|
|
|
|
depends "crt0.o linuxbios_payload ldscript.ld"
|
|
|
|
action "$(CC) -nostdlib -nostartfiles -static -o $@ -T ldscript.ld crt0.o"
|
|
|
|
action "$(CROSS_COMPILE)nm -n linuxbios | sort > linuxbios.map"
|
|
|
|
end
|
|
|
|
|
|
|
|
makerule linuxbios.a
|
|
|
|
depends "$(OBJECTS-1)"
|
|
|
|
action "rm -f linuxbios.a"
|
|
|
|
action "ar cr linuxbios.a $(OBJECTS-1)"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
#makerule crt0.S
|
|
|
|
# depends "$(CRT0)"
|
|
|
|
# action "cp $< $@"
|
|
|
|
#end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
|
|
|
# the buildrom tool
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule buildrom
|
|
|
|
depends "$(TOP)/util/buildrom/buildrom.c"
|
|
|
|
action "$(HOSTCC) -o $@ $<"
|
|
|
|
end
|
|
|
|
|
2003-06-17 18:51:06 +02:00
|
|
|
# Force crt0.s (which has build time version code in it to rebuild every time)
|
|
|
|
makedefine .PHONY : crt0.s
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule crt0.s
|
|
|
|
depends "crt0.S $(CRT0_INCLUDES)"
|
|
|
|
action "@echo \"$(CPP) ... $< > $@ \""
|
|
|
|
action "$(CPP) $(CPPFLAGS) -I. -I$(TOP)/src $< > $@.new && mv $@.new $@"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule crt0.o
|
|
|
|
depends "crt0.s $(INIT-OBJECTS)"
|
|
|
|
action "@echo $(CC) ... -o $@ $<"
|
|
|
|
action "@$(CC) -c $(CPU_OPT) -o $@ $< $(INIT-OBJECTS)"
|
|
|
|
end
|
|
|
|
|
|
|
|
makerule etags
|
|
|
|
depends "$(SOURCES)"
|
|
|
|
action "etags $(SOURCES)"
|
|
|
|
end
|
|
|
|
makerule tags
|
|
|
|
depends "$(SOURCES)"
|
|
|
|
action "ctags $(SOURCES)"
|
|
|
|
end
|
|
|
|
makerule documentation
|
|
|
|
depends "$(SOURCES)"
|
|
|
|
action "doxygen LinuxBIOSDoc.config"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule ./romcc
|
|
|
|
depends "$(TOP)/util/romcc/romcc.c"
|
|
|
|
action "$(HOSTCC) -g $(HOSTCFLAGS) -DVERSION='\"0.21\"' -DRELEASE_DATE='\"7 april 2003\"' $< -o $@"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule build_opt_tbl
|
|
|
|
depends "$(TOP)/util/options/build_opt_tbl.c $(TOP)/src/include/pc80/mc146818rtc.h $(TOP)/src/include/boot/linuxbios_tables.h"
|
|
|
|
action "$(HOSTCC) $(HOSTCFLAGS) $< -o $@"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
#makerule /$(TARGET_DIR)/option_table.c
|
|
|
|
# depends "build_opt_tbl $(MAINBOARD)/cmos.layout"
|
|
|
|
# action "./build_opt_tbl -b --config $(MAINBOARD)/cmos.layout"
|
|
|
|
#end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule option_table.c
|
|
|
|
depends "build_opt_tbl $(MAINBOARD)/cmos.layout"
|
|
|
|
action "./build_opt_tbl -b --config $(MAINBOARD)/cmos.layout"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
|
|
|
if HAVE_OPTION_TABLE
|
|
|
|
object ./option_table.o
|
|
|
|
#special rule
|
2003-07-14 20:00:10 +02:00
|
|
|
#makerule option_table.o
|
|
|
|
# depends "option_table.c"
|
|
|
|
# action "$(CC) -c $(CFLAGS) -o $@ $<"
|
|
|
|
#end
|
2003-06-17 18:51:06 +02:00
|
|
|
# object option_table.o
|
|
|
|
end
|
|
|
|
|
2003-07-14 20:00:10 +02:00
|
|
|
makerule clean
|
|
|
|
action "rm -f linuxbios.* *~"
|
|
|
|
action "rm -f linuxbios"
|
|
|
|
action "rm -f ldscript.ld"
|
|
|
|
action "rm -f a.out *.s *.l *.o"
|
|
|
|
action "rm -f TAGS tags"
|
|
|
|
action "rm -f docipl"
|
|
|
|
action "rm -f build_opt_tbl option_table.c crt0.S"
|
|
|
|
end
|
2003-06-17 18:51:06 +02:00
|
|
|
|
|
|
|
# do standard config files that the user need not specify
|
|
|
|
# for now, this is just 'lib', but it may be more later.
|
|
|
|
dir /lib
|
|
|
|
dir /console
|
|
|
|
dir /stream
|
|
|
|
dir /devices
|
|
|
|
dir /pc80
|
|
|
|
dir /boot
|