Subversion Repositories HelenOS-historic

Rev

Rev 431 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 431 Rev 455
Line -... Line 1...
-
 
1
#
1
MIPS_TARGET=mipsel-linux-gnu
2
# Copyright (C) 2005 Martin Decky
2
MIPS_CC_DIR=/usr/local/mipsel/bin
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
#
3
MIPS_BINUTILS_DIR=/usr/local/mipsel/bin
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.
4
 
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
5
CC=$(MIPS_CC_DIR)/$(MIPS_TARGET)-gcc
19
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
6
AS=$(MIPS_BINUTILS_DIR)/$(MIPS_TARGET)-as
20
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-
 
21
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
7
LD=$(MIPS_BINUTILS_DIR)/$(MIPS_TARGET)-ld
22
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
8
OBJDUMP=$(MIPS_BINUTILS_DIR)/$(MIPS_TARGET)-objdump
23
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
9
OBJCOPY=$(MIPS_BINUTILS_DIR)/$(MIPS_TARGET)-objcopy
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.
10
BFD_ARCH=mips
27
#
11
 
28
 
-
 
29
## Toolchain configuration
-
 
30
#
-
 
31
 
-
 
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
 
12
DEFS=-DARCH=$(ARCH) -DMACHINE=${MACHINE} -DKERNEL_LOAD_ADDRESS=${KERNEL_LOAD_ADDRESS}
130
DEFS= -DMACHINE=${MACHINE} -DKERNEL_LOAD_ADDRESS=${KERNEL_LOAD_ADDRESS}
13
CFLAGS=$(DEFS) -mno-abicalls -G 0 -nostdlib -fno-builtin -O2  -fno-zero-initialized-in-bss
131
CFLAGS=-mno-abicalls -G 0 -nostdlib -fno-builtin -O2  -fno-zero-initialized-in-bss
14
LFLAGS=
132
LFLAGS=
15
BFD_ARCH=mips
-
 
16
 
133
 
17
# GCC 4.0.1 compiled for mipsEL has problems compiling in 
134
# GCC 4.0.1 compiled for mipsEL has problems compiling in 
18
# BigEndian mode with the swl/swr/lwl/lwr instructions.
135
# BigEndian mode with the swl/swr/lwl/lwr instructions.
19
# We have to compile it with mips-sgi-irix5 to get it right.
136
# We have to compile it with mips-sgi-irix5 to get it right.
20
ifeq (${MACHINE},indy)
137
ifeq (${MACHINE},indy)