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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since ecbdc724 was 04225a7, checked in by Ondrej Palkovsky <ondrap@…>, 20 years ago

Fixed boot process not to call malloc when slab not initialized.
Added simics workaround.

  • Property mode set to 100644
File size: 3.5 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
[9371c30]45DEFS += -D_CPU=${IA32_CPU}
[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
84
[e16e036a]85## Accepted configuration directives
86#
[f761f1eb]87
[e16e036a]88ifeq ($(CONFIG_SMP),y)
[5f85c91]89 DEFS += -DCONFIG_SMP
[e16e036a]90endif
91ifeq ($(CONFIG_HT),y)
[5f85c91]92 DEFS += -DCONFIG_HT
[e16e036a]93endif
[04225a7]94ifeq ($(CONFIG_SIMICS_FIX),y)
95 DEFS += -DCONFIG_SIMICS_FIX
96endif
[1b492b5]97
[e16e036a]98ARCH_SOURCES = \
99 arch/$(ARCH)/src/context.s \
100 arch/$(ARCH)/src/debug/panic.s \
101 arch/$(ARCH)/src/delay.s \
102 arch/$(ARCH)/src/asm.S \
103 arch/$(ARCH)/src/proc/scheduler.c \
104 arch/$(ARCH)/src/bios/bios.c \
105 arch/$(ARCH)/src/smp/ap.S \
106 arch/$(ARCH)/src/smp/apic.c \
107 arch/$(ARCH)/src/smp/mps.c \
108 arch/$(ARCH)/src/smp/smp.c \
109 arch/$(ARCH)/src/atomic.S \
110 arch/$(ARCH)/src/smp/ipi.c \
111 arch/$(ARCH)/src/ia32.c \
112 arch/$(ARCH)/src/interrupt.c \
113 arch/$(ARCH)/src/pm.c \
114 arch/$(ARCH)/src/userspace.c \
115 arch/$(ARCH)/src/cpu/cpu.c \
[ef67bab]116 arch/$(ARCH)/src/mm/as.c \
[e16e036a]117 arch/$(ARCH)/src/mm/frame.c \
118 arch/$(ARCH)/src/mm/memory_init.c \
119 arch/$(ARCH)/src/mm/page.c \
120 arch/$(ARCH)/src/mm/tlb.c \
121 arch/$(ARCH)/src/drivers/i8042.c \
122 arch/$(ARCH)/src/drivers/i8254.c \
123 arch/$(ARCH)/src/drivers/i8259.c \
124 arch/$(ARCH)/src/drivers/ega.c \
125 arch/$(ARCH)/src/boot/boot.S \
[b524c5e0]126 arch/$(ARCH)/src/fpu_context.c
Note: See TracBrowser for help on using the repository browser.