2006-06-27 03:35:46 +03:00
|
|
|
#
|
|
|
|
# Copyright (C) 2006 OpenWrt.org
|
|
|
|
#
|
|
|
|
# This is free software, licensed under the GNU General Public License v2.
|
|
|
|
# See /LICENSE for more information.
|
|
|
|
#
|
2007-03-18 11:32:22 +02:00
|
|
|
RAMSTART = 0x80000000
|
|
|
|
RAMSIZE = 0x00100000 # 1MB
|
2006-01-31 04:32:29 +02:00
|
|
|
LOADADDR = 0x80400000 # RAM start + 4M
|
|
|
|
KERNEL_ENTRY = 0x80001000
|
2006-06-08 02:45:42 +03:00
|
|
|
IMAGE_COPY:=0
|
2006-01-12 21:10:07 +02:00
|
|
|
|
|
|
|
CROSS_COMPILE = mips-linux-
|
|
|
|
|
2006-06-08 02:45:42 +03:00
|
|
|
OBJCOPY:= $(CROSS_COMPILE)objcopy -O binary -R .reginfo -R .note -R .comment -R .mdebug -S
|
2007-03-18 11:32:22 +02:00
|
|
|
CFLAGS := -fno-builtin -Os -G 0 -ffunction-sections -mno-abicalls -fno-pic -mabi=32 -march=mips32 -Wa,-32 -Wa,-march=mips32 -Wa,-mips32 -Wa,--trap -Wall -DRAMSTART=${RAMSTART} -DRAMSIZE=${RAMSIZE} -DKERNEL_ENTRY=${KERNEL_ENTRY} -D_LZMA_IN_CB
|
2006-06-08 02:45:42 +03:00
|
|
|
ifeq ($(IMAGE_COPY),1)
|
|
|
|
CFLAGS += -DLOADADDR=${LOADADDR} -DIMAGE_COPY=1
|
|
|
|
endif
|
|
|
|
|
2006-01-12 21:10:07 +02:00
|
|
|
.S.s:
|
|
|
|
$(CPP) $(CFLAGS) $< -o $*.s
|
|
|
|
.S.o:
|
|
|
|
$(CC) $(CFLAGS) -c $< -o $*.o
|
|
|
|
.c.o:
|
|
|
|
$(CC) $(CFLAGS) -c $< -o $*.o
|
|
|
|
|
|
|
|
CC = $(CROSS_COMPILE)gcc
|
|
|
|
LD = $(CROSS_COMPILE)ld
|
|
|
|
OBJDUMP = $(CROSS_COMPILE)objdump
|
|
|
|
|
|
|
|
O_FORMAT = $(shell $(OBJDUMP) -i | head -2 | grep elf32)
|
|
|
|
|
|
|
|
# Drop some uninteresting sections in the kernel.
|
|
|
|
# This is only relevant for ELF kernels but doesn't hurt a.out
|
|
|
|
drop-sections = .reginfo .mdebug .comment
|
|
|
|
strip-flags = $(addprefix --remove-section=,$(drop-sections))
|
|
|
|
|
2008-03-26 15:33:22 +02:00
|
|
|
all : lzma.elf lzma.bin
|
2006-01-12 21:10:07 +02:00
|
|
|
|
2006-01-31 04:32:29 +02:00
|
|
|
lzma.lds: lzma.lds.in
|
2006-06-08 02:45:42 +03:00
|
|
|
sed -e 's,@LOADADDR@,$(LOADADDR),g' -e 's,@ENTRY@,_start,g' $< >$@
|
2006-01-31 04:32:29 +02:00
|
|
|
|
|
|
|
kernel.o: vmlinux.lzma lzma.lds
|
2006-01-12 21:10:07 +02:00
|
|
|
$(LD) -r -b binary --oformat $(O_FORMAT) -o $@ $<
|
|
|
|
|
2008-03-26 15:33:22 +02:00
|
|
|
lzma.bin: lzma.elf
|
|
|
|
$(OBJCOPY) $< $@
|
|
|
|
|
2006-06-08 02:45:42 +03:00
|
|
|
ifeq ($(IMAGE_COPY),1)
|
2006-11-18 20:04:28 +02:00
|
|
|
LOADER_ENTRY ?= $(KERNEL_ENTRY)
|
2008-03-27 17:44:14 +02:00
|
|
|
lzma.o: decompress.o LzmaDecode.o kernel.o print.o printf.o uart16550.o
|
2006-06-08 02:45:42 +03:00
|
|
|
sed -e 's,@LOADADDR@,$(LOADADDR),g' -e 's,@ENTRY@,entry,g' lzma.lds.in >lzma-stage2.lds
|
|
|
|
$(LD) -static --no-warn-mismatch -e entry -Tlzma-stage2.lds -o temp-$@ $^
|
|
|
|
$(OBJCOPY) temp-$@ lzma.tmp
|
|
|
|
@echo "SECTIONS { .data : { code_start = .; *(.data) code_stop = .; }}" > lzma-data.lds
|
|
|
|
$(LD) -no-warn-mismatch -T lzma-data.lds -r -o $@ -b binary lzma.tmp --oformat $(O_FORMAT)
|
|
|
|
|
|
|
|
lzma.elf: start.o lzma.o
|
2006-11-18 20:04:28 +02:00
|
|
|
sed -e 's,@LOADADDR@,$(LOADER_ENTRY),g' lzma-copy.lds.in >lzma-copy.lds
|
2006-06-08 02:45:42 +03:00
|
|
|
$(LD) -s -Tlzma-copy.lds -o $@ $^
|
|
|
|
else
|
2008-03-27 17:44:14 +02:00
|
|
|
lzma.elf: start.o decompress.o LzmaDecode.o kernel.o print.o printf.o uart16550.o
|
2006-01-12 21:10:07 +02:00
|
|
|
$(LD) -s -Tlzma.lds -o $@ $^
|
2006-06-08 02:45:42 +03:00
|
|
|
endif
|
2006-01-12 21:10:07 +02:00
|
|
|
|
|
|
|
clean:
|
2008-03-26 15:33:22 +02:00
|
|
|
rm -f *.o lzma.elf lzma.bin *.tmp *.lds
|