source: mainline/arch/ia32/Makefile.inc@ a597e3f0

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

Initialize ARCH_THREAD_DATA on all architectures.
On ia32 and amd64 this fixes bug caused by uninitialized TLS pointer.

  • Property mode set to 100644
File size: 3.6 KB
RevLine 
[e16e036a]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#
[9060bd1]28
[e16e036a]29## Toolchain configuration
30#
[9060bd1]31
[e16e036a]32BFD_NAME = elf32-i386
33BFD_ARCH = i386
[389f41e]34BFD = binary
[e16e036a]35TARGET = i686-pc-linux-gnu
36TOOLCHAIN_DIR = /usr/local/i686/bin
[ab08b42]37
[6bc4dbd]38## Make some default assumptions
[e16e036a]39#
[6bc4dbd]40
[9371c30]41ifndef IA32_CPU
42 IA32_CPU = pentium4
[6bc4dbd]43endif
44
[de6b301]45DEFS += -D_CPU=${IA32_CPU} -D__32_BITS__
[789b5cc]46
[6bc4dbd]47## Accepted CPUs
[e16e036a]48#
[f761f1eb]49
[9371c30]50ifeq ($(IA32_CPU),athlon-xp)
[e16e036a]51 CFLAGS += -march=athlon-xp -mmmx -msse -m3dnow
[0187fd0]52 DEFS += -DCONFIG_FENCES_P3
[e16e036a]53 CONFIG_SMP = n
54 CONFIG_HT = n
[6bc4dbd]55endif
[9371c30]56ifeq ($(IA32_CPU),athlon-mp)
[e16e036a]57 CFLAGS += -march=athlon-mp -mmmx -msse -m3dnow
[0187fd0]58 DEFS += -DCONFIG_FENCES_P3
[389f41e]59 CONFIG_HT = n
[6bc4dbd]60endif
[9371c30]61ifeq ($(IA32_CPU),pentium3)
[389f41e]62 CFLAGS += -march=pentium3 -mmmx -msse
[0187fd0]63 DEFS += -DCONFIG_FENCES_P3
[389f41e]64 CONFIG_HT = n
[6bc4dbd]65endif
[9371c30]66ifeq ($(IA32_CPU),prescott)
[e16e036a]67 CFLAGS += -march=pentium4 -mfpmath=sse -mmmx -msse -msse2 -msse3
[0187fd0]68 DEFS += -DCONFIG_FENCES_P4
[b9b103d3]69endif
[9371c30]70ifeq ($(IA32_CPU),pentium4)
[389f41e]71 CFLAGS += -march=pentium4 -mfpmath=sse -mmmx -msse -msse2
[0187fd0]72 DEFS += -DCONFIG_FENCES_P4
[389f41e]73endif
[b9b103d3]74
[e16e036a]75## Own configuration directives
76#
[f761f1eb]77
[e16e036a]78CONFIG_ACPI = y
[f761f1eb]79
[6d7ffa65]80## Compile with hierarchical page tables support.
81#
82
83CONFIG_PAGE_PT = y
[d71007e]84DEFS += -DCONFIG_PAGE_PT
[6d7ffa65]85
[02f441c0]86## Compile with i8042 controller support
87#
88
89CONFIG_I8042 = y
90
91
[e16e036a]92## Accepted configuration directives
93#
[f761f1eb]94
[e16e036a]95ifeq ($(CONFIG_SMP),y)
[5f85c91]96 DEFS += -DCONFIG_SMP
[e16e036a]97endif
98ifeq ($(CONFIG_HT),y)
[5f85c91]99 DEFS += -DCONFIG_HT
[e16e036a]100endif
[04225a7]101ifeq ($(CONFIG_SIMICS_FIX),y)
102 DEFS += -DCONFIG_SIMICS_FIX
103endif
[1b492b5]104
[e16e036a]105ARCH_SOURCES = \
106 arch/$(ARCH)/src/context.s \
107 arch/$(ARCH)/src/debug/panic.s \
108 arch/$(ARCH)/src/delay.s \
109 arch/$(ARCH)/src/asm.S \
110 arch/$(ARCH)/src/proc/scheduler.c \
[3fa424a9]111 arch/$(ARCH)/src/proc/thread.c \
[e16e036a]112 arch/$(ARCH)/src/bios/bios.c \
113 arch/$(ARCH)/src/smp/ap.S \
114 arch/$(ARCH)/src/smp/apic.c \
115 arch/$(ARCH)/src/smp/mps.c \
116 arch/$(ARCH)/src/smp/smp.c \
117 arch/$(ARCH)/src/atomic.S \
118 arch/$(ARCH)/src/smp/ipi.c \
119 arch/$(ARCH)/src/ia32.c \
120 arch/$(ARCH)/src/interrupt.c \
121 arch/$(ARCH)/src/pm.c \
122 arch/$(ARCH)/src/userspace.c \
123 arch/$(ARCH)/src/cpu/cpu.c \
[ef67bab]124 arch/$(ARCH)/src/mm/as.c \
[e16e036a]125 arch/$(ARCH)/src/mm/frame.c \
126 arch/$(ARCH)/src/mm/memory_init.c \
127 arch/$(ARCH)/src/mm/page.c \
128 arch/$(ARCH)/src/mm/tlb.c \
129 arch/$(ARCH)/src/drivers/i8254.c \
130 arch/$(ARCH)/src/drivers/i8259.c \
131 arch/$(ARCH)/src/drivers/ega.c \
132 arch/$(ARCH)/src/boot/boot.S \
[23d22eb]133 arch/$(ARCH)/src/fpu_context.c \
134 arch/$(ARCH)/src/debugger.c
Note: See TracBrowser for help on using the repository browser.