OSDN Git Service

Add support for Cirrus EP9312, an ARM variant.
[pf3gnuchains/gcc-fork.git] / gcc / config / arm / t-arm-elf
1 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         
24 MULTILIB_OPTIONS     = marm/mthumb
25 MULTILIB_DIRNAMES    = arm thumb
26 MULTILIB_EXCEPTIONS  = 
27
28 # MULTILIB_OPTIONS    += mcpu=ep9312
29 # MULTILIB_DIRNAMES   += ep9312
30 # MULTILIB_EXCEPTIONS += *mthumb/*mcpu=ep9312*
31         
32 # MULTILIB_OPTIONS     += mlittle-endian/mbig-endian
33 # MULTILIB_DIRNAMES    += le be
34 # MULTILIB_EXCEPTIONS  = 
35 # MULTILIB_MATCHES     = mbig-endian=mbe mlittle-endian=mle
36
37 # MULTILIB_OPTIONS    += mhard-float/msoft-float
38 # MULTILIB_DIRNAMES   += fpu soft
39 # MULTILIB_EXCEPTIONS += *mthumb/*mhard-float*
40
41 # MULTILIB_OPTIONS    += mapcs-32/mapcs-26
42 # MULTILIB_DIRNAMES   += 32bit 26bit
43 # MULTILIB_EXCEPTIONS += *mthumb/*mapcs-26*
44
45 # MULTILIB_OPTIONS    += mno-thumb-interwork/mthumb-interwork
46 # MULTILIB_DIRNAMES   += normal interwork
47 # MULTILIB_EXCEPTIONS += *mapcs-26/*mthumb-interwork*
48
49 # MULTILIB_OPTIONS    += fno-leading-underscore/fleading-underscore
50 # MULTILIB_DIRNAMES   += elf under
51
52 # MULTILIB_OPTIONS    += mcpu=arm7
53 # MULTILIB_DIRNAMES   += nofmult
54 # MULTILIB_EXCEPTIONS += *mthumb*/*mcpu=arm7*
55 # # Note: the multilib_exceptions matches both -mthumb and
56 # # -mthumb-interwork
57 # #
58 # # We have to match all the arm cpu variants which do not have the
59 # # multiply instruction and treat them as if the user had specified
60 # # -mcpu=arm7.  Note that in the following the ? is interpreted as
61 # # an = for the purposes of matching command line options.
62 # # FIXME: There ought to be a better way to do this.
63 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm7d
64 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm7di
65 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm70
66 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm700
67 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm700i
68 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm710
69 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm710c
70 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm7100
71 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm7500
72 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm7500fe
73 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm6
74 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm60
75 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm600
76 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm610
77 # MULTILIB_MATCHES    += mcpu?arm7=mcpu?arm620
78
79 EXTRA_MULTILIB_PARTS = crtbegin.o crtend.o crti.o crtn.o
80
81 # If EXTRA_MULTILIB_PARTS is not defined above then define EXTRA_PARTS here
82 # EXTRA_PARTS = crtbegin.o crtend.o crti.o crtn.o
83
84 LIBGCC = stmp-multilib
85 INSTALL_LIBGCC = install-multilib
86
87 # Currently there is a bug somewhere in GCC's alias analysis
88 # or scheduling code that is breaking _fpmul_parts in fp-bit.c.
89 # Disabling function inlining is a workaround for this problem.
90 TARGET_LIBGCC2_CFLAGS = -Dinhibit_libc -fno-inline
91
92 # Assemble startup files.
93 $(T)crti.o: $(srcdir)/config/arm/crti.asm $(GCC_PASSES)
94         $(GCC_FOR_TARGET) $(GCC_CFLAGS) $(MULTILIB_CFLAGS) $(INCLUDES) \
95         -c -o $(T)crti.o -x assembler-with-cpp $(srcdir)/config/arm/crti.asm
96
97 $(T)crtn.o: $(srcdir)/config/arm/crtn.asm $(GCC_PASSES)
98         $(GCC_FOR_TARGET) $(GCC_CFLAGS) $(MULTILIB_CFLAGS) $(INCLUDES) \
99         -c -o $(T)crtn.o -x assembler-with-cpp $(srcdir)/config/arm/crtn.asm