summaryrefslogtreecommitdiffstats
path: root/sys/boot/efi
diff options
context:
space:
mode:
authorru <ru@FreeBSD.org>2004-02-12 08:10:34 +0000
committerru <ru@FreeBSD.org>2004-02-12 08:10:34 +0000
commit29e256506233a1c95ec83caa5e342855e0adf105 (patch)
tree791ce63a1fe22f573e4bf7cf6091279cb40b609a /sys/boot/efi
parentc7690426167e786ff7a8d9c20a2698db348d6dd0 (diff)
downloadFreeBSD-src-29e256506233a1c95ec83caa5e342855e0adf105.zip
FreeBSD-src-29e256506233a1c95ec83caa5e342855e0adf105.tar.gz
Tidy up makefiles.
Tested by: marcel
Diffstat (limited to 'sys/boot/efi')
-rw-r--r--sys/boot/efi/Makefile.inc3
-rw-r--r--sys/boot/efi/libefi/Makefile15
-rw-r--r--sys/boot/efi/loader/Makefile92
3 files changed, 27 insertions, 83 deletions
diff --git a/sys/boot/efi/Makefile.inc b/sys/boot/efi/Makefile.inc
index 81f7724..2668708 100644
--- a/sys/boot/efi/Makefile.inc
+++ b/sys/boot/efi/Makefile.inc
@@ -1,4 +1,7 @@
# $FreeBSD$
+BINDIR?= /boot
+
# Options used when building app-specific efi components
CFLAGS+= -ffreestanding -fshort-wchar -Wformat
+LDFLAGS+= -nostdlib
diff --git a/sys/boot/efi/libefi/Makefile b/sys/boot/efi/libefi/Makefile
index bd8e034..ee9a429 100644
--- a/sys/boot/efi/libefi/Makefile
+++ b/sys/boot/efi/libefi/Makefile
@@ -12,28 +12,21 @@ SRCS+= delay.c efifs.c efinet.c elf_freebsd.c bootinfo.c pal.S
SRCS+= efifpswa.c
.endif
-CFLAGS+= -ffreestanding -fpic
+CFLAGS+= -fpic
CFLAGS+= -I${.CURDIR}/../include
CFLAGS+= -I${.CURDIR}/../include/${MACHINE_ARCH}
-CFLAGS+= -I${.CURDIR}/../../../../lib/libstand/
+CFLAGS+= -I${.CURDIR}/../../../../lib/libstand
# Pick up the bootstrap header for some interface items
-CFLAGS+= -I${.CURDIR}/../../common -I${.CURDIR}/../../.. -I.
+CFLAGS+= -I${.CURDIR}/../../common
.if ${MACHINE_ARCH} == "powerpc"
CFLAGS+= -msoft-float
.endif
-.ifdef(BOOT_DISK_DEBUG)
+.if defined(BOOT_DISK_DEBUG)
# Make the disk code more talkative
CFLAGS+= -DDISK_DEBUG
.endif
-machine:
- ln -sf ${.CURDIR}/../../../${MACHINE_ARCH}/include machine
-
-CLEANFILES+= machine
-
.include <bsd.lib.mk>
-
-beforedepend ${OBJS}: machine
diff --git a/sys/boot/efi/loader/Makefile b/sys/boot/efi/loader/Makefile
index e2f9a84..8197b6a 100644
--- a/sys/boot/efi/loader/Makefile
+++ b/sys/boot/efi/loader/Makefile
@@ -1,76 +1,45 @@
# $FreeBSD$
-.PATH: ${.CURDIR}/../common
-
-BASE= loader
-PROG= ${BASE}.efi
+PROG= loader.sym
+INTERNALPROG=
NOMAN=
NEWVERSWHAT= "EFI boot" ${MACHINE_ARCH}
-BINDIR?= /boot
-STRIP= # We must not strip loader.efi at install time.
-SRCS+= main.c conf.c dev_net.c
+SRCS= start.S main.c conf.c dev_net.c vers.c
-CFLAGS+= -ffreestanding
+.PATH: ${.CURDIR}/../libefi/arch/${MACHINE_ARCH}
.if !defined(NOFORTH)
# Enable BootForth
BOOT_FORTH= yes
CFLAGS+= -DBOOT_FORTH
CFLAGS+= -I${.CURDIR}/../../ficl -I${.CURDIR}/../../ficl/${MACHINE_ARCH}
-.if exists(${.OBJDIR}/../../ficl/libficl.a)
LIBFICL= ${.OBJDIR}/../../ficl/libficl.a
-.else
-LIBFICL= ${.CURDIR}/../../ficl/libficl.a
-.endif
-.endif
-
-# where to get libstand from
-.if exists(${.OBJDIR}/../../../../lib/libstand/libstand.a)
-LIBSTAND= ${.OBJDIR}/../../../../lib/libstand/libstand.a
-.else
-LIBSTAND= ${.CURDIR}/../../../../lib/libstand/libstand.a
.endif
-.if exists(${.OBJDIR}/../libefi/libefi.a)
LIBEFI= ${.OBJDIR}/../libefi/libefi.a
-.else
-LIBEFI= ${.CURDIR}/../libefi/libefi.a
-.endif
# Always add MI sources
.PATH: ${.CURDIR}/../../common
-.include <${.CURDIR}/../../common/Makefile.inc>
+.include "${.CURDIR}/../../common/Makefile.inc"
-CFLAGS+= -I-
CFLAGS+= -I${.CURDIR}/../include
CFLAGS+= -I${.CURDIR}/../include/${MACHINE_ARCH}
-CFLAGS+= -I${.CURDIR}/../../common -I${.CURDIR}
-CFLAGS+= -I${.CURDIR}/../../.. -I.
+CFLAGS+= -I${.CURDIR}/../../common
CFLAGS+= -I${.CURDIR}/../libefi
CFLAGS+= -I${.CURDIR}/../../../../lib/libstand
CFLAGS+= -DLOADER
LDSCRIPT= ${.CURDIR}/../libefi/arch/${MACHINE_ARCH}/ldscript.${MACHINE_ARCH}
-LDFLAGS= -nostdlib -T ${LDSCRIPT} -shared -Bsymbolic
+LDFLAGS= -Wl,-T${LDSCRIPT} -Wl,-M,-Map,loader.list -shared -symbolic
OBJCOPY?= objcopy
-CLEANFILES+= setdef0.c setdef0.o setdef1.c setdef1.o setdefs.h start.o \
- vers.c vers.o ${BASE}.efi ${BASE}.sym ${BASE}.list
-CLEANFILES+= loader.help
-CLEANFILES+= machine
-
-CRT= start.o
-
-all: ${BASE}
+CLEANFILES= vers.c loader.efi loader.list loader.help
-vers.o: ${.CURDIR}/../../common/newvers.sh ${.CURDIR}/version
+vers.c: ${.CURDIR}/../../common/newvers.sh ${.CURDIR}/version
sh ${.CURDIR}/../../common/newvers.sh ${.CURDIR}/version ${NEWVERSWHAT}
- ${CC} -c vers.c
-${BASE}: ${BASE}.efi ${BASE}.help
-
-${BASE}.efi: ${BASE}.sym
+loader.efi: loader.sym
${OBJCOPY} -j .text \
-j .hash \
-j .data \
@@ -81,43 +50,22 @@ ${BASE}.efi: ${BASE}.sym
-j .dynsym \
-j .dynstr \
--target=efi-app-${MACHINE_ARCH} \
- ${BASE}.sym ${BASE}.efi
+ loader.sym loader.efi
-${BASE}.help: help.common
+loader.help: help.common
cat ${.ALLSRC} | awk -f ${.CURDIR}/../../common/merge_help.awk \
> ${.TARGET}
-beforeinstall:
-.if exists(${.OBJDIR}/loader.help)
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.OBJDIR}/${BASE}.help ${DESTDIR}/boot
-.else
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.CURDIR}/${BASE}.help ${DESTDIR}/boot
-.endif
+.PATH: ${.CURDIR}/../../forth
+FILES= loader.efi loader.help loader.4th support.4th loader.conf
+FILESMODE_loader.efi= ${BINMODE}
+FILESDIR_loader.conf= /boot/defaults
+
.if !exists(${DESTDIR}/boot/loader.rc)
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.CURDIR}/../../forth/loader.rc ${DESTDIR}/boot
+FILES+= loader.rc
.endif
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.CURDIR}/../../forth/loader.4th ${DESTDIR}/boot
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.CURDIR}/../../forth/support.4th ${DESTDIR}/boot
- ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
- ${.CURDIR}/../../forth/loader.conf ${DESTDIR}/boot/defaults
-
-# Other fragments still to be brought in from ../Makfile.booters?
-start.o: ${.CURDIR}/../libefi/arch/${MACHINE_ARCH}/start.S
- ${CC} -c ${CFLAGS} ${.IMPSRC}
-
-machine:
- ln -sf ${.CURDIR}/../../../${MACHINE_ARCH}/include machine
+DPADD= ${LIBFICL} ${LIBEFI} ${LIBSTAND}
+LDADD= ${LIBFICL} ${LIBEFI} -lstand
.include <bsd.prog.mk>
-
-${BASE}.sym: ${OBJS} ${LIBFICL} ${LIBEFI} ${LIBSTAND} ${CRT} vers.o
- ${LD} ${LDFLAGS} -o ${BASE}.sym -M ${CRT} ${OBJS} vers.o \
- ${LIBFICL} ${LIBEFI} ${LIBSTAND} > ${.OBJDIR}/${BASE}.list
-
-beforedepend ${OBJS}: machine
OpenPOWER on IntegriCloud