source: mainline/kernel/arch/ia32/Makefile.inc@ b5a1730

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since b5a1730 was 23cdc921, checked in by Jakub Jermar <jakub@…>, 17 years ago

Introduce the notion of FPU_NO_CFLAGS and separate building of test/fpu
objects and building the rest of kernel objects. Now, amd64 and ia32 can
enable things such as SSE selectively for the test/fpu/*.

  • Property mode set to 100644
File size: 4.2 KB
Line 
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#
28
29## Toolchain configuration
30#
31
32BFD_NAME = elf32-i386
33BFD_ARCH = i386
34BFD = binary
35TARGET = i686-pc-linux-gnu
36TOOLCHAIN_DIR = /usr/local/i686
37
38DEFS += -DMACHINE=$(MACHINE) -D__32_BITS__
39
40CMN1 = -m32
41GCC_CFLAGS += $(CMN1)
42ICC_CFLAGS += $(CMN1)
43SUNCC_CFLAGS += $(CMN1)
44
45## Accepted CPUs
46#
47
48ifeq ($(MACHINE),athlon-xp)
49 FPU_NO_CFLAGS = -mno-mmx -mno-sse -mno-3dnow
50 CMN2 = -march=athlon-xp
51 GCC_CFLAGS += $(CMN2)
52 ICC_CFLAGS += $(CMN2)
53 SUNCC_CFLAGS += -xarch=ssea
54 DEFS += -DCONFIG_FENCES_P3
55 CONFIG_SMP = n
56 CONFIG_HT = n
57endif
58ifeq ($(MACHINE),athlon-mp)
59 FPU_NO_CFLAGS = -mno-mmx -mno-sse -mno-3dnow
60 CMN2 = -march=athlon-mp
61 GCC_CFLAGS += $(CMN2)
62 ICC_CFLAGS += $(CMN2)
63 SUNCC_CFLAGS += xarch=ssea
64 DEFS += -DCONFIG_FENCES_P3
65 CONFIG_HT = n
66endif
67ifeq ($(MACHINE),pentium3)
68 FPU_NO_CFLAGS = -mno-mmx -mno-sse
69 CMN2 = -march=pentium3
70 GCC_CFLAGS += $(CMN2)
71 ICC_CFLAGS += $(CMN2)
72 SUNCC_CFLAGS += -xarch=sse
73 DEFS += -DCONFIG_FENCES_P3
74 CONFIG_HT = n
75endif
76ifeq ($(MACHINE),core)
77 FPU_NO_CFLAGS = -mno-mmmx -mno-sse -mno-sse2 -mno-sse3
78 CMN2 = -march=prescott
79 GCC_CFLAGS += $(CMN2)
80 ICC_CFLAGS += $(CMN2)
81 SUNCC_CFLAGS += -xarch=sse3
82 DEFS += -DCONFIG_FENCES_P4
83endif
84ifeq ($(MACHINE),pentium4)
85 FPU_NO_CFLAGS = -mno-mmx -mno-sse -mno-sse2
86 GCC_CFLAGS += -march=pentium4
87 ICC_CFLAGS += -march=pentium4
88 SUNCC_CFLAGS += -xarch=sse2
89 DEFS += -DCONFIG_FENCES_P4
90endif
91
92## Own configuration directives
93#
94
95CONFIG_ACPI = y
96
97## Compile with hierarchical page tables support.
98#
99
100CONFIG_PAGE_PT = y
101DEFS += -DCONFIG_PAGE_PT
102
103## Compile with i8042 controller support
104#
105
106CONFIG_I8042 = y
107DEFS += -DCONFIG_I8042
108
109## Accepted configuration directives
110#
111
112ifeq ($(CONFIG_SMP),y)
113 DEFS += -DCONFIG_SMP
114endif
115ifeq ($(CONFIG_HT),y)
116 DEFS += -DCONFIG_HT
117endif
118ifeq ($(CONFIG_SIMICS_FIX),y)
119 DEFS += -DCONFIG_SIMICS_FIX
120endif
121
122## Compile with support for software integer division.
123#
124
125CONFIG_SOFTINT = y
126
127ARCH_SOURCES = \
128 arch/$(ARCH)/src/context.S \
129 arch/$(ARCH)/src/debug/panic.s \
130 arch/$(ARCH)/src/delay.s \
131 arch/$(ARCH)/src/asm.S \
132 arch/$(ARCH)/src/proc/scheduler.c \
133 arch/$(ARCH)/src/proc/task.c \
134 arch/$(ARCH)/src/proc/thread.c \
135 arch/$(ARCH)/src/bios/bios.c \
136 arch/$(ARCH)/src/smp/ap.S \
137 arch/$(ARCH)/src/smp/apic.c \
138 arch/$(ARCH)/src/smp/mps.c \
139 arch/$(ARCH)/src/smp/smp.c \
140 arch/$(ARCH)/src/atomic.S \
141 arch/$(ARCH)/src/smp/ipi.c \
142 arch/$(ARCH)/src/ia32.c \
143 arch/$(ARCH)/src/interrupt.c \
144 arch/$(ARCH)/src/pm.c \
145 arch/$(ARCH)/src/userspace.c \
146 arch/$(ARCH)/src/cpu/cpu.c \
147 arch/$(ARCH)/src/mm/as.c \
148 arch/$(ARCH)/src/mm/frame.c \
149 arch/$(ARCH)/src/mm/page.c \
150 arch/$(ARCH)/src/mm/tlb.c \
151 arch/$(ARCH)/src/ddi/ddi.c \
152 arch/$(ARCH)/src/drivers/i8254.c \
153 arch/$(ARCH)/src/drivers/i8259.c \
154 arch/$(ARCH)/src/drivers/ega.c \
155 arch/$(ARCH)/src/drivers/vesa.c \
156 arch/$(ARCH)/src/boot/boot.S \
157 arch/$(ARCH)/src/boot/memmap.c \
158 arch/$(ARCH)/src/fpu_context.c \
159 arch/$(ARCH)/src/debugger.c
Note: See TracBrowser for help on using the repository browser.