source: mainline/kernel/arch/ia32/Makefile.inc@ 965dc18

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

Support for SYSENTER on ia32.

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