romcc:
- Set __PRE_RAM__ define per default - Properly handle ignored (#ifdef'd out) #include lines amd/serengeti_cheetah_fam10: - write ACPI files to $(obj) instead of the top dir (alias $(CURDIR)) tinybootblock: - provide a way to define code that should be added to the bootblock, to map the entire ROM for use by CBFS amd/model_fxx, amd/model_10xxx: - add CONFIG_SSE walkcbfs.S: - eliminate the use of two registers, to make space for romcc to wiggle amd/serengeti_cheetah_fam10: - use the enable_rom framework. not entirely functional yet Boot-tested on emulation/qemu-x86 Build-tested on amd/serengeti_cheetah_fam10 amd/serengeti_cheetah_fam10 fails in amdht/ somewhere, but builds Signed-off-by: Patrick Georgi <patrick.georgi@coresystems.de> Acked-by: Ronald G. Minnich <rminnich@gmail.com> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@4994 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
9db833bec3
commit
1bb6828900
|
@ -43,3 +43,9 @@ config MAX_REBOOT_CNT
|
||||||
config TINY_BOOTBLOCK
|
config TINY_BOOTBLOCK
|
||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
|
|
||||||
|
config BOOTBLOCK_NORTHBRIDGE_INIT
|
||||||
|
string
|
||||||
|
|
||||||
|
config BOOTBLOCK_SOUTHBRIDGE_INIT
|
||||||
|
string
|
||||||
|
|
|
@ -30,9 +30,17 @@ bootblock_inc += $(src)/cpu/x86/16bit/entry16.inc
|
||||||
bootblock_inc += $(src)/cpu/x86/16bit/reset16.inc
|
bootblock_inc += $(src)/cpu/x86/16bit/reset16.inc
|
||||||
bootblock_inc += $(src)/cpu/x86/32bit/entry32.inc
|
bootblock_inc += $(src)/cpu/x86/32bit/entry32.inc
|
||||||
bootblock_inc += $(src)/arch/i386/lib/id.inc
|
bootblock_inc += $(src)/arch/i386/lib/id.inc
|
||||||
|
ifeq ($(CONFIG_SSE),y)
|
||||||
|
bootblock_inc += $(src)/cpu/x86/sse_enable.inc
|
||||||
|
endif
|
||||||
bootblock_inc += $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.inc
|
bootblock_inc += $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.inc
|
||||||
bootblock_inc += $(src)/arch/i386/lib/walkcbfs.S
|
bootblock_inc += $(src)/arch/i386/lib/walkcbfs.S
|
||||||
|
|
||||||
|
bootblock_romccflags := -mcpu=i386
|
||||||
|
ifeq ($(CONFIG_SSE),y)
|
||||||
|
bootblock_romccflags := -mcpu=k7 -msse
|
||||||
|
endif
|
||||||
|
|
||||||
$(obj)/bootblock/ldscript.ld: $(bootblock_ldscripts) $(obj)/ldoptions
|
$(obj)/bootblock/ldscript.ld: $(bootblock_ldscripts) $(obj)/ldoptions
|
||||||
mkdir -p $(obj)/bootblock
|
mkdir -p $(obj)/bootblock
|
||||||
printf '$(foreach ldscript,ldoptions $(bootblock_lds),INCLUDE "$(ldscript)"\n)' > $@
|
printf '$(foreach ldscript,ldoptions $(bootblock_lds),INCLUDE "$(ldscript)"\n)' > $@
|
||||||
|
@ -48,7 +56,7 @@ $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.s: $(obj)/bootblock/bootblock.c
|
||||||
$(CC) -x assembler-with-cpp -DASSEMBLY -E -I$(src)/include -I$(src)/arch/i386/include -I$(obj) -I$(obj)/bootblock -include $(obj)/config.h -I. -I$(src) $< > $@.new && mv $@.new $@
|
$(CC) -x assembler-with-cpp -DASSEMBLY -E -I$(src)/include -I$(src)/arch/i386/include -I$(obj) -I$(obj)/bootblock -include $(obj)/config.h -I. -I$(src) $< > $@.new && mv $@.new $@
|
||||||
|
|
||||||
$(obj)/mainboard/$(MAINBOARDDIR)/bootblock.inc: $(obj)/romcc $(src)/arch/i386/init/bootblock.c
|
$(obj)/mainboard/$(MAINBOARDDIR)/bootblock.inc: $(obj)/romcc $(src)/arch/i386/init/bootblock.c
|
||||||
$(obj)/romcc $(ROMCCFLAGS) $(INCLUDES) $(src)/arch/i386/init/bootblock.c -o $@
|
$(obj)/romcc $(bootblock_romccflags) -O2 $(ROMCCFLAGS) $(INCLUDES) $(src)/arch/i386/init/bootblock.c -o $@
|
||||||
|
|
||||||
$(obj)/bootblock.elf: $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.o $(obj)/bootblock/ldscript.ld
|
$(obj)/bootblock.elf: $(obj)/mainboard/$(MAINBOARDDIR)/bootblock.o $(obj)/bootblock/ldscript.ld
|
||||||
@printf " LINK $(subst $(obj)/,,$(@))\n"
|
@printf " LINK $(subst $(obj)/,,$(@))\n"
|
||||||
|
|
|
@ -1,24 +1,46 @@
|
||||||
|
#if CONFIG_LOGICAL_CPUS && \
|
||||||
|
(defined(CONFIG_BOOTBLOCK_NORTHBRIDGE_INIT) || defined(CONFIG_BOOTBLOCK_SOUTHBRIDGE_INIT))
|
||||||
|
#include <cpu/x86/lapic/boot_cpu.c>
|
||||||
|
#else
|
||||||
|
#define boot_cpu(x) 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_BOOTBLOCK_NORTHBRIDGE_INIT
|
||||||
|
#include CONFIG_BOOTBLOCK_NORTHBRIDGE_INIT
|
||||||
|
#else
|
||||||
|
static void bootblock_northbridge_init(void) { }
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_BOOTBLOCK_SOUTHBRIDGE_INIT
|
||||||
|
#include CONFIG_BOOTBLOCK_SOUTHBRIDGE_INIT
|
||||||
|
#else
|
||||||
|
static void bootblock_southbridge_init(void) { }
|
||||||
|
#endif
|
||||||
|
|
||||||
static unsigned long findstage(char* target)
|
static unsigned long findstage(char* target)
|
||||||
{
|
{
|
||||||
unsigned long entry;
|
unsigned long entry;
|
||||||
asm volatile (
|
asm volatile (
|
||||||
"mov $1f, %%esp\n\t"
|
"mov $1f, %%esp\n\t"
|
||||||
"jmp walkcbfs\n\t"
|
"jmp walkcbfs\n\t"
|
||||||
"1:\n\t" : "=a" (entry) : "S" (target) : "ebx", "ecx", "edx", "edi", "ebp", "esp");
|
"1:\n\t" : "=a" (entry) : "S" (target) : "ebx", "ecx", "edi", "esp");
|
||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void call(unsigned long addr)
|
static void call(unsigned long addr, unsigned long bist)
|
||||||
{
|
{
|
||||||
asm volatile ("jmp %0\n\t" : : "r" (addr));
|
asm volatile ("jmp %0\n\t" : : "r" (addr), "a" (bist));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void main(void)
|
static void main(unsigned long bist)
|
||||||
{
|
{
|
||||||
|
if (boot_cpu()) {
|
||||||
|
bootblock_northbridge_init();
|
||||||
|
bootblock_southbridge_init();
|
||||||
|
}
|
||||||
const char* target1 = "fallback/romstage";
|
const char* target1 = "fallback/romstage";
|
||||||
unsigned long entry;
|
unsigned long entry;
|
||||||
entry = findstage(target1);
|
entry = findstage(target1);
|
||||||
if (entry) call(entry);
|
if (entry) call(entry, bist);
|
||||||
asm volatile ("1:\n\thlt\n\tjmp 1b\n\t");
|
asm volatile ("1:\n\thlt\n\tjmp 1b\n\t");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,18 +25,9 @@
|
||||||
input %esi: filename
|
input %esi: filename
|
||||||
input %esp: return address (not pointer to return address!)
|
input %esp: return address (not pointer to return address!)
|
||||||
output %eax: entry point
|
output %eax: entry point
|
||||||
clobbers %ebx, %ecx, %edx, %edi, %ebp
|
clobbers %ebx, %ecx, %edi
|
||||||
*/
|
*/
|
||||||
walkcbfs:
|
walkcbfs:
|
||||||
mov %esi, %ebp /* stash away filename pointer */
|
|
||||||
mov $0, %edx
|
|
||||||
1:
|
|
||||||
cmpb $0, (%edx,%esi)
|
|
||||||
jz 2f
|
|
||||||
add $1, %edx
|
|
||||||
jmp 1b
|
|
||||||
2:
|
|
||||||
add $1, %edx
|
|
||||||
mov CBFS_HEADER_PTR, %eax
|
mov CBFS_HEADER_PTR, %eax
|
||||||
mov CBFS_HEADER_ROMSIZE(%eax), %ecx
|
mov CBFS_HEADER_ROMSIZE(%eax), %ecx
|
||||||
bswap %ecx
|
bswap %ecx
|
||||||
|
@ -45,15 +36,20 @@ walkcbfs:
|
||||||
mov CBFS_HEADER_OFFSET(%eax), %ecx
|
mov CBFS_HEADER_OFFSET(%eax), %ecx
|
||||||
bswap %ecx
|
bswap %ecx
|
||||||
add %ecx, %ebx
|
add %ecx, %ebx
|
||||||
mov CBFS_HEADER_ALIGN(%eax), %eax
|
|
||||||
bswap %eax
|
|
||||||
sub $1, %eax
|
|
||||||
|
|
||||||
|
/* determine filename length */
|
||||||
|
mov $0, %eax
|
||||||
|
1:
|
||||||
|
cmpb $0, (%eax,%esi)
|
||||||
|
jz 2f
|
||||||
|
add $1, %eax
|
||||||
|
jmp 1b
|
||||||
|
2:
|
||||||
|
add $1, %eax
|
||||||
walker:
|
walker:
|
||||||
mov %ebp, %esi
|
|
||||||
mov %ebx, %edi
|
mov %ebx, %edi
|
||||||
add $CBFS_FILE_STRUCTSIZE, %edi /* edi = address of first byte after struct cbfs_file */
|
add $CBFS_FILE_STRUCTSIZE, %edi /* edi = address of first byte after struct cbfs_file */
|
||||||
mov %edx, %ecx
|
mov %eax, %ecx
|
||||||
repe cmpsb
|
repe cmpsb
|
||||||
# zero flag set if strings are equal
|
# zero flag set if strings are equal
|
||||||
jnz tryharder
|
jnz tryharder
|
||||||
|
@ -67,21 +63,29 @@ walker:
|
||||||
jmp *%esp
|
jmp *%esp
|
||||||
|
|
||||||
tryharder:
|
tryharder:
|
||||||
|
sub %ebx, %edi /* edi = # of walked bytes */
|
||||||
|
sub %edi, %esi /* esi = start of filename */
|
||||||
|
|
||||||
|
/* ebx = ecx = (current+offset+len+ALIGN-1) & ~(ALIGN-1) */
|
||||||
mov CBFS_FILE_OFFSET(%ebx), %ecx
|
mov CBFS_FILE_OFFSET(%ebx), %ecx
|
||||||
bswap %ecx
|
bswap %ecx
|
||||||
add %ebx, %ecx
|
add %ebx, %ecx
|
||||||
mov CBFS_FILE_LEN(%ebx), %edi
|
mov CBFS_FILE_LEN(%ebx), %edi
|
||||||
bswap %edi
|
bswap %edi
|
||||||
add %edi, %ecx
|
add %edi, %ecx
|
||||||
add %eax, %ecx
|
mov CBFS_HEADER_PTR, %ebx
|
||||||
mov %eax, %edi
|
mov CBFS_HEADER_ALIGN(%ebx), %ebx
|
||||||
|
bswap %ebx
|
||||||
|
sub $1, %ebx
|
||||||
|
add %ebx, %ecx
|
||||||
|
mov %ebx, %edi
|
||||||
not %edi
|
not %edi
|
||||||
and %edi, %ecx
|
and %edi, %ecx
|
||||||
mov %ecx, %ebx
|
mov %ecx, %ebx
|
||||||
|
|
||||||
/* look if we should exit */
|
/* look if we should exit */
|
||||||
mov CBFS_HEADER_PTR, %esi
|
mov CBFS_HEADER_PTR, %ecx
|
||||||
mov CBFS_HEADER_ROMSIZE(%esi), %ecx
|
mov CBFS_HEADER_ROMSIZE(%ecx), %ecx
|
||||||
bswap %ecx
|
bswap %ecx
|
||||||
not %ecx
|
not %ecx
|
||||||
add $1, %ecx
|
add $1, %ecx
|
||||||
|
|
|
@ -3,6 +3,7 @@ config CPU_AMD_MODEL_10XXX
|
||||||
select HAVE_MOVNTI
|
select HAVE_MOVNTI
|
||||||
select USE_PRINTK_IN_CAR
|
select USE_PRINTK_IN_CAR
|
||||||
select USE_DCACHE_RAM
|
select USE_DCACHE_RAM
|
||||||
|
select SSE
|
||||||
|
|
||||||
config CPU_ADDR_BITS
|
config CPU_ADDR_BITS
|
||||||
int
|
int
|
||||||
|
|
|
@ -3,6 +3,7 @@ config CPU_AMD_MODEL_FXX
|
||||||
select HAVE_MOVNTI
|
select HAVE_MOVNTI
|
||||||
select USE_PRINTK_IN_CAR
|
select USE_PRINTK_IN_CAR
|
||||||
select USE_DCACHE_RAM
|
select USE_DCACHE_RAM
|
||||||
|
select SSE
|
||||||
|
|
||||||
config CPU_ADDR_BITS
|
config CPU_ADDR_BITS
|
||||||
int
|
int
|
||||||
|
|
|
@ -20,6 +20,7 @@ config BOARD_AMD_SERENGETI_CHEETAH_FAM10
|
||||||
select BOARD_ROMSIZE_KB_1024
|
select BOARD_ROMSIZE_KB_1024
|
||||||
select ENABLE_APIC_EXT_ID
|
select ENABLE_APIC_EXT_ID
|
||||||
select LIFT_BSP_APIC_ID
|
select LIFT_BSP_APIC_ID
|
||||||
|
select TINY_BOOTBLOCK
|
||||||
|
|
||||||
config MAINBOARD_DIR
|
config MAINBOARD_DIR
|
||||||
string
|
string
|
||||||
|
@ -127,3 +128,12 @@ config MAINBOARD_PCI_SUBSYSTEM_VENDOR_ID
|
||||||
default 0x1022
|
default 0x1022
|
||||||
depends on BOARD_AMD_SERENGETI_CHEETAH_FAM10
|
depends on BOARD_AMD_SERENGETI_CHEETAH_FAM10
|
||||||
|
|
||||||
|
config RAMBASE
|
||||||
|
hex
|
||||||
|
default 0x200000
|
||||||
|
depends on BOARD_AMD_SERENGETI_CHEETAH_FAM10
|
||||||
|
|
||||||
|
config ID_SECTION_OFFSET
|
||||||
|
hex
|
||||||
|
default 0x80
|
||||||
|
depends on BOARD_AMD_SERENGETI_CHEETAH_FAM10
|
||||||
|
|
|
@ -41,17 +41,12 @@ driver-y += ../../../drivers/i2c/i2cmux2/i2cmux2.o
|
||||||
|
|
||||||
initobj-y += crt0.o
|
initobj-y += crt0.o
|
||||||
# FIXME in $(top)/Makefile
|
# FIXME in $(top)/Makefile
|
||||||
crt0-y += ../../../../src/cpu/x86/16bit/entry16.inc
|
|
||||||
crt0-y += ../../../../src/cpu/x86/32bit/entry32.inc
|
crt0-y += ../../../../src/cpu/x86/32bit/entry32.inc
|
||||||
crt0-y += ../../../../src/cpu/x86/16bit/reset16.inc
|
|
||||||
crt0-y += ../../../../src/arch/i386/lib/id.inc
|
|
||||||
crt0-y += ../../../../src/cpu/amd/car/cache_as_ram.inc
|
crt0-y += ../../../../src/cpu/amd/car/cache_as_ram.inc
|
||||||
crt0-y += auto.inc
|
crt0-y += auto.inc
|
||||||
|
|
||||||
ldscript-y += ../../../../src/arch/i386/init/ldscript_fallback_cbfs.lb
|
ldscript-y += ../../../../src/arch/i386/init/ldscript_fallback_cbfs.lb
|
||||||
ldscript-y += ../../../../src/cpu/x86/16bit/entry16.lds
|
ldscript-y += ../../../../src/cpu/x86/32bit/entry32.lds
|
||||||
ldscript-y += ../../../../src/cpu/x86/16bit/reset16.lds
|
|
||||||
ldscript-y += ../../../../src/arch/i386/lib/id.lds
|
|
||||||
ldscript-y += ../../../../src/arch/i386/lib/failover.lds
|
ldscript-y += ../../../../src/arch/i386/lib/failover.lds
|
||||||
|
|
||||||
ifdef POST_EVALUATION
|
ifdef POST_EVALUATION
|
||||||
|
|
|
@ -52,4 +52,9 @@ config HW_MEM_HOLE_SIZE_AUTO_INC
|
||||||
default n
|
default n
|
||||||
depends on NORTHBRIDGE_AMD_AMDFAM10
|
depends on NORTHBRIDGE_AMD_AMDFAM10
|
||||||
|
|
||||||
|
config BOOTBLOCK_NORTHBRIDGE_INIT
|
||||||
|
string
|
||||||
|
default "northbridge/amd/amdfam10/bootblock.c"
|
||||||
|
depends on NORTHBRIDGE_AMD_AMDFAM10
|
||||||
|
|
||||||
source src/northbridge/amd/amdfam10/root_complex/Kconfig
|
source src/northbridge/amd/amdfam10/root_complex/Kconfig
|
||||||
|
|
|
@ -13,33 +13,33 @@ obj-y += get_pci1234.o
|
||||||
|
|
||||||
ifdef POST_EVALUATION
|
ifdef POST_EVALUATION
|
||||||
$(obj)/northbridge/amd/amdfam10/ssdt.c: $(src)/northbridge/amd/amdfam10/ssdt.dsl
|
$(obj)/northbridge/amd/amdfam10/ssdt.c: $(src)/northbridge/amd/amdfam10/ssdt.dsl
|
||||||
iasl -p $(CURDIR)/ssdt -tc $<
|
iasl -p $(obj)/ssdt -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_ssdt/g' ssdt.hex
|
perl -pi -e 's/AmlCode/AmlCode_ssdt/g' $(obj)/ssdt.hex
|
||||||
mv ssdt.hex $@
|
mv $(obj)/ssdt.hex $@
|
||||||
|
|
||||||
$(obj)/northbridge/amd/amdfam10/sspr1.c: $(src)/northbridge/amd/amdfam10/sspr1.dsl
|
$(obj)/northbridge/amd/amdfam10/sspr1.c: $(src)/northbridge/amd/amdfam10/sspr1.dsl
|
||||||
iasl -p $(CURDIR)/sspr1 -tc $<
|
iasl -p $(obj)/sspr1 -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_sspr1/g' sspr1.hex
|
perl -pi -e 's/AmlCode/AmlCode_sspr1/g' $(obj)/sspr1.hex
|
||||||
mv sspr1.hex $@
|
mv $(obj)/sspr1.hex $@
|
||||||
|
|
||||||
$(obj)/northbridge/amd/amdfam10/sspr2.c: $(src)/northbridge/amd/amdfam10/sspr2.dsl
|
$(obj)/northbridge/amd/amdfam10/sspr2.c: $(src)/northbridge/amd/amdfam10/sspr2.dsl
|
||||||
iasl -p $(CURDIR)/sspr2 -tc $<
|
iasl -p $(obj)/sspr2 -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_sspr2/g' sspr2.hex
|
perl -pi -e 's/AmlCode/AmlCode_sspr2/g' $(obj)/sspr2.hex
|
||||||
mv sspr2.hex $@
|
mv $(obj)/sspr2.hex $@
|
||||||
|
|
||||||
$(obj)/northbridge/amd/amdfam10/sspr3.c: $(src)/northbridge/amd/amdfam10/sspr3.dsl
|
$(obj)/northbridge/amd/amdfam10/sspr3.c: $(src)/northbridge/amd/amdfam10/sspr3.dsl
|
||||||
iasl -p $(CURDIR)/sspr3 -tc $<
|
iasl -p $(obj)/sspr3 -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_sspr3/g' sspr3.hex
|
perl -pi -e 's/AmlCode/AmlCode_sspr3/g' $(obj)/sspr3.hex
|
||||||
mv sspr3.hex $@
|
mv $(obj)/sspr3.hex $@
|
||||||
|
|
||||||
$(obj)/northbridge/amd/amdfam10/sspr4.c: $(src)/northbridge/amd/amdfam10/sspr4.dsl
|
$(obj)/northbridge/amd/amdfam10/sspr4.c: $(src)/northbridge/amd/amdfam10/sspr4.dsl
|
||||||
iasl -p $(CURDIR)/sspr4 -tc $<
|
iasl -p $(obj)/sspr4 -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_sspr4/g' sspr4.hex
|
perl -pi -e 's/AmlCode/AmlCode_sspr4/g' $(obj)/sspr4.hex
|
||||||
mv sspr4.hex $@
|
mv $(obj)/sspr4.hex $@
|
||||||
|
|
||||||
$(obj)/northbridge/amd/amdfam10/sspr5.c: $(src)/northbridge/amd/amdfam10/sspr5.dsl
|
$(obj)/northbridge/amd/amdfam10/sspr5.c: $(src)/northbridge/amd/amdfam10/sspr5.dsl
|
||||||
iasl -p $(CURDIR)/sspr5 -tc $<
|
iasl -p $(obj)/sspr5 -tc $<
|
||||||
perl -pi -e 's/AmlCode/AmlCode_sspr5/g' sspr5.hex
|
perl -pi -e 's/AmlCode/AmlCode_sspr5/g' $(obj)/sspr5.hex
|
||||||
mv sspr5.hex $@
|
mv $(obj)/sspr5.hex $@
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
#include <arch/io.h>
|
||||||
|
#include <arch/romcc_io.h>
|
||||||
|
#include <device/pci_def.h>
|
||||||
|
#include "northbridge/amd/amdfam10/early_ht.c"
|
||||||
|
|
||||||
|
static void bootblock_northbridge_init(void) {
|
||||||
|
/* Nothing special needs to be done to find bus 0 */
|
||||||
|
/* Allow the HT devices to be found */
|
||||||
|
/* mov bsp to bus 0xff when > 8 nodes */
|
||||||
|
set_bsp_node_CHtExtNodeCfgEn();
|
||||||
|
enumerate_ht_chain();
|
||||||
|
}
|
|
@ -20,3 +20,7 @@
|
||||||
config SOUTHBRIDGE_AMD_AMD8111
|
config SOUTHBRIDGE_AMD_AMD8111
|
||||||
bool
|
bool
|
||||||
|
|
||||||
|
config BOOTBLOCK_SOUTHBRIDGE_INIT
|
||||||
|
string
|
||||||
|
default "southbridge/amd/amd8111/bootblock.c"
|
||||||
|
depends on SOUTHBRIDGE_AMD_AMD8111
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
#include "southbridge/amd/amd8111/amd8111_enable_rom.c"
|
||||||
|
|
||||||
|
static void bootblock_southbridge_init(void) {
|
||||||
|
/* Setup the rom access for 4M */
|
||||||
|
amd8111_enable_rom();
|
||||||
|
}
|
|
@ -103,8 +103,12 @@ sed \
|
||||||
-e "/^CONFIG_GDB_STUB / d" \
|
-e "/^CONFIG_GDB_STUB / d" \
|
||||||
-e "/^CONFIG_VIDEO_MB / d" \
|
-e "/^CONFIG_VIDEO_MB / d" \
|
||||||
-e "/^CONFIG_EXPERT / d" \
|
-e "/^CONFIG_EXPERT / d" \
|
||||||
|
-e "/^CONFIG_SSE / d" \
|
||||||
-e "/^CONFIG_VGA_BIOS / d" \
|
-e "/^CONFIG_VGA_BIOS / d" \
|
||||||
-e "/^CONFIG_WARNINGS_ARE_ERRORS / d" \
|
-e "/^CONFIG_WARNINGS_ARE_ERRORS / d" \
|
||||||
|
-e "/^CONFIG_TINY_BOOTBLOCK / d" \
|
||||||
|
-e "/^CONFIG_BOOTBLOCK_NORTHBRIDGE_INIT / d" \
|
||||||
|
-e "/^CONFIG_BOOTBLOCK_SOUTHBRIDGE_INIT / d" \
|
||||||
$A/new > $A/new.filtered
|
$A/new > $A/new.filtered
|
||||||
|
|
||||||
normalize $A/old.filtered > $A/old.normalized
|
normalize $A/old.filtered > $A/old.normalized
|
||||||
|
|
|
@ -3616,6 +3616,7 @@ static void register_builtin_macros(struct compile_state *state)
|
||||||
tm = localtime(&now);
|
tm = localtime(&now);
|
||||||
|
|
||||||
register_builtin_macro(state, "__ROMCC__", VERSION_MAJOR);
|
register_builtin_macro(state, "__ROMCC__", VERSION_MAJOR);
|
||||||
|
register_builtin_macro(state, "__PRE_RAM__", VERSION_MAJOR);
|
||||||
register_builtin_macro(state, "__ROMCC_MINOR__", VERSION_MINOR);
|
register_builtin_macro(state, "__ROMCC_MINOR__", VERSION_MINOR);
|
||||||
register_builtin_macro(state, "__FILE__", "\"This should be the filename\"");
|
register_builtin_macro(state, "__FILE__", "\"This should be the filename\"");
|
||||||
register_builtin_macro(state, "__LINE__", "54321");
|
register_builtin_macro(state, "__LINE__", "54321");
|
||||||
|
@ -5453,6 +5454,13 @@ static void preprocess(struct compile_state *state, struct token *current_token)
|
||||||
name = 0;
|
name = 0;
|
||||||
|
|
||||||
pp_eat(state, TOK_MINCLUDE);
|
pp_eat(state, TOK_MINCLUDE);
|
||||||
|
if (if_eat(state)) {
|
||||||
|
/* Find the end of the line */
|
||||||
|
while((tok = raw_peek(state)) != TOK_EOL) {
|
||||||
|
raw_eat(state, tok);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
tok = peek(state);
|
tok = peek(state);
|
||||||
if (tok == TOK_LIT_STRING) {
|
if (tok == TOK_LIT_STRING) {
|
||||||
struct token *tk;
|
struct token *tk;
|
||||||
|
|
Loading…
Reference in New Issue