1999-08-28 00:22:10 +00:00
|
|
|
# $FreeBSD$
|
2001-10-27 08:30:36 +00:00
|
|
|
|
2017-01-20 03:52:16 +00:00
|
|
|
.PATH: ${.CURDIR:H}/common
|
1998-03-07 20:27:11 +00:00
|
|
|
|
2000-10-28 21:26:48 +00:00
|
|
|
SRCS= crt1.c crti.S crtn.S
|
1998-03-07 20:27:11 +00:00
|
|
|
OBJS= ${SRCS:N*.h:R:S/$/.o/g}
|
2009-12-02 16:34:20 +00:00
|
|
|
OBJS+= Scrt1.o gcrt1.o
|
2017-01-20 03:52:16 +00:00
|
|
|
CFLAGS+= -I${.CURDIR:H}/common \
|
|
|
|
-I${SRCTOP}/lib/libc/include
|
2008-08-22 09:23:39 +00:00
|
|
|
CFLAGS+= -fno-omit-frame-pointer
|
2000-05-20 17:47:29 +00:00
|
|
|
|
2015-09-21 18:39:13 +00:00
|
|
|
FILES= ${OBJS}
|
|
|
|
FILESMODE= ${LIBMODE}
|
|
|
|
FILESOWN= ${LIBOWN}
|
|
|
|
FILESGRP= ${LIBGRP}
|
|
|
|
FILESDIR= ${LIBDIR}
|
2015-09-21 21:44:02 +00:00
|
|
|
# These FILES qualify as libraries for the purpose of LIBRARIES_ONLY.
|
|
|
|
.undef LIBRARIES_ONLY
|
1998-03-07 20:27:11 +00:00
|
|
|
|
2002-05-13 15:28:00 +00:00
|
|
|
CLEANFILES= ${OBJS}
|
2011-01-13 20:44:31 +00:00
|
|
|
CLEANFILES+= crt1.s gcrt1.s Scrt1.s
|
2002-05-13 15:28:00 +00:00
|
|
|
|
2011-01-13 20:44:31 +00:00
|
|
|
# See the comment in lib/csu/common/crtbrand.c for the reason crt1.c is not
|
|
|
|
# directly compiled to .o files.
|
1998-09-07 23:32:00 +00:00
|
|
|
|
2011-01-13 20:44:31 +00:00
|
|
|
crt1.s: crt1.c
|
|
|
|
${CC} ${CFLAGS} -S -o ${.TARGET} ${.CURDIR}/crt1.c
|
2012-03-11 20:04:09 +00:00
|
|
|
sed ${SED_FIX_NOTE} ${.TARGET}
|
2011-01-13 20:44:31 +00:00
|
|
|
|
|
|
|
crt1.o: crt1.s
|
After r217375, some startup objects under lib/csu are built in a special
way: first they are compiled to assembly, then some sed'ing is done on
the assembly, and lastly the assembly is compiled to an object file.
This last step is done using ${CC}, and not ${AS}, because when the
compiler is clang, it outputs directives that are too advanced for our
old gas. So we use clang's integrated assembler instead. (When the
compiler is gcc, it just calls gas, and nothing is different, except one
extra fork.)
However, in the .s to .o rules in lib/csu/$ARCH/Makefile, I still passed
CFLAGS to the compiler, instead of ACFLAGS, which are specifically for
compiling .s files.
In case you are using '-g' for debug info anywhere in your CFLAGS, it
causes the .s files to already contain debug information in the assembly
itself. In the next step, the .s files are also compiled using '-g',
and if the compiler is clang, it complains: "error: input can't have
.file dwarf directives when -g is used to generate dwarf debug info for
assembly code".
Fix this by using ${ACFLAGS} for compiling the .s files instead.
Reported by: jasone
MFC after: 1 week
2012-04-20 21:00:39 +00:00
|
|
|
${CC} ${ACFLAGS} -c -o ${.TARGET} crt1.s
|
2011-01-13 20:44:31 +00:00
|
|
|
|
|
|
|
gcrt1.s: crt1.c
|
|
|
|
${CC} ${CFLAGS} -DGCRT -S -o ${.TARGET} ${.CURDIR}/crt1.c
|
2012-03-11 20:04:09 +00:00
|
|
|
sed ${SED_FIX_NOTE} ${.TARGET}
|
2011-01-13 20:44:31 +00:00
|
|
|
|
|
|
|
gcrt1.o: gcrt1.s
|
After r217375, some startup objects under lib/csu are built in a special
way: first they are compiled to assembly, then some sed'ing is done on
the assembly, and lastly the assembly is compiled to an object file.
This last step is done using ${CC}, and not ${AS}, because when the
compiler is clang, it outputs directives that are too advanced for our
old gas. So we use clang's integrated assembler instead. (When the
compiler is gcc, it just calls gas, and nothing is different, except one
extra fork.)
However, in the .s to .o rules in lib/csu/$ARCH/Makefile, I still passed
CFLAGS to the compiler, instead of ACFLAGS, which are specifically for
compiling .s files.
In case you are using '-g' for debug info anywhere in your CFLAGS, it
causes the .s files to already contain debug information in the assembly
itself. In the next step, the .s files are also compiled using '-g',
and if the compiler is clang, it complains: "error: input can't have
.file dwarf directives when -g is used to generate dwarf debug info for
assembly code".
Fix this by using ${ACFLAGS} for compiling the .s files instead.
Reported by: jasone
MFC after: 1 week
2012-04-20 21:00:39 +00:00
|
|
|
${CC} ${ACFLAGS} -c -o ${.TARGET} gcrt1.s
|
2011-01-13 20:44:31 +00:00
|
|
|
|
|
|
|
Scrt1.s: crt1.c
|
|
|
|
${CC} ${CFLAGS} -fPIC -DPIC -S -o ${.TARGET} ${.CURDIR}/crt1.c
|
2012-03-11 20:04:09 +00:00
|
|
|
sed ${SED_FIX_NOTE} ${.TARGET}
|
2011-01-13 20:44:31 +00:00
|
|
|
|
|
|
|
Scrt1.o: Scrt1.s
|
After r217375, some startup objects under lib/csu are built in a special
way: first they are compiled to assembly, then some sed'ing is done on
the assembly, and lastly the assembly is compiled to an object file.
This last step is done using ${CC}, and not ${AS}, because when the
compiler is clang, it outputs directives that are too advanced for our
old gas. So we use clang's integrated assembler instead. (When the
compiler is gcc, it just calls gas, and nothing is different, except one
extra fork.)
However, in the .s to .o rules in lib/csu/$ARCH/Makefile, I still passed
CFLAGS to the compiler, instead of ACFLAGS, which are specifically for
compiling .s files.
In case you are using '-g' for debug info anywhere in your CFLAGS, it
causes the .s files to already contain debug information in the assembly
itself. In the next step, the .s files are also compiled using '-g',
and if the compiler is clang, it complains: "error: input can't have
.file dwarf directives when -g is used to generate dwarf debug info for
assembly code".
Fix this by using ${ACFLAGS} for compiling the .s files instead.
Reported by: jasone
MFC after: 1 week
2012-04-20 21:00:39 +00:00
|
|
|
${CC} ${ACFLAGS} -c -o ${.TARGET} Scrt1.s
|
2009-12-02 16:34:20 +00:00
|
|
|
|
1998-03-07 20:27:11 +00:00
|
|
|
.include <bsd.lib.mk>
|