[coreboot-gerrit] Patch set updated for coreboot: Hook up libhwbase in ramstage

Nico Huber (nico.h@gmx.de) gerrit at coreboot.org
Thu Oct 20 18:22:48 CEST 2016


Nico Huber (nico.h at gmx.de) just uploaded a new patch set to gerrit, which you can find at https://review.coreboot.org/16951

-gerrit

commit a8bef01d47e3f5e993fd8a84da5a8b1368953b32
Author: Nico Huber <nico.huber at secunet.com>
Date:   Wed Oct 5 17:46:49 2016 +0200

    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 at secunet.com>
---
 3rdparty/libhwbase            |  2 +-
 src/Kconfig                   |  9 +++++++
 src/console/Kconfig           |  9 +++++++
 src/console/Makefile.inc      |  4 +++
 src/console/hw-debug_sink.adb | 59 +++++++++++++++++++++++++++++++++++++++++++
 src/console/hw-debug_sink.ads | 24 ++++++++++++++++++
 src/lib/Makefile.inc          | 10 ++++++++
 src/lib/hw-time-timer.adb     | 48 +++++++++++++++++++++++++++++++++++
 8 files changed, 164 insertions(+), 1 deletion(-)

diff --git a/3rdparty/libhwbase b/3rdparty/libhwbase
index 5e9b1b5..aab715f 160000
--- a/3rdparty/libhwbase
+++ b/3rdparty/libhwbase
@@ -1 +1 @@
-Subproject commit 5e9b1b50e7ac90f68ca2ea798ef656ac863c2851
+Subproject commit aab715f166bf1b54cfbd6982e8df49248ea544d8
diff --git a/src/Kconfig b/src/Kconfig
index d6af6eb..1b915af 100644
--- a/src/Kconfig
+++ b/src/Kconfig
@@ -1248,3 +1248,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 8f74613..caf91ab 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 059dea5..aa0dbf5 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 0000000..5a16556
--- /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 0000000..322249e
--- /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 67f8364..d654f27 100644
--- a/src/lib/Makefile.inc
+++ b/src/lib/Makefile.inc
@@ -261,3 +261,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/hw-time-timer.adb b/src/lib/hw-time-timer.adb
new file mode 100644
index 0000000..643cc98
--- /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;



More information about the coreboot-gerrit mailing list