simplify code
git-svn-id: svn://svn.coreboot.org/coreboot/trunk@2012 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
afa190e046
commit
246ae2129e
|
@ -0,0 +1,6 @@
|
||||||
|
struct cpu_emulation_qemu_i386_config
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
extern struct chip_operations cpu_emulation_qemu_i386_ops;
|
||||||
|
|
|
@ -119,7 +119,16 @@ static void enable_dev(struct device *dev)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct chip_operations northbridge_emulation_qemu_i386_ops = {
|
struct chip_operations cpu_emulation_qemu_i386_ops = {
|
||||||
CHIP_NAME("QEMU Northbridge")
|
CHIP_NAME("QEMU Northbridge")
|
||||||
.enable_dev = enable_dev,
|
.enable_dev = enable_dev,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void udelay(int usecs)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for(i = 0; i < usecs; i++)
|
||||||
|
outb(i&0xff, 0x80);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,8 +2,11 @@
|
||||||
## Compute the location and size of where this firmware image
|
## Compute the location and size of where this firmware image
|
||||||
## (linuxBIOS plus bootloader) will live in the boot rom chip.
|
## (linuxBIOS plus bootloader) will live in the boot rom chip.
|
||||||
##
|
##
|
||||||
|
default ROM_SIZE = 256 * 1024
|
||||||
|
default FALLBACK_SIZE = 128*1024
|
||||||
|
|
||||||
if USE_FALLBACK_IMAGE
|
if USE_FALLBACK_IMAGE
|
||||||
default ROM_SECTION_SIZE = FALLBACK_SIZE
|
default ROM_SECTION_SIZE = 128 * 1024 # FALLBACK_SIZE
|
||||||
default ROM_SECTION_OFFSET = ( ROM_SIZE - FALLBACK_SIZE )
|
default ROM_SECTION_OFFSET = ( ROM_SIZE - FALLBACK_SIZE )
|
||||||
else
|
else
|
||||||
default ROM_SECTION_SIZE = ( ROM_SIZE - FALLBACK_SIZE )
|
default ROM_SECTION_SIZE = ( ROM_SIZE - FALLBACK_SIZE )
|
||||||
|
@ -29,9 +32,13 @@ default _ROMBASE = ( CONFIG_ROM_STREAM_START + PAYLOAD_SIZE )
|
||||||
## XIP_ROM_SIZE must be a power of 2.
|
## XIP_ROM_SIZE must be a power of 2.
|
||||||
## XIP_ROM_BASE must be a multiple of XIP_ROM_SIZE
|
## XIP_ROM_BASE must be a multiple of XIP_ROM_SIZE
|
||||||
##
|
##
|
||||||
default XIP_ROM_SIZE=65536
|
default XIP_ROM_SIZE=32*1024
|
||||||
default XIP_ROM_BASE = ( _ROMBASE + ROM_IMAGE_SIZE - XIP_ROM_SIZE )
|
default XIP_ROM_BASE = ( _ROMBASE + ROM_IMAGE_SIZE - XIP_ROM_SIZE )
|
||||||
|
|
||||||
|
##
|
||||||
|
## Set all of the defaults for an x86 architecture
|
||||||
|
##
|
||||||
|
|
||||||
arch i386 end
|
arch i386 end
|
||||||
|
|
||||||
##
|
##
|
||||||
|
@ -39,9 +46,8 @@ arch i386 end
|
||||||
##
|
##
|
||||||
|
|
||||||
driver mainboard.o
|
driver mainboard.o
|
||||||
if HAVE_MP_TABLE object mptable.o end
|
|
||||||
if HAVE_PIRQ_TABLE object irq_tables.o end
|
if HAVE_PIRQ_TABLE object irq_tables.o end
|
||||||
#object reset.o
|
object reset.o
|
||||||
|
|
||||||
##
|
##
|
||||||
## Romcc output
|
## Romcc output
|
||||||
|
@ -58,11 +64,11 @@ end
|
||||||
|
|
||||||
makerule ./auto.E
|
makerule ./auto.E
|
||||||
depends "$(MAINBOARD)/auto.c option_table.h ./romcc"
|
depends "$(MAINBOARD)/auto.c option_table.h ./romcc"
|
||||||
action "./romcc -E -mcpu=i386 -O2 -I$(TOP)/src -I. $(CPPFLAGS) $(MAINBOARD)/auto.c -o $@"
|
action "./romcc -E -mcpu=i386 -O -I$(TOP)/src -I. $(CPPFLAGS) $(MAINBOARD)/auto.c -o $@"
|
||||||
end
|
end
|
||||||
makerule ./auto.inc
|
makerule ./auto.inc
|
||||||
depends "$(MAINBOARD)/auto.c option_table.h ./romcc"
|
depends "$(MAINBOARD)/auto.c option_table.h ./romcc"
|
||||||
action "./romcc -mcpu=i386 -O2 -I$(TOP)/src -I. $(CPPFLAGS) $(MAINBOARD)/auto.c -o $@"
|
action "./romcc -mcpu=i386 -O -I$(TOP)/src -I. $(CPPFLAGS) $(MAINBOARD)/auto.c -o $@"
|
||||||
end
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
|
@ -111,11 +117,7 @@ end
|
||||||
## Setup RAM
|
## Setup RAM
|
||||||
##
|
##
|
||||||
mainboardinit cpu/x86/fpu/enable_fpu.inc
|
mainboardinit cpu/x86/fpu/enable_fpu.inc
|
||||||
#mainboardinit cpu/x86/mmx/enable_mmx.inc # emulators dont do mmx+sse
|
|
||||||
#mainboardinit cpu/x86/sse/enable_sse.inc
|
|
||||||
mainboardinit ./auto.inc
|
mainboardinit ./auto.inc
|
||||||
#mainboardinit cpu/x86/sse/disable_sse.inc
|
|
||||||
#mainboardinit cpu/x86/mmx/disable_mmx.inc
|
|
||||||
|
|
||||||
##
|
##
|
||||||
## Include the secondary Configuration files
|
## Include the secondary Configuration files
|
||||||
|
@ -123,8 +125,11 @@ mainboardinit ./auto.inc
|
||||||
dir /pc80
|
dir /pc80
|
||||||
config chip.h
|
config chip.h
|
||||||
|
|
||||||
chip northbridge/emulation/qemu-i386
|
chip cpu/emulation/qemu-i386
|
||||||
device pci_domain 0 on
|
device pci_domain 0 on
|
||||||
|
device pci 0.0 on end
|
||||||
|
device pci 1.0 on end
|
||||||
|
# register "com1" = "{1}"
|
||||||
|
# register "com1" = "{1, 0, 0x3f8, 4}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -3,67 +3,62 @@ uses HAVE_PIRQ_TABLE
|
||||||
uses USE_FALLBACK_IMAGE
|
uses USE_FALLBACK_IMAGE
|
||||||
uses HAVE_FALLBACK_BOOT
|
uses HAVE_FALLBACK_BOOT
|
||||||
uses HAVE_HARD_RESET
|
uses HAVE_HARD_RESET
|
||||||
uses IRQ_SLOT_COUNT
|
|
||||||
uses HAVE_OPTION_TABLE
|
uses HAVE_OPTION_TABLE
|
||||||
uses CONFIG_MAX_CPUS
|
uses USE_OPTION_TABLE
|
||||||
uses CONFIG_IOAPIC
|
uses CONFIG_COMPRESS
|
||||||
uses CONFIG_SMP
|
uses CONFIG_ROM_STREAM
|
||||||
|
uses IRQ_SLOT_COUNT
|
||||||
|
uses MAINBOARD
|
||||||
|
uses MAINBOARD_VENDOR
|
||||||
|
uses MAINBOARD_PART_NUMBER
|
||||||
|
uses LINUXBIOS_EXTRA_VERSION
|
||||||
|
uses ARCH
|
||||||
uses FALLBACK_SIZE
|
uses FALLBACK_SIZE
|
||||||
|
uses STACK_SIZE
|
||||||
|
uses HEAP_SIZE
|
||||||
uses ROM_SIZE
|
uses ROM_SIZE
|
||||||
uses ROM_SECTION_SIZE
|
uses ROM_SECTION_SIZE
|
||||||
uses ROM_IMAGE_SIZE
|
uses ROM_IMAGE_SIZE
|
||||||
uses ROM_SECTION_SIZE
|
uses ROM_SECTION_SIZE
|
||||||
uses ROM_SECTION_OFFSET
|
uses ROM_SECTION_OFFSET
|
||||||
uses CONFIG_ROM_STREAM
|
|
||||||
uses CONFIG_ROM_STREAM_START
|
uses CONFIG_ROM_STREAM_START
|
||||||
uses PAYLOAD_SIZE
|
uses PAYLOAD_SIZE
|
||||||
uses _ROMBASE
|
uses _ROMBASE
|
||||||
|
uses _RAMBASE
|
||||||
uses XIP_ROM_SIZE
|
uses XIP_ROM_SIZE
|
||||||
uses XIP_ROM_BASE
|
uses XIP_ROM_BASE
|
||||||
uses STACK_SIZE
|
uses HAVE_MP_TABLE
|
||||||
uses HEAP_SIZE
|
|
||||||
uses USE_OPTION_TABLE
|
|
||||||
uses LB_CKS_RANGE_START
|
|
||||||
uses LB_CKS_RANGE_END
|
|
||||||
uses LB_CKS_LOC
|
|
||||||
uses MAINBOARD
|
|
||||||
uses MAINBOARD_PART_NUMBER
|
|
||||||
uses MAINBOARD_VENDOR
|
|
||||||
uses LINUXBIOS_EXTRA_VERSION
|
|
||||||
uses _RAMBASE
|
|
||||||
uses TTYS0_BAUD
|
|
||||||
uses TTYS0_BASE
|
|
||||||
uses TTYS0_LCS
|
|
||||||
uses DEFAULT_CONSOLE_LOGLEVEL
|
|
||||||
uses MAXIMUM_CONSOLE_LOGLEVEL
|
|
||||||
uses MAINBOARD_POWER_ON_AFTER_POWER_FAIL
|
|
||||||
uses CONFIG_CONSOLE_SERIAL8250
|
|
||||||
uses HAVE_INIT_TIMER
|
|
||||||
uses CONFIG_GDB_STUB
|
|
||||||
uses CROSS_COMPILE
|
uses CROSS_COMPILE
|
||||||
uses CC
|
uses CC
|
||||||
uses HOSTCC
|
uses HOSTCC
|
||||||
uses OBJCOPY
|
uses OBJCOPY
|
||||||
|
|
||||||
|
uses CONFIG_CONSOLE_SERIAL8250
|
||||||
|
|
||||||
|
|
||||||
|
uses DEFAULT_CONSOLE_LOGLEVEL
|
||||||
|
uses MAXIMUM_CONSOLE_LOGLEVEL
|
||||||
|
|
||||||
|
default CONFIG_CONSOLE_SERIAL8250=1
|
||||||
|
default DEFAULT_CONSOLE_LOGLEVEL=8
|
||||||
|
default MAXIMUM_CONSOLE_LOGLEVEL=8
|
||||||
|
## ROM_SIZE is the size of boot ROM that this board will use.
|
||||||
|
default ROM_SIZE = 256*1024
|
||||||
|
|
||||||
###
|
###
|
||||||
### Build options
|
### Build options
|
||||||
###
|
###
|
||||||
|
|
||||||
##
|
|
||||||
## ROM_SIZE is the size of boot ROM that this board will use.
|
|
||||||
##
|
|
||||||
default ROM_SIZE=0x40000
|
|
||||||
|
|
||||||
##
|
|
||||||
## FALLBACK_SIZE is the amount of the ROM the complete fallback image will use
|
|
||||||
##
|
|
||||||
default FALLBACK_SIZE=0x40000
|
|
||||||
|
|
||||||
##
|
##
|
||||||
## Build code for the fallback boot
|
## Build code for the fallback boot
|
||||||
##
|
##
|
||||||
default HAVE_FALLBACK_BOOT=1
|
default HAVE_FALLBACK_BOOT=1
|
||||||
|
|
||||||
|
##
|
||||||
|
## no MP table
|
||||||
|
##
|
||||||
|
default HAVE_MP_TABLE=0
|
||||||
|
|
||||||
##
|
##
|
||||||
## Build code to reset the motherboard from linuxBIOS
|
## Build code to reset the motherboard from linuxBIOS
|
||||||
##
|
##
|
||||||
|
@ -73,51 +68,21 @@ default HAVE_HARD_RESET=0
|
||||||
## Build code to export a programmable irq routing table
|
## Build code to export a programmable irq routing table
|
||||||
##
|
##
|
||||||
default HAVE_PIRQ_TABLE=0
|
default HAVE_PIRQ_TABLE=0
|
||||||
default IRQ_SLOT_COUNT=9
|
default IRQ_SLOT_COUNT=5
|
||||||
|
#object irq_tables.o
|
||||||
##
|
|
||||||
## Build code to export an x86 MP table
|
|
||||||
## Useful for specifying IRQ routing values
|
|
||||||
##
|
|
||||||
default HAVE_MP_TABLE=0
|
|
||||||
|
|
||||||
##
|
##
|
||||||
## Build code to export a CMOS option table
|
## Build code to export a CMOS option table
|
||||||
##
|
##
|
||||||
default HAVE_OPTION_TABLE=1
|
default HAVE_OPTION_TABLE=1
|
||||||
|
|
||||||
##
|
|
||||||
## Move the default LinuxBIOS cmos range off of AMD RTC registers
|
|
||||||
##
|
|
||||||
default LB_CKS_RANGE_START=49
|
|
||||||
default LB_CKS_RANGE_END=122
|
|
||||||
default LB_CKS_LOC=123
|
|
||||||
|
|
||||||
##
|
|
||||||
## Build code for SMP support
|
|
||||||
## Only worry about 2 micro processors
|
|
||||||
##
|
|
||||||
default CONFIG_SMP=0
|
|
||||||
default CONFIG_MAX_CPUS=2
|
|
||||||
|
|
||||||
##
|
|
||||||
## Build code to setup a generic IOAPIC
|
|
||||||
##
|
|
||||||
default CONFIG_IOAPIC=1
|
|
||||||
|
|
||||||
##
|
|
||||||
## Clean up the motherboard id strings
|
|
||||||
##
|
|
||||||
default MAINBOARD_PART_NUMBER="x86"
|
|
||||||
default MAINBOARD_VENDOR="QEMU"
|
|
||||||
|
|
||||||
|
|
||||||
###
|
###
|
||||||
### LinuxBIOS layout values
|
### LinuxBIOS layout values
|
||||||
###
|
###
|
||||||
|
|
||||||
## ROM_IMAGE_SIZE is the amount of space to allow linuxBIOS to occupy.
|
## ROM_IMAGE_SIZE is the amount of space to allow linuxBIOS to occupy.
|
||||||
default ROM_IMAGE_SIZE = 65536
|
default ROM_IMAGE_SIZE = 65536
|
||||||
|
default FALLBACK_SIZE = 131072
|
||||||
|
|
||||||
##
|
##
|
||||||
## Use a small 8K stack
|
## Use a small 8K stack
|
||||||
|
@ -132,78 +97,19 @@ default HEAP_SIZE=0x4000
|
||||||
##
|
##
|
||||||
## Only use the option table in a normal image
|
## Only use the option table in a normal image
|
||||||
##
|
##
|
||||||
default USE_OPTION_TABLE = !USE_FALLBACK_IMAGE
|
#default USE_OPTION_TABLE = !USE_FALLBACK_IMAGE
|
||||||
|
default USE_OPTION_TABLE = 0
|
||||||
|
|
||||||
##
|
|
||||||
## LinuxBIOS C code runs at this location in RAM
|
|
||||||
##
|
|
||||||
default _RAMBASE = 0x00004000
|
default _RAMBASE = 0x00004000
|
||||||
|
|
||||||
##
|
|
||||||
## Load the payload from the ROM
|
|
||||||
##
|
|
||||||
default CONFIG_ROM_STREAM = 1
|
default CONFIG_ROM_STREAM = 1
|
||||||
|
|
||||||
###
|
|
||||||
### Defaults of options that you may want to override in the target config file
|
|
||||||
###
|
|
||||||
|
|
||||||
##
|
##
|
||||||
## The default compiler
|
## The default compiler
|
||||||
##
|
##
|
||||||
default CC="$(CROSS_COMPILE)gcc -m32"
|
default CC="$(CROSS_COMPILE)gcc -m32"
|
||||||
default HOSTCC="gcc"
|
default HOSTCC="gcc"
|
||||||
|
|
||||||
##
|
|
||||||
## Disable the gdb stub by default
|
|
||||||
##
|
|
||||||
default CONFIG_GDB_STUB=0
|
|
||||||
|
|
||||||
##
|
|
||||||
## The Serial Console
|
|
||||||
##
|
|
||||||
|
|
||||||
# To Enable the Serial Console
|
|
||||||
default CONFIG_CONSOLE_SERIAL8250=1
|
|
||||||
|
|
||||||
## Select the serial console baud rate
|
|
||||||
default TTYS0_BAUD=115200
|
|
||||||
#default TTYS0_BAUD=57600
|
|
||||||
#default TTYS0_BAUD=38400
|
|
||||||
#default TTYS0_BAUD=19200
|
|
||||||
#default TTYS0_BAUD=9600
|
|
||||||
#default TTYS0_BAUD=4800
|
|
||||||
#default TTYS0_BAUD=2400
|
|
||||||
#default TTYS0_BAUD=1200
|
|
||||||
|
|
||||||
# Select the serial console base port
|
|
||||||
default TTYS0_BASE=0x3f8
|
|
||||||
|
|
||||||
# Select the serial protocol
|
|
||||||
# This defaults to 8 data bits, 1 stop bit, and no parity
|
|
||||||
default TTYS0_LCS=0x3
|
|
||||||
|
|
||||||
##
|
|
||||||
### Select the linuxBIOS loglevel
|
|
||||||
##
|
|
||||||
## EMERG 1 system is unusable
|
|
||||||
## ALERT 2 action must be taken immediately
|
|
||||||
## CRIT 3 critical conditions
|
|
||||||
## ERR 4 error conditions
|
|
||||||
## WARNING 5 warning conditions
|
|
||||||
## NOTICE 6 normal but significant condition
|
|
||||||
## INFO 7 informational
|
|
||||||
## DEBUG 8 debug-level messages
|
|
||||||
## SPEW 9 Way too many details
|
|
||||||
|
|
||||||
## Request this level of debugging output
|
|
||||||
default DEFAULT_CONSOLE_LOGLEVEL=9
|
|
||||||
## At a maximum only compile in this level of debugging
|
|
||||||
default MAXIMUM_CONSOLE_LOGLEVEL=9
|
|
||||||
|
|
||||||
##
|
|
||||||
## Select power on after power fail setting
|
|
||||||
default MAINBOARD_POWER_ON_AFTER_POWER_FAIL="MAINBOARD_POWER_ON"
|
|
||||||
|
|
||||||
### End Options.lb
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
extern struct chip_operations mainboard_emulation_qemu_i386_ops;
|
extern struct chip_operations mainboard_emulation_qemu_i386_ops;
|
||||||
|
|
||||||
struct mainboard_emulation_qemu_i386_config {
|
struct mainboard_emulation_qemu_i386_config {
|
||||||
int nothing;
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
struct northbridge_emulation_qemu_i386_config
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
extern struct chip_operations northbridge_emulation_qemu_i386_ops;
|
|
Loading…
Reference in New Issue