Changeset cc1f8d4 in mainline for boot/arch/ppc32/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/ppc32/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_NAME = elf32-powerpc
    40 BFD_ARCH = powerpc:common
    41 TARGET = ppc-linux-gnu
    42 TOOLCHAIN_DIR = $(CROSS_PREFIX)/ppc32/bin
    43 
    44 ifeq ($(COMPILER),gcc_native)
    45         CC = gcc
    46         AS = as
    47         LD = ld
    48         OBJCOPY = objcopy
    49         OBJDUMP = objdump
    50 endif
    51 
    52 ifeq ($(COMPILER),gcc_cross)
    53         CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
    54         AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
    55         LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
    56         OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
    57         OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
    58 endif
    59 
    60 CFLAGS = -DRELEASE=$(RELEASE) -I. -I../../../generic -I../../../genarch -imacros ../../../../config.h -nostdinc -nostdlib -fno-builtin -Werror-implicit-function-declaration -Wmissing-prototypes -Werror -O3 -mcpu=powerpc -msoft-float -m32 -pipe
    61 
    62 SOURCES = \
    63         main.c \
    64         _components.c \
    65         ../../../generic/printf.c \
    66         ../../../generic/string.c \
    67         ../../../genarch/balloc.c \
    68         ../../../genarch/ofw.c \
    69         ../../../genarch/ofw_tree.c \
    70         ofwarch.c \
    71         asm.S \
    72         boot.S
    73 
    74 COMPONENTS = \
    75         $(KERNELDIR)/kernel.bin \
    76         $(USPACEDIR)/srv/ns/ns \
    77         $(USPACEDIR)/app/init/init \
    78         $(USPACEDIR)/srv/loader/loader \
    79         $(USPACEDIR)/srv/devmap/devmap \
    80         $(USPACEDIR)/srv/bd/rd/rd \
    81         $(USPACEDIR)/srv/vfs/vfs
    82 ifeq ($(RDFMT),tmpfs)
    83         COMPONENTS += $(USPACEDIR)/srv/fs/tmpfs/tmpfs
    84 endif
    85 ifeq ($(RDFMT),fat)
    86         COMPONENTS += $(USPACEDIR)/srv/fs/fat/fat
    87 endif
    88 
    89 RD_SRVS = \
    90         $(USPACEDIR)/srv/fb/fb \
    91         $(USPACEDIR)/srv/kbd/kbd \
    92         $(USPACEDIR)/srv/console/console \
    93         $(USPACEDIR)/srv/fs/devfs/devfs \
    94         $(USPACEDIR)/srv/fs/tmpfs/tmpfs \
    95         $(USPACEDIR)/srv/fs/fat/fat \
    96         $(USPACEDIR)/srv/bd/file_bd/file_bd \
    97         $(USPACEDIR)/srv/part/mbr_part/mbr_part
    98 
    99 RD_APPS = \
    100         $(USPACEDIR)/app/edit/edit \
    101         $(USPACEDIR)/app/getvc/getvc \
    102         $(USPACEDIR)/app/tetris/tetris \
    103         $(USPACEDIR)/app/tester/tester \
    104         $(USPACEDIR)/app/trace/trace \
    105         $(USPACEDIR)/app/bdsh/bdsh \
    106         $(USPACEDIR)/app/klog/klog
    107 
    108 OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
    109 COMPONENT_OBJECTS := $(addsuffix .o,$(basename $(notdir $(COMPONENTS))))
    110 
    111 .PHONY: all clean depend
    112 
    113 all: image.boot
    114 
    115 -include Makefile.depend
    116 
    117 image.boot: depend _components.h _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS)
    118         $(LD) -no-check-sections -N -T _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) -o $@
    119 
    120 depend:
    121         -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
    12237
    12338clean:
    124         -for file in $(RD_SRVS) ; do \
     39        for file in $(RD_SRVS) ; do \
    12540                rm -f $(USPACEDIR)/dist/srv/`basename $$file` ; \
    12641        done
    127         -for file in $(RD_APPS) ; do \
     42        for file in $(RD_APPS) ; do \
    12843                rm -f $(USPACEDIR)/dist/app/`basename $$file` ; \
    12944        done
    130         -rm -f _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o $(OBJECTS) initrd.img image.boot Makefile.depend
    131 
    132 _components.h _components.c _link.ld $(COMPONENT_OBJECTS) initrd.o: $(COMPONENTS) $(RD_SRVS) $(RD_APPS) _link.ld.in
    133         for file in $(RD_SRVS) ; do \
    134                 cp $$file $(USPACEDIR)/dist/srv/ ; \
    135         done
    136         for file in $(RD_APPS) ; do \
    137                 cp $$file $(USPACEDIR)/dist/app/ ; \
    138         done
    139 ifeq ($(RDFMT),tmpfs)
    140         ../../../../tools/mktmpfs.py $(USPACEDIR)/dist/ initrd.fs
    141 endif
    142 ifeq ($(RDFMT),fat)
    143         ../../../../tools/mkfat.py $(USPACEDIR)/dist/ initrd.fs
    144 endif
    145         ../../../../tools/mkhord.py 4096 initrd.fs initrd.img
    146         rm initrd.fs
    147         ../../../tools/pack.py $(OBJCOPY) $(BFD_NAME) $(BFD_ARCH) 4096 "unsigned int" $(COMPONENTS) ./initrd.img
    148 
    149 %.o: %.S
    150         $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
    151 
    152 %.o: %.c
    153         $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
     45        rm -f $(DEPEND) $(DEPEND_PREV) $(OUTPUT) $(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.