Subversion Repositories HelenOS-historic

Rev

Rev 431 | Rev 457 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
455 decky 1
#
2
# Copyright (C) 2005 Martin Decky
3
# All rights reserved.
4
#
5
# Redistribution and use in source and binary forms, with or without
6
# modification, are permitted provided that the following conditions
7
# are met:
8
#
9
# - Redistributions of source code must retain the above copyright
10
#   notice, this list of conditions and the following disclaimer.
11
# - Redistributions in binary form must reproduce the above copyright
12
#   notice, this list of conditions and the following disclaimer in the
13
#   documentation and/or other materials provided with the distribution.
14
# - The name of the author may not be used to endorse or promote products
15
#   derived from this software without specific prior written permission.
16
#
17
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
#
1 jermar 28
 
455 decky 29
## Toolchain configuration
30
#
1 jermar 31
 
455 decky 32
BFD_NAME = elf32-i386
33
BFD_ARCH = mips
34
TARGET = mipsel-linux-gnu
35
TOOLCHAIN_DIR = /usr/local/mipsel/bin
36
 
37
## Make some default assumptions
38
#
39
 
40
ifndef CPU
41
	CPU = pentium4
42
endif
43
 
44
## Accepted CPUs
45
#
46
 
47
ifeq ($(CPU),athlon-xp)
48
	CFLAGS += -march=athlon-xp -mmmx -msse -m3dnow
49
	DEFS += -DFENCES=486
50
	CONFIG_SMP = n
51
	CONFIG_HT = n
52
endif
53
ifeq ($(CPU),athlon-mp)
54
	CFLAGS += -march=athlon-mp -mmmx -msse -m3dnow
55
	DEFS += -DFENCES=486
56
endif
57
ifeq ($(CPU),pentium3)
58
	CFLAGS += -march=pentium3 -mmmx -msse -msse2
59
	DEFS += -DFENCES=486
60
endif
61
ifeq ($(CPU),pentium4)
62
	CFLAGS += -march=pentium4 -mfpmath=sse -mmmx -msse -msse2 -msse3
63
	DEFS += -DFENCES=p4
64
endif
65
 
66
## Own configuration directives
67
#
68
 
69
CONFIG_ACPI = y
70
 
71
## Accepted configuration directives
72
#
73
 
74
ifeq ($(CONFIG_SMP),y)
75
	DEFS += -DSMP
76
endif
77
ifeq ($(CONFIG_HT),y)
78
	DEFS += -DHT
79
endif
80
ifeq ($(CONFIG_FPU_LAZY),y)
81
	DEFS += -DFPU_LAZY
82
endif
83
 
84
ARCH_SOURCES = \
85
	arch/$(ARCH)/src/context.s \
86
	arch/$(ARCH)/src/debug/panic.s \
87
	arch/$(ARCH)/src/delay.s \
88
	arch/$(ARCH)/src/asm.S \
89
	arch/$(ARCH)/src/proc/scheduler.c \
90
	arch/$(ARCH)/src/bios/bios.c \
91
	arch/$(ARCH)/src/smp/ap.S \
92
	arch/$(ARCH)/src/smp/apic.c \
93
	arch/$(ARCH)/src/smp/mps.c \
94
	arch/$(ARCH)/src/smp/smp.c \
95
	arch/$(ARCH)/src/atomic.S \
96
	arch/$(ARCH)/src/smp/ipi.c \
97
	arch/$(ARCH)/src/ia32.c \
98
	arch/$(ARCH)/src/interrupt.c \
99
	arch/$(ARCH)/src/pm.c \
100
	arch/$(ARCH)/src/userspace.c \
101
	arch/$(ARCH)/src/cpu/cpu.c \
102
	arch/$(ARCH)/src/mm/frame.c \
103
	arch/$(ARCH)/src/mm/memory_init.c \
104
	arch/$(ARCH)/src/mm/page.c \
105
	arch/$(ARCH)/src/mm/tlb.c \
106
	arch/$(ARCH)/src/drivers/i8042.c \
107
	arch/$(ARCH)/src/drivers/i8254.c \
108
	arch/$(ARCH)/src/drivers/i8259.c \
109
	arch/$(ARCH)/src/drivers/ega.c \
110
	arch/$(ARCH)/src/boot/boot.S \
111
	arch/$(ARCH)/src/boot/memmap.S \
112
	arch/$(ARCH)/src/fpu_context.c\
113
	arch/$(ARCH)/src/fmath.c
114
 
115
 
116
 
117
 
118
 
119
 
120
 
121
 
122
 
123
 
124
 
125
 
126
 
127
 
128
 
129
 
130
DEFS= -DMACHINE=${MACHINE} -DKERNEL_LOAD_ADDRESS=${KERNEL_LOAD_ADDRESS}
131
CFLAGS=-mno-abicalls -G 0 -nostdlib -fno-builtin -O2  -fno-zero-initialized-in-bss
391 jermar 132
LFLAGS=
1 jermar 133
 
332 palkovsky 134
# GCC 4.0.1 compiled for mipsEL has problems compiling in 
135
# BigEndian mode with the swl/swr/lwl/lwr instructions.
136
# We have to compile it with mips-sgi-irix5 to get it right.
137
ifeq (${MACHINE},indy)
138
 MIPS_TARGET=mips-sgi-irix5
139
 MIPS_CC_DIR=/usr/local/mips/bin
140
 MIPS_BINUTILS_DIR=/usr/local/mips/bin
326 palkovsky 141
 
332 palkovsky 142
 CFLAGS += -EB -DBIG_ENDIAN -DHAVE_FPU -DFPU_LAZY -march=r4600
329 palkovsky 143
 BFD = ecoff-bigmips
144
 KERNEL_LOAD_ADDRESS = 0x88002000
339 palkovsky 145
 BFD_NAME=elf32-bigmips
326 palkovsky 146
endif
147
 
148
ifeq (${MACHINE},lgxemul)
329 palkovsky 149
 CFLAGS += -DHAVE_FPU -DFPU_LAZY -mips3
326 palkovsky 150
 BFD = ecoff-littlemips
330 palkovsky 151
 KERNEL_LOAD_ADDRESS = 0x80100000
431 jermar 152
 BFD_NAME=elf32-tradlittlemips
326 palkovsky 153
endif
154
 
155
ifeq (${MACHINE},bgxemul)
332 palkovsky 156
 MIPS_TARGET=mips-sgi-irix5
157
 MIPS_CC_DIR=/usr/local/mips/bin
158
 MIPS_BINUTILS_DIR=/usr/local/mips/bin
159
 
160
 CFLAGS += -EB -DBIG_ENDIAN -DHAVE_FPU -DFPU_LAZY -mips3
326 palkovsky 161
 BFD = ecoff-bigmips
330 palkovsky 162
 KERNEL_LOAD_ADDRESS = 0x80100000
339 palkovsky 163
 BFD_NAME=elf32-bigmips
326 palkovsky 164
endif
165
 
329 palkovsky 166
# MSIM needs lwl/swl patch & 4kc instruction patch to work
167
# otherwise add -mmemcpy -mips3
364 palkovsky 168
ifeq (${MACHINE},msim4kc)
326 palkovsky 169
 BFD = binary
429 jermar 170
 CFLAGS += -mhard-float -march=4kc 
330 palkovsky 171
 KERNEL_LOAD_ADDRESS = 0x80100000
431 jermar 172
 BFD_NAME=elf32-tradlittlemips
326 palkovsky 173
endif
174
 
364 palkovsky 175
ifeq (${MACHINE},msim)
176
 BFD = binary
429 jermar 177
 CFLAGS += -mhard-float -mips3
364 palkovsky 178
 KERNEL_LOAD_ADDRESS = 0x80100000
431 jermar 179
 BFD_NAME=elf32-tradlittlemips
364 palkovsky 180
endif
181
 
329 palkovsky 182
# SIMICS 4kc emulation is broken, although for instructions
183
# that do not bother us
326 palkovsky 184
ifeq (${MACHINE},simics)
431 jermar 185
 BFD = elf32-tradlittlemips
429 jermar 186
 CFLAGS += -mhard-float -mips3
330 palkovsky 187
 KERNEL_LOAD_ADDRESS = 0x80100000
431 jermar 188
 BFD_NAME=elf32-tradlittlemips
326 palkovsky 189
endif
190
 
376 jermar 191
arch/$(ARCH)/_link.ld: arch/$(ARCH)/_link.ld.in
326 palkovsky 192
	$(CC) $(CFLAGS) -C -DBFD=${BFD} -E -x c $< | grep -v "^\#" > $@
193
 
1 jermar 194
arch_sources= \
430 jermar 195
	generic/src/arch/start.S \
196
	generic/src/arch/context.S \
197
	generic/src/arch/panic.S \
198
	generic/src/arch/mips32.c \
199
	generic/src/arch/dummy.S \
200
	generic/src/arch/console.c \
201
	generic/src/arch/asm.S \
202
	generic/src/arch/exception.c \
203
	generic/src/arch/interrupt.c \
204
	generic/src/arch/cache.c \
205
	generic/src/arch/cpu/cpu.c \
206
	generic/src/arch/mm/asid.c \
207
	generic/src/arch/mm/frame.c \
208
	generic/src/arch/mm/page.c \
209
	generic/src/arch/mm/tlb.c \
210
	generic/src/arch/mm/vm.c \
211
	generic/src/arch/fpu_context.c \
212
	generic/src/arch/fmath.c \
213
	generic/src/arch/drivers/arc.c