Changeset cc1f8d4 in mainline for boot/arch/mips32/loader/Makefile


Ignore:
Timestamp:
2009-10-20T16:08:08Z (15 years ago)
Author:
Martin Decky <martin@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
50989793
Parents:
00413c5c
Message:

proper support for parallel building (this time really tested)
all ports except sparc64 (which should follow soon)

File:
1 edited

Legend:

Unmodified
Added
Removed
  • boot/arch/mips32/loader/Makefile

    r00413c5c rcc1f8d4  
    11#
    2 # Copyright (c) 2006 Martin Decky
     2# Copyright (c) 2005 Martin Decky
     3# Copyright (c) 2007 Jakub Jermar
    34# All rights reserved.
    45#
     
    2728#
    2829
    29 include ../../../../version
    30 -include ../../../../Makefile.config
     30include Makefile.common
    3131
    32 ## Toolchain configuration
    33 #
     32.PHONY: all clean
    3433
    35 ifndef CROSS_PREFIX
    36         CROSS_PREFIX = /usr/local
    37 endif
    38 
    39 BFD_ARCH = mips
    40 TARGET = mipsel-linux-gnu
    41 TOOLCHAIN_DIR = $(CROSS_PREFIX)/mips32/bin
    42 
    43 ifeq ($(MACHINE),lgxemul)
    44         BFD_NAME = elf32-tradlittlemips
    45         BFD = ecoff-littlemips
    46 endif
    47 ifeq ($(MACHINE),bgxemul)
    48         BFD_NAME = elf32-tradbigmips
    49         BFD = ecoff-bigmips
    50         TOOLCHAIN_DIR = $(CROSS_PREFIX)/mips32eb/bin
    51         TARGET = mips-linux-gnu
    52 endif
    53 ifeq ($(MACHINE),msim)
    54         BFD_NAME = elf32-tradlittlemips
    55         BFD = binary
    56 endif
    57 
    58 ifeq ($(COMPILER),gcc_native)
    59         CC = gcc
    60         AS = as
    61         LD = ld
    62         OBJCOPY = objcopy
    63         OBJDUMP = objdump
    64 endif
    65 
    66 ifeq ($(COMPILER),gcc_cross)
    67         CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
    68         AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
    69         LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
    70         OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
    71         OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
    72 endif
    73 
    74 CFLAGS = -DRELEASE=$(RELEASE) -I. -I../../../generic -imacros ../../../../config.h -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mno-abicalls -G 0 -fno-zero-initialized-in-bss -mhard-float -mips3 -pipe
    75 
    76 SOURCES = \
    77         main.c \
    78         msim.c \
    79         _components.c \
    80         ../../../generic/printf.c \
    81         ../../../generic/string.c \
    82         asm.S \
    83         boot.S
    84 
    85 COMPONENTS = \
    86         $(KERNELDIR)/kernel.bin \
    87         $(USPACEDIR)/srv/ns/ns \
    88         $(USPACEDIR)/srv/loader/loader \
    89         $(USPACEDIR)/app/init/init \
    90         $(USPACEDIR)/srv/devmap/devmap \
    91         $(USPACEDIR)/srv/bd/rd/rd \
    92         $(USPACEDIR)/srv/vfs/vfs
    93 ifeq ($(RDFMT),tmpfs)
    94         COMPONENTS += $(USPACEDIR)/srv/fs/tmpfs/tmpfs
    95 endif
    96 ifeq ($(RDFMT),fat)
    97         COMPONENTS += $(USPACEDIR)/srv/fs/fat/fat
    98 endif
    99 
    100 RD_SRVS = \
    101         $(USPACEDIR)/srv/fb/fb \
    102         $(USPACEDIR)/srv/kbd/kbd \
    103         $(USPACEDIR)/srv/console/console \
    104         $(USPACEDIR)/srv/fs/devfs/devfs \
    105         $(USPACEDIR)/srv/fs/tmpfs/tmpfs \
    106         $(USPACEDIR)/srv/fs/fat/fat \
    107         $(USPACEDIR)/srv/bd/file_bd/file_bd \
    108         $(USPACEDIR)/srv/bd/gxe_bd/gxe_bd \
    109         $(USPACEDIR)/srv/part/mbr_part/mbr_part
    110 
    111 RD_APPS = \
    112         $(USPACEDIR)/app/edit/edit \
    113         $(USPACEDIR)/app/getvc/getvc \
    114         $(USPACEDIR)/app/tetris/tetris \
    115         $(USPACEDIR)/app/tester/tester \
    116         $(USPACEDIR)/app/trace/trace \
    117         $(USPACEDIR)/app/bdsh/bdsh \
    118         $(USPACEDIR)/app/klog/klog
    119 
    120 OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
    121 COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
    122 
    123 .PHONY: all clean depend
    124 
    125 all: image.boot
    126 
    127 -include Makefile.depend
    128 
    129 image.boot: image.raw
    130         $(OBJCOPY) -O $(BFD) $< $@
    131 
    132 image.raw: depend _components.h _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
    133         $(LD) -no-check-sections -N -T _link.ld -o $@ $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
    134 
    135 depend:
    136         -makedepend -f - -- $(DEFS) $(CFLAGS) -- $(SOURCES) > Makefile.depend 2> /dev/null
     34all: ../../../../version ../../../../Makefile.config ../../../../config.h ../../../../config.defs
     35        -[ -f $(DEPEND) ] && mv -f $(DEPEND) $(DEPEND_PREV)
     36        $(MAKE) -f Makefile.build
    13737
    13838clean:
    139         -for file in $(RD_SRVS) ; do \
     39        for file in $(RD_SRVS) ; do \
    14040                rm -f $(USPACEDIR)/dist/srv/`basename $$file` ; \
    14141        done
    142         -for file in $(RD_APPS) ; do \
     42        for file in $(RD_APPS) ; do \
    14343                rm -f $(USPACEDIR)/dist/app/`basename $$file` ; \
    14444        done
    145         -rm -f _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) initrd.img image.raw image.boot Makefile.depend
    146 
    147 _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o: $(COMPONENTS) $(RD_SRVS) $(RD_APPS) _link.ld.in
    148         for file in $(RD_SRVS) ; do \
    149                 cp $$file $(USPACEDIR)/dist/srv/ ; \
    150         done
    151         for file in $(RD_APPS) ; do \
    152                 cp $$file $(USPACEDIR)/dist/app/ ; \
    153         done
    154 ifeq ($(RDFMT),tmpfs)
    155         ../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs
    156 endif
    157 ifeq ($(RDFMT),fat)
    158         ../../../../tools/mkfat.py $(USPACEDIR)/dist/ initrd.fs
    159 endif
    160         ../../../../tools/mkhord.py 16384 initrd.fs initrd.img
    161         rm initrd.fs
    162         ../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 16384 "unsigned int" $(COMPONENTS) ./initrd.img
    163 
    164 %.o: %.S
    165         $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
    166 
    167 %.o: %.c
    168         $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
     45        rm -f $(DEPEND) $(DEPEND_PREV) $(OUTPUT) $(RAW) $(COMPS).h $(COMPS).c $(LINK) $(INITRD).img $(INITRD).fs
     46        find . -name '*.o' -follow -exec rm \{\} \;
     47        find . -name '*.co' -follow -exec rm \{\} \;
Note: See TracChangeset for help on using the changeset viewer.