summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNico Huber <nico.huber@secunet.com>2016-10-05 17:46:49 +0200
committerNico Huber <nico.h@gmx.de>2016-11-29 23:45:40 +0100
commitc83239eabc3b09273294a013c4dcb84f09ab0241 (patch)
tree6d3eacf46f8e5a7c5add0c58229093f7fd269520
parent079b5c65c3347d2539a6b3d7d88a194f2d66ad40 (diff)
downloadcoreboot-c83239eabc3b09273294a013c4dcb84f09ab0241.tar.gz
coreboot-c83239eabc3b09273294a013c4dcb84f09ab0241.tar.bz2
coreboot-c83239eabc3b09273294a013c4dcb84f09ab0241.zip
Hook up libhwbase in ramstage
It's hidden behind a configuration option `CONFIG_RAMSTAGE_LIBHWBASE`. This also adds some glue code to use the coreboot console for debug output and our monotonic timer framework as timer backend. v2: Also update 3rdparty/libhwbase to the latest master commit. Change-Id: I8e8d50271b46aac1141f95ab55ad323ac0889a8d Signed-off-by: Nico Huber <nico.huber@secunet.com> Reviewed-on: https://review.coreboot.org/16951 Tested-by: build bot (Jenkins) Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net> Reviewed-by: Ronald G. Minnich <rminnich@gmail.com>
m---------3rdparty/libhwbase0
-rw-r--r--src/Kconfig9
-rw-r--r--src/console/Kconfig9
-rw-r--r--src/console/Makefile.inc4
-rw-r--r--src/console/hw-debug_sink.adb59
-rw-r--r--src/console/hw-debug_sink.ads24
-rw-r--r--src/lib/Makefile.inc10
-rw-r--r--src/lib/gnat/Makefile.inc2
-rw-r--r--src/lib/hw-time-timer.adb48
9 files changed, 164 insertions, 1 deletions
diff --git a/3rdparty/libhwbase b/3rdparty/libhwbase
-Subproject 5e9b1b50e7ac90f68ca2ea798ef656ac863c285
+Subproject aab715f166bf1b54cfbd6982e8df49248ea544d
diff --git a/src/Kconfig b/src/Kconfig
index be38af130133..610be5671c17 100644
--- a/src/Kconfig
+++ b/src/Kconfig
@@ -1262,3 +1262,12 @@ config RAMSTAGE_ADA
def_bool n
help
Selected by features that use Ada code in ramstage.
+
+config RAMSTAGE_LIBHWBASE
+ def_bool n
+ select RAMSTAGE_ADA
+ help
+ Selected by features that require `libhwbase` in ramstage.
+
+config HWBASE_DYNAMIC_MMIO
+ def_bool y
diff --git a/src/console/Kconfig b/src/console/Kconfig
index 8f74613847de..caf91ab25246 100644
--- a/src/console/Kconfig
+++ b/src/console/Kconfig
@@ -399,4 +399,13 @@ config NO_EARLY_BOOTBLOCK_POSTCODES
POST codes that go out before the chipset's bootblock initialization
can happen. This option suppresses those POST codes.
+config HWBASE_DEBUG_CB
+ bool
+ default y if DEFAULT_CONSOLE_LOGLEVEL_7 || DEFAULT_CONSOLE_LOGLEVEL_8
+ default n
+
+config HWBASE_DEBUG_NULL
+ def_bool y
+ depends on !HWBASE_DEBUG_CB
+
endmenu
diff --git a/src/console/Makefile.inc b/src/console/Makefile.inc
index 059dea544c15..aa0dbf5f7207 100644
--- a/src/console/Makefile.inc
+++ b/src/console/Makefile.inc
@@ -2,6 +2,10 @@ ramstage-y += vtxprintf.c printk.c vsprintf.c
ramstage-y += init.c console.c
ramstage-y += post.c
ramstage-y += die.c
+ifeq ($(CONFIG_HWBASE_DEBUG_CB),y)
+ramstage-$(CONFIG_RAMSTAGE_LIBHWBASE) += hw-debug_sink.ads
+ramstage-$(CONFIG_RAMSTAGE_LIBHWBASE) += hw-debug_sink.adb
+endif
smm-$(CONFIG_DEBUG_SMI) += init.c console.c vtxprintf.c printk.c
smm-$(CONFIG_SMM_TSEG) += die.c
diff --git a/src/console/hw-debug_sink.adb b/src/console/hw-debug_sink.adb
new file mode 100644
index 000000000000..5a165562dc91
--- /dev/null
+++ b/src/console/hw-debug_sink.adb
@@ -0,0 +1,59 @@
+--
+-- This file is part of the coreboot project.
+--
+-- Copyright (C) 2015 secunet Security Networks AG
+--
+-- This program is free software; you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation; version 2 of the License.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+
+with Interfaces.C;
+
+use type Interfaces.C.int;
+
+package body HW.Debug_Sink is
+
+ Sink_Enabled : Boolean;
+
+ procedure console_tx_byte (chr : Interfaces.C.char);
+ pragma Import (C, console_tx_byte, "console_tx_byte");
+
+ procedure Put (Item : String) is
+ begin
+ if Sink_Enabled then
+ for Idx in Item'Range loop
+ console_tx_byte (Interfaces.C.To_C (Item (Idx)));
+ end loop;
+ end if;
+ end Put;
+
+ procedure Put_Char (Item : Character) is
+ begin
+ if Sink_Enabled then
+ console_tx_byte (Interfaces.C.To_C (Item));
+ end if;
+ end Put_Char;
+
+ procedure New_Line is
+ begin
+ Put_Char (Character'Val (16#0a#));
+ end New_Line;
+
+ ----------------------------------------------------------------------------
+
+ function console_log_level
+ (msg_level : Interfaces.C.int)
+ return Interfaces.C.int;
+ pragma Import (C, console_log_level, "console_log_level");
+
+ Msg_Level_BIOS_DEBUG : constant := 7;
+
+begin
+ Sink_Enabled := console_log_level (Msg_Level_BIOS_DEBUG) /= 0;
+end HW.Debug_Sink;
diff --git a/src/console/hw-debug_sink.ads b/src/console/hw-debug_sink.ads
new file mode 100644
index 000000000000..322249e1cb8d
--- /dev/null
+++ b/src/console/hw-debug_sink.ads
@@ -0,0 +1,24 @@
+--
+-- This file is part of the coreboot project.
+--
+-- Copyright (C) 2015 secunet Security Networks AG
+--
+-- This program is free software; you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation; version 2 of the License.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+
+package HW.Debug_Sink is
+
+ procedure Put (Item : String);
+
+ procedure Put_Char (Item : Character);
+
+ procedure New_Line;
+
+end HW.Debug_Sink;
diff --git a/src/lib/Makefile.inc b/src/lib/Makefile.inc
index 36591adbb6cb..ddade2be1c35 100644
--- a/src/lib/Makefile.inc
+++ b/src/lib/Makefile.inc
@@ -269,3 +269,13 @@ $(objcbfs)/%.debug.rmod: $(objcbfs)/%.debug | $(RMODTOOL)
$(obj)/%.elf.rmod: $(obj)/%.elf | $(RMODTOOL)
$(RMODTOOL) -i $< -o $@
+
+ifeq ($(CONFIG_RAMSTAGE_LIBHWBASE),y)
+
+$(call add-special-class,hw)
+hw-handler = $(eval ramstage-srcs += $$(addprefix $(1),$(2)))
+subdirs-y += ../../3rdparty/libhwbase
+
+ramstage-$(CONFIG_HAVE_MONOTONIC_TIMER) += hw-time-timer.adb
+
+endif # CONFIG_RAMSTAGE_LIBHWBASE
diff --git a/src/lib/gnat/Makefile.inc b/src/lib/gnat/Makefile.inc
index 394c8388423d..9c68624947c1 100644
--- a/src/lib/gnat/Makefile.inc
+++ b/src/lib/gnat/Makefile.inc
@@ -62,5 +62,5 @@ $(foreach arch,$(standard-archs), \
$(eval $(call libgnat-template,$(arch))))
ifeq ($(CONFIG_RAMSTAGE_ADA),y)
-ramstage-libs += $$(obj)/libgnat-$(ARCH-ramstage-y)/libgnat.a
+ramstage-libs += $(obj)/libgnat-$(ARCH-ramstage-y)/libgnat.a
endif
diff --git a/src/lib/hw-time-timer.adb b/src/lib/hw-time-timer.adb
new file mode 100644
index 000000000000..643cc9861027
--- /dev/null
+++ b/src/lib/hw-time-timer.adb
@@ -0,0 +1,48 @@
+--
+-- This file is part of the coreboot project.
+--
+-- Copyright (C) 2016 secunet Security Networks AG
+--
+-- This program is free software; you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation; version 2 of the License.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+
+with Interfaces.C;
+
+package body HW.Time.Timer
+ with Refined_State => (Timer_State => null,
+ Abstract_Time => null)
+is
+
+ procedure Timer_Monotonic_Get (MT : out Interfaces.C.long);
+ pragma Import (C, Timer_Monotonic_Get, "timer_monotonic_get");
+
+ function Raw_Value_Min return T
+ with
+ SPARK_Mode => Off
+ is
+ Microseconds : Interfaces.C.long;
+ begin
+ Timer_Monotonic_Get (Microseconds);
+ return T (Microseconds);
+ end Raw_Value_Min;
+
+ function Raw_Value_Max return T
+ is
+ begin
+ return Raw_Value_Min + 1;
+ end Raw_Value_Max;
+
+ function Hz return T
+ is
+ begin
+ return 1_000_000;
+ end Hz;
+
+end HW.Time.Timer;