1 |
38 |
julius |
LIB1ASMSRC = arm/lib1funcs.asm
|
2 |
|
|
LIB1ASMFUNCS = _udivsi3 _divsi3 _umodsi3 _modsi3 _dvmd_tls _bb_init_func _call_via_rX _interwork_call_via_rX
|
3 |
|
|
|
4 |
|
|
# We want fine grained libraries, so use the new code to build the
|
5 |
|
|
# floating point emulation libraries.
|
6 |
|
|
FPBIT = fp-bit.c
|
7 |
|
|
DPBIT = dp-bit.c
|
8 |
|
|
|
9 |
|
|
fp-bit.c: $(srcdir)/config/fp-bit.c
|
10 |
|
|
echo '#define FLOAT' > fp-bit.c
|
11 |
|
|
echo '#ifndef __ARMEB__' >> fp-bit.c
|
12 |
|
|
echo '#define FLOAT_BIT_ORDER_MISMATCH' >> fp-bit.c
|
13 |
|
|
echo '#endif' >> fp-bit.c
|
14 |
|
|
cat $(srcdir)/config/fp-bit.c >> fp-bit.c
|
15 |
|
|
|
16 |
|
|
dp-bit.c: $(srcdir)/config/fp-bit.c
|
17 |
|
|
echo '#ifndef __ARMEB__' > dp-bit.c
|
18 |
|
|
echo '#define FLOAT_BIT_ORDER_MISMATCH' >> dp-bit.c
|
19 |
|
|
echo '#define FLOAT_WORD_ORDER_MISMATCH' >> dp-bit.c
|
20 |
|
|
echo '#endif' >> dp-bit.c
|
21 |
|
|
cat $(srcdir)/config/fp-bit.c >> dp-bit.c
|
22 |
|
|
|
23 |
|
|
MULTILIB_OPTIONS = mbig-endian
|
24 |
|
|
MULTILIB_DIRNAMES = be
|
25 |
|
|
MULTILIB_EXCEPTIONS =
|
26 |
|
|
MULTILIB_MATCHES = mbig-endian=mbe mlittle-endian=mle
|
27 |
|
|
|
28 |
|
|
# Note XScale does not support hard FP
|
29 |
|
|
|
30 |
|
|
MULTILIB_OPTIONS += mthumb-interwork
|
31 |
|
|
MULTILIB_DIRNAMES += interwork
|
32 |
|
|
|
33 |
|
|
MULTILIB_OPTIONS += mthumb
|
34 |
|
|
MULTILIB_DIRNAMES += thumb
|
35 |
|
|
MULTILIB_EXCEPTIONS += *mhard-float/*mthumb*
|
36 |
|
|
|
37 |
|
|
MULTILIB_REDUNDANT_DIRS = interwork/thumb=thumb
|
38 |
|
|
|
39 |
|
|
# The iWMMXt multilibs are suppressed for now because gcc only
|
40 |
|
|
# supports generating them with the IWMMXT or AAPCS ABIs, neither of
|
41 |
|
|
# which is the default. Until GCC can generate code for an iWMMXt
|
42 |
|
|
# which will work with the default ABI it is not possible to safely
|
43 |
|
|
# generate these multilibs.
|
44 |
|
|
#
|
45 |
|
|
# MULTILIB_OPTIONS += mcpu=iwmmxt
|
46 |
|
|
# MULTILIB_DIRNAMES += iwmmxt
|
47 |
|
|
# MULTILIB_REDUNDANT_DIRS += interwork/thumb/iwmmxt=thumb
|
48 |
|
|
|
49 |
|
|
EXTRA_MULTILIB_PARTS = crtbegin.o crtend.o crti.o crtn.o
|
50 |
|
|
|
51 |
|
|
LIBGCC = stmp-multilib
|
52 |
|
|
INSTALL_LIBGCC = install-multilib
|
53 |
|
|
|
54 |
|
|
# Currently there is a bug somewhere in GCC's alias analysis
|
55 |
|
|
# or scheduling code that is breaking _fpmul_parts in fp-bit.c.
|
56 |
|
|
# Disabling function inlining is a workaround for this problem.
|
57 |
|
|
TARGET_LIBGCC2_CFLAGS = -fno-inline
|
58 |
|
|
|
59 |
|
|
# Assemble startup files.
|
60 |
|
|
$(T)crti.o: $(srcdir)/config/arm/crti.asm $(GCC_PASSES)
|
61 |
|
|
$(GCC_FOR_TARGET) $(GCC_CFLAGS) $(MULTILIB_CFLAGS) $(INCLUDES) \
|
62 |
|
|
-c -o $(T)crti.o -x assembler-with-cpp $(srcdir)/config/arm/crti.asm
|
63 |
|
|
|
64 |
|
|
$(T)crtn.o: $(srcdir)/config/arm/crtn.asm $(GCC_PASSES)
|
65 |
|
|
$(GCC_FOR_TARGET) $(GCC_CFLAGS) $(MULTILIB_CFLAGS) $(INCLUDES) \
|
66 |
|
|
-c -o $(T)crtn.o -x assembler-with-cpp $(srcdir)/config/arm/crtn.asm
|