diff --git a/src/arch/x86/boot/Makefile.inc b/src/arch/x86/boot/Makefile.inc index 2c482b33f3..9a68d81488 100644 --- a/src/arch/x86/boot/Makefile.inc +++ b/src/arch/x86/boot/Makefile.inc @@ -19,6 +19,4 @@ ramstage-$(CONFIG_GENERATE_SMBIOS_TABLES) += smbios.c ramstage-$(CONFIG_HAVE_ACPI_TABLES) += acpigen.c ramstage-$(CONFIG_HAVE_ACPI_RESUME) += wakeup.S -$(obj)/arch/x86/boot/smbios.ramstage.o: $(obj)/build.h - -endif # CONFIG_ARCH_RAMSTAGE_X86_32 \ No newline at end of file +endif # CONFIG_ARCH_RAMSTAGE_X86_32 diff --git a/src/arch/x86/boot/smbios.c b/src/arch/x86/boot/smbios.c index 64889f713c..f2f998d7bc 100644 --- a/src/arch/x86/boot/smbios.c +++ b/src/arch/x86/boot/smbios.c @@ -23,7 +23,7 @@ #include #include #include -#include +#include #include #include #include @@ -123,7 +123,7 @@ const char *__attribute__((weak)) smbios_mainboard_bios_version(void) if (strlen(CONFIG_LOCALVERSION)) return CONFIG_LOCALVERSION; else - return COREBOOT_VERSION; + return coreboot_version; } static int smbios_write_type0(unsigned long *current, int handle) @@ -138,13 +138,13 @@ static int smbios_write_type0(unsigned long *current, int handle) t->vendor = smbios_add_string(t->eos, "coreboot"); #if !CONFIG_CHROMEOS - t->bios_release_date = smbios_add_string(t->eos, COREBOOT_DMI_DATE); + t->bios_release_date = smbios_add_string(t->eos, coreboot_dmi_date); t->bios_version = smbios_add_string(t->eos, smbios_mainboard_bios_version()); #else #define SPACES \ " " - t->bios_release_date = smbios_add_string(t->eos, COREBOOT_DMI_DATE); + t->bios_release_date = smbios_add_string(t->eos, coreboot_dmi_date); u32 version_offset = (u32)smbios_string_table_len(t->eos); t->bios_version = smbios_add_string(t->eos, SPACES); /* SMBIOS offsets start at 1 rather than 0 */ diff --git a/src/console/Makefile.inc b/src/console/Makefile.inc index c72c60b309..d339500ea2 100644 --- a/src/console/Makefile.inc +++ b/src/console/Makefile.inc @@ -14,8 +14,3 @@ romstage-y += die.c bootblock-$(CONFIG_BOOTBLOCK_CONSOLE) += vtxprintf.c printk.c bootblock-$(CONFIG_BOOTBLOCK_CONSOLE) += init.c console.c bootblock-$(CONFIG_BOOTBLOCK_CONSOLE) += die.c - -$(obj)/console/init.smm.o : $(obj)/build.h -$(obj)/console/init.ramstage.o : $(obj)/build.h -$(obj)/console/init.romstage.o : $(obj)/build.h -$(obj)/console/init.bootblock.o : $(obj)/build.h diff --git a/src/console/init.c b/src/console/init.c index 6d3dc1f68a..3dbf014919 100644 --- a/src/console/init.c +++ b/src/console/init.c @@ -19,12 +19,12 @@ * MA 02110-1301 USA */ -#include #include #include #include #include #include +#include /* While in romstage, console loglevel is built-time constant. */ static ROMSTAGE_CONST int console_loglevel = CONFIG_DEFAULT_CONSOLE_LOGLEVEL; @@ -48,14 +48,7 @@ void console_init(void) console_hw_init(); #if defined(__PRE_RAM__) - static const char console_test[] = - "\n\ncoreboot-" - COREBOOT_VERSION - COREBOOT_EXTRA_VERSION - " " - COREBOOT_BUILD - " starting...\n"; - - print_info(console_test); + printk(BIOS_INFO, "\n\ncoreboot-%s%s %s starting...\n", + coreboot_version, coreboot_extra_version, coreboot_build); #endif } diff --git a/src/drivers/pc80/Makefile.inc b/src/drivers/pc80/Makefile.inc index a60033bbcb..fe6d11fd36 100644 --- a/src/drivers/pc80/Makefile.inc +++ b/src/drivers/pc80/Makefile.inc @@ -18,6 +18,3 @@ cmos.default-file = $(CONFIG_CMOS_DEFAULT_FILE):nvramtool cmos.default-type = 0xaa smm-y += mc146818rtc.c - -$(obj)/drivers/pc80/mc146818rtc.ramstage.o : $(obj)/build.h -$(obj)/drivers/pc80/mc146818rtc.smm.o : $(obj)/build.h diff --git a/src/drivers/pc80/mc146818rtc.c b/src/drivers/pc80/mc146818rtc.c index 9670e9ce6b..014a8c9402 100644 --- a/src/drivers/pc80/mc146818rtc.c +++ b/src/drivers/pc80/mc146818rtc.c @@ -1,5 +1,5 @@ #include -#include +#include #include #include #include @@ -17,11 +17,12 @@ static void cmos_update_date(u8 has_century) cmos_write(0, RTC_CLK_SECOND); cmos_write(0, RTC_CLK_MINUTE); cmos_write(1, RTC_CLK_HOUR); - cmos_write(COREBOOT_BUILD_WEEKDAY_BCD + 1, RTC_CLK_DAYOFWEEK); - cmos_write(COREBOOT_BUILD_DAY_BCD, RTC_CLK_DAYOFMONTH); - cmos_write(COREBOOT_BUILD_MONTH_BCD, RTC_CLK_MONTH); - cmos_write(COREBOOT_BUILD_YEAR_BCD, RTC_CLK_YEAR); - if (has_century) cmos_write(0x20, RTC_CLK_ALTCENTURY); + cmos_write(coreboot_build_date.weekday + 1, RTC_CLK_DAYOFWEEK); + cmos_write(coreboot_build_date.day, RTC_CLK_DAYOFMONTH); + cmos_write(coreboot_build_date.month, RTC_CLK_MONTH); + cmos_write(coreboot_build_date.year, RTC_CLK_YEAR); + if (has_century) + cmos_write(coreboot_build_date.century, RTC_CLK_ALTCENTURY); } #if CONFIG_USE_OPTION_TABLE diff --git a/src/include/device/azalia_device.h b/src/include/device/azalia_device.h index 0f477a357a..68c292a447 100644 --- a/src/include/device/azalia_device.h +++ b/src/include/device/azalia_device.h @@ -26,7 +26,6 @@ #include #include #include -#include #include diff --git a/src/include/string.h b/src/include/string.h index b4d0268419..b862194979 100644 --- a/src/include/string.h +++ b/src/include/string.h @@ -56,6 +56,16 @@ static inline char *strdup(const char *s) memcpy(d, s, sz); return d; } + +static inline char *strconcat(const char *s1, const char *s2) +{ + size_t sz_1 = strlen(s1); + size_t sz_2 = strlen(s2); + char *d = malloc(sz_1 + sz_2 + 1); + memcpy(d, s1, sz_1); + memcpy(d + sz_1, s2, sz_2 + 1); + return d; +} #endif static inline char *strncpy(char *to, const char *from, int count) diff --git a/src/include/version.h b/src/include/version.h index 729026139d..250cb27ea1 100644 --- a/src/include/version.h +++ b/src/include/version.h @@ -15,5 +15,16 @@ extern const char coreboot_compile_time[]; extern const char coreboot_compile_by[]; extern const char coreboot_compile_host[]; extern const char coreboot_compile_domain[]; +extern const char coreboot_dmi_date[]; + +struct bcd_date { + unsigned char century; + unsigned char year; + unsigned char month; + unsigned char day; + unsigned char weekday; +}; + +extern const struct bcd_date coreboot_build_date; #endif /* VERSION_H */ diff --git a/src/lib/Makefile.inc b/src/lib/Makefile.inc index 6faf28a950..55e0fa84a9 100644 --- a/src/lib/Makefile.inc +++ b/src/lib/Makefile.inc @@ -54,7 +54,6 @@ smm-$(CONFIG_SMM_TSEG) += malloc.c ramstage-y += delay.c ramstage-y += fallback_boot.c ramstage-y += compute_ip_checksum.c -ramstage-y += version.c ramstage-y += cbfs.c cbfs_core.c ramstage-y += lzma.c lzmadecode.c ramstage-y += stack.c @@ -92,7 +91,15 @@ romstage-$(CONFIG_CACHE_RELOCATED_RAMSTAGE_OUTSIDE_CBMEM) += ramstage_cache.c smm-y += cbfs.c cbfs_core.c memcmp.c smm-$(CONFIG_COMPILER_GCC) += gcc.c +bootblock-y += version.c +romstage-y += version.c +ramstage-y += version.c +smm-y += version.c + +$(obj)/lib/version.bootblock.o : $(obj)/build.h +$(obj)/lib/version.romstage.o : $(obj)/build.h $(obj)/lib/version.ramstage.o : $(obj)/build.h +$(obj)/lib/version.smm.o : $(obj)/build.h romstage-y += bootmode.c ramstage-y += bootmode.c diff --git a/src/lib/version.c b/src/lib/version.c index 027aea1309..eb5bbb8351 100644 --- a/src/lib/version.c +++ b/src/lib/version.c @@ -40,3 +40,13 @@ const char coreboot_compile_time[] = COREBOOT_COMPILE_TIME; const char coreboot_compile_by[] = COREBOOT_COMPILE_BY; const char coreboot_compile_host[] = COREBOOT_COMPILE_HOST; const char coreboot_compile_domain[] = COREBOOT_COMPILE_DOMAIN; + +const char coreboot_dmi_date[] = COREBOOT_DMI_DATE; + +const struct bcd_date coreboot_build_date = { + .century = 0x20, + .year = COREBOOT_BUILD_YEAR_BCD, + .month = COREBOOT_BUILD_MONTH_BCD, + .day = COREBOOT_BUILD_DAY_BCD, + .weekday = COREBOOT_BUILD_WEEKDAY_BCD, +}; diff --git a/src/mainboard/lenovo/t60/mainboard.c b/src/mainboard/lenovo/t60/mainboard.c index 79b3da8747..abda9eabc4 100644 --- a/src/mainboard/lenovo/t60/mainboard.c +++ b/src/mainboard/lenovo/t60/mainboard.c @@ -36,7 +36,7 @@ #include #include #include -#include +#include #include #define PANEL INT15_5F35_CL_DISPLAY_DEFAULT @@ -54,11 +54,16 @@ int get_cst_entries(acpi_cstate_t **entries) const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } static void mainboard_init(device_t dev) diff --git a/src/mainboard/lenovo/x200/mainboard.c b/src/mainboard/lenovo/x200/mainboard.c index 8bfd66b319..5354834e3e 100644 --- a/src/mainboard/lenovo/x200/mainboard.c +++ b/src/mainboard/lenovo/x200/mainboard.c @@ -27,7 +27,7 @@ #include #include #include -#include +#include #include #include #include @@ -37,11 +37,16 @@ const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } static void mainboard_init(device_t dev) diff --git a/src/mainboard/lenovo/x201/mainboard.c b/src/mainboard/lenovo/x201/mainboard.c index a58d41505c..3cda4fa6c6 100644 --- a/src/mainboard/lenovo/x201/mainboard.c +++ b/src/mainboard/lenovo/x201/mainboard.c @@ -45,7 +45,7 @@ #include #include #include -#include +#include #include "drivers/lenovo/lenovo.h" static acpi_cstate_t cst_entries[] = { @@ -62,11 +62,16 @@ int get_cst_entries(acpi_cstate_t ** entries) const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } diff --git a/src/mainboard/lenovo/x220/mainboard.c b/src/mainboard/lenovo/x220/mainboard.c index 2fdc204e4e..87c6c90743 100644 --- a/src/mainboard/lenovo/x220/mainboard.c +++ b/src/mainboard/lenovo/x220/mainboard.c @@ -32,7 +32,7 @@ #include #include #include -#include +#include void mainboard_suspend_resume(void) { @@ -42,11 +42,16 @@ void mainboard_suspend_resume(void) const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } static void mainboard_init(device_t dev) diff --git a/src/mainboard/lenovo/x230/mainboard.c b/src/mainboard/lenovo/x230/mainboard.c index da0aa65a0a..2a45808eed 100644 --- a/src/mainboard/lenovo/x230/mainboard.c +++ b/src/mainboard/lenovo/x230/mainboard.c @@ -33,7 +33,7 @@ #include #include #include -#include +#include void mainboard_suspend_resume(void) { @@ -43,11 +43,16 @@ void mainboard_suspend_resume(void) const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } static void mainboard_init(device_t dev) diff --git a/src/mainboard/lenovo/x60/mainboard.c b/src/mainboard/lenovo/x60/mainboard.c index 1d29c71220..334c27d64e 100644 --- a/src/mainboard/lenovo/x60/mainboard.c +++ b/src/mainboard/lenovo/x60/mainboard.c @@ -38,7 +38,7 @@ #include "dock.h" #include #include -#include +#include #include #include "drivers/lenovo/lenovo.h" @@ -103,11 +103,16 @@ static void mainboard_init(device_t dev) const char *smbios_mainboard_bios_version(void) { + static char *s = NULL; + /* Satisfy thinkpad_acpi. */ if (strlen(CONFIG_LOCALVERSION)) return "CBET4000 " CONFIG_LOCALVERSION; - else - return "CBET4000 " COREBOOT_VERSION; + + if (s != NULL) + return s; + s = strconcat("CBET4000 ", coreboot_version); + return s; } static void fill_ssdt(void) diff --git a/src/northbridge/intel/fsp_rangeley/Makefile.inc b/src/northbridge/intel/fsp_rangeley/Makefile.inc index 96de4df449..6cb6cb2349 100644 --- a/src/northbridge/intel/fsp_rangeley/Makefile.inc +++ b/src/northbridge/intel/fsp_rangeley/Makefile.inc @@ -36,4 +36,3 @@ CPPFLAGS_common += -I$(src)/mainboard/$(MAINBOARDDIR) CPPFLAGS_common += -I$(src)/northbridge/intel/fsp_rangeley/ CPPFLAGS_common += -I$(src)/northbridge/intel/fsp_rangeley/fsp -$(obj)/northbridge/intel/fsp_rangeley/acpi.ramstage.o : $(obj)/build.h diff --git a/src/northbridge/intel/fsp_rangeley/acpi.c b/src/northbridge/intel/fsp_rangeley/acpi.c index b2ddc88f93..4c959c05fe 100644 --- a/src/northbridge/intel/fsp_rangeley/acpi.c +++ b/src/northbridge/intel/fsp_rangeley/acpi.c @@ -29,7 +29,6 @@ #include #include #include -#include #include #include #include "northbridge.h" diff --git a/src/northbridge/intel/fsp_sandybridge/Makefile.inc b/src/northbridge/intel/fsp_sandybridge/Makefile.inc index 22e4ed4cbe..080a7f4946 100644 --- a/src/northbridge/intel/fsp_sandybridge/Makefile.inc +++ b/src/northbridge/intel/fsp_sandybridge/Makefile.inc @@ -34,4 +34,3 @@ smm-$(CONFIG_HAVE_SMI_HANDLER) += finalize.c CPPFLAGS_common += -I$(src)/northbridge/intel/fsp_sandybridge/fsp -$(obj)/northbridge/intel/fsp_sandybridge/acpi.ramstage.o : $(obj)/build.h diff --git a/src/northbridge/intel/fsp_sandybridge/acpi.c b/src/northbridge/intel/fsp_sandybridge/acpi.c index d820139db4..a372e7b70b 100644 --- a/src/northbridge/intel/fsp_sandybridge/acpi.c +++ b/src/northbridge/intel/fsp_sandybridge/acpi.c @@ -28,7 +28,6 @@ #include #include #include -#include #include #include #include "northbridge.h" diff --git a/src/northbridge/intel/haswell/Makefile.inc b/src/northbridge/intel/haswell/Makefile.inc index 372175554f..f2577c7bd9 100644 --- a/src/northbridge/intel/haswell/Makefile.inc +++ b/src/northbridge/intel/haswell/Makefile.inc @@ -40,4 +40,3 @@ mrc.bin-file := $(call strip_quotes,$(CONFIG_MRC_FILE)) mrc.bin-position := 0xfffa0000 mrc.bin-type := 0xab -$(obj)/northbridge/intel/haswell/acpi.ramstage.o : $(obj)/build.h diff --git a/src/northbridge/intel/haswell/acpi.c b/src/northbridge/intel/haswell/acpi.c index 37f3717d33..488170d74a 100644 --- a/src/northbridge/intel/haswell/acpi.c +++ b/src/northbridge/intel/haswell/acpi.c @@ -28,7 +28,6 @@ #include #include #include -#include #include "haswell.h" #include #include diff --git a/src/northbridge/intel/nehalem/Makefile.inc b/src/northbridge/intel/nehalem/Makefile.inc index 416e481d59..13275f6db0 100644 --- a/src/northbridge/intel/nehalem/Makefile.inc +++ b/src/northbridge/intel/nehalem/Makefile.inc @@ -42,4 +42,3 @@ mrc.cache-file := $(obj)/mrc.cache mrc.cache-position := 0xfffe0000 mrc.cache-type := 0xac -$(obj)/northbridge/intel/nehalem/acpi.ramstage.o : $(obj)/build.h diff --git a/src/northbridge/intel/nehalem/acpi.c b/src/northbridge/intel/nehalem/acpi.c index ed418fdaca..460942f121 100644 --- a/src/northbridge/intel/nehalem/acpi.c +++ b/src/northbridge/intel/nehalem/acpi.c @@ -32,7 +32,6 @@ #include #include #include -#include #include #include #include diff --git a/src/northbridge/intel/sandybridge/Makefile.inc b/src/northbridge/intel/sandybridge/Makefile.inc index e11468eb69..5d757a471e 100644 --- a/src/northbridge/intel/sandybridge/Makefile.inc +++ b/src/northbridge/intel/sandybridge/Makefile.inc @@ -65,4 +65,3 @@ mrc.cache-position := $(mrc-cache-position-y) mrc.cache-type := 0xac endif -$(obj)/northbridge/intel/sandybridge/acpi.ramstage.o : $(obj)/build.h diff --git a/src/northbridge/intel/sandybridge/acpi.c b/src/northbridge/intel/sandybridge/acpi.c index 29255884c3..7a4869654c 100644 --- a/src/northbridge/intel/sandybridge/acpi.c +++ b/src/northbridge/intel/sandybridge/acpi.c @@ -28,7 +28,6 @@ #include #include #include -#include #include #include #include "sandybridge.h" diff --git a/src/soc/intel/fsp_baytrail/romstage/Makefile.inc b/src/soc/intel/fsp_baytrail/romstage/Makefile.inc index ff7762eda7..00bdc6ce2e 100644 --- a/src/soc/intel/fsp_baytrail/romstage/Makefile.inc +++ b/src/soc/intel/fsp_baytrail/romstage/Makefile.inc @@ -22,5 +22,3 @@ romstage-y += romstage.c romstage-y += pmc.c romstage-y += report_platform.c romstage-$(CONFIG_ENABLE_BUILTIN_COM1) += uart.c - -$(obj)/soc/intel/fsp_baytrail/romstage/romstage.romstage.o : $(obj)/build.h \ No newline at end of file diff --git a/src/soc/intel/fsp_baytrail/romstage/romstage.c b/src/soc/intel/fsp_baytrail/romstage/romstage.c index cd3cd90d21..6dff7434cf 100644 --- a/src/soc/intel/fsp_baytrail/romstage/romstage.c +++ b/src/soc/intel/fsp_baytrail/romstage/romstage.c @@ -40,7 +40,7 @@ #include #include #include -#include +#include #include #include #include @@ -142,11 +142,8 @@ static void baytrail_rtc_init(void) if (rtc_failed) { printk(BIOS_DEBUG, - "RTC Failure detected. Resetting Date to %x/%x/%x%x\n", - COREBOOT_BUILD_MONTH_BCD, - COREBOOT_BUILD_DAY_BCD, - 0x20, - COREBOOT_BUILD_YEAR_BCD); + "RTC Failure detected. Resetting Date to %s\n", + coreboot_dmi_date); write32(DEFAULT_PBASE + GEN_PMCON1, gen_pmcon1 & ~RPS); } diff --git a/src/southbridge/intel/fsp_rangeley/Makefile.inc b/src/southbridge/intel/fsp_rangeley/Makefile.inc index 995d0dc213..48ac522ddd 100644 --- a/src/southbridge/intel/fsp_rangeley/Makefile.inc +++ b/src/southbridge/intel/fsp_rangeley/Makefile.inc @@ -37,7 +37,6 @@ romstage-y += romstage.c romstage-$(CONFIG_USBDEBUG) += usb_debug.c ramstage-$(CONFIG_USBDEBUG) += usb_debug.c -$(obj)/southbridge/intel/fsp_rangeley/early_init.romstage.o : $(obj)/build.h ifeq ($(CONFIG_INCLUDE_ME),y) INTERMEDIATE+=rangeley_add_descriptor diff --git a/src/southbridge/intel/fsp_rangeley/early_init.c b/src/southbridge/intel/fsp_rangeley/early_init.c index bd3d12ccb5..844f4b8492 100644 --- a/src/southbridge/intel/fsp_rangeley/early_init.c +++ b/src/southbridge/intel/fsp_rangeley/early_init.c @@ -25,7 +25,7 @@ #include #include #include -#include +#include #include #include "pci_devs.h" #include "soc.h" @@ -59,11 +59,8 @@ static void reset_rtc(void) if (rtc_failed) { printk(BIOS_DEBUG, - "RTC Failure detected. Resetting Date to %x/%x/%x%x\n", - COREBOOT_BUILD_MONTH_BCD, - COREBOOT_BUILD_DAY_BCD, - 0x20, - COREBOOT_BUILD_YEAR_BCD); + "RTC Failure detected. Resetting Date to %s\n", + coreboot_dmi_date); /* Clear the power failure flag */ write32(DEFAULT_PBASE + GEN_PMCON1, gen_pmcon1 & ~RPS);