[SLOF] [PATCH v2 04/20] Add initial support for logging
Stefan Berger
stefanb at us.ibm.com
Wed Nov 18 04:02:20 AEDT 2015
From: Stefan Berger <stefanb at linux.vnet.ibm.com>
This patch adds initial support for the logging that will be done
following measurements done by further code added to SLOF.
Signed-off-by: Stefan Berger <stefanb at linux.vnet.ibm.com>
Reviewed-by: Nikunj A Dadhania <nikunj at linux.vnet.ibm.com>
---
board-qemu/slof/vtpm-sml.fs | 3 +++
lib/libtpm/tcgbios.c | 30 ++++++++++++++++++++++++++++++
lib/libtpm/tcgbios.h | 1 +
lib/libtpm/tpm.code | 11 +++++++++++
lib/libtpm/tpm.in | 1 +
5 files changed, 46 insertions(+)
diff --git a/board-qemu/slof/vtpm-sml.fs b/board-qemu/slof/vtpm-sml.fs
index 40f1b7e..5bfd629 100644
--- a/board-qemu/slof/vtpm-sml.fs
+++ b/board-qemu/slof/vtpm-sml.fs
@@ -25,6 +25,9 @@ LOG-SIZE alloc-mem to log-base
\ create /ibm,vtpm
s" ibm,vtpm" 2dup device-name device-type
+\ convey logbase and size to the C driver
+log-base LOG-SIZE tpm-set-log-parameters
+
: sml-get-allocated-size ( -- buffer-size)
vtpm-debug? IF
." Call to sml-get-allocated-size; size = " LOG-SIZE . cr
diff --git a/lib/libtpm/tcgbios.c b/lib/libtpm/tcgbios.c
index 0dae810..7e2ae1e 100644
--- a/lib/libtpm/tcgbios.c
+++ b/lib/libtpm/tcgbios.c
@@ -80,6 +80,9 @@ static struct tpm_state tpm_state = {
extern struct tpm_driver tpm_drivers[];
+static void *log_base;
+static uint32_t log_area_size;
+
/* prototypes */
static uint32_t build_and_send_cmd(uint32_t ordinal, const uint8_t *append,
uint32_t append_size, uint8_t *resbuffer,
@@ -90,6 +93,33 @@ static uint32_t build_and_send_cmd(uint32_t ordinal, const uint8_t *append,
Extensions for TCG-enabled BIOS
*******************************************************/
+void tpm_set_log_parameters(void *addr, unsigned int size)
+{
+ dprintf("Log is at 0x%llx; size is %u bytes\n",
+ (uint64_t)addr, size);
+ log_base = addr;
+ log_area_size = size;
+}
+
+static uint8_t *get_log_base_ptr(void)
+{
+ return log_base;
+}
+
+static uint32_t get_log_area_size(void)
+{
+ return log_area_size;
+}
+
+/* clear the OpenFirmware device tree log */
+static void reset_ofdt_log(void)
+{
+ uint8_t *log_area_start_address = get_log_base_ptr();
+
+ if (log_area_start_address)
+ memset(log_area_start_address, 0, get_log_area_size());
+}
+
static bool is_tpm_present(void)
{
bool rc = false;
diff --git a/lib/libtpm/tcgbios.h b/lib/libtpm/tcgbios.h
index 594a089..351f778 100644
--- a/lib/libtpm/tcgbios.h
+++ b/lib/libtpm/tcgbios.h
@@ -17,5 +17,6 @@
uint32_t tpm_start(void);
uint32_t tpm_unassert_physical_presence(void);
+void tpm_set_log_parameters(void *address, unsigned int size);
#endif /* TCGBIOS_H */
diff --git a/lib/libtpm/tpm.code b/lib/libtpm/tpm.code
index e42fd0b..4ce1739 100644
--- a/lib/libtpm/tpm.code
+++ b/lib/libtpm/tpm.code
@@ -35,3 +35,14 @@ PRIM(tpm_X2d_unassert_X2d_physical_X2d_presence)
PUSH;
TOS.n = tpm_unassert_physical_presence();
MIRP
+
+/*************************************************************/
+/* Convey log address and size */
+/* SLOF: tpm-set-log-parameters ( addr size -- ) */
+/* LIBTPM: tpm_set_log_parameters(void *addr, uint64_t size) */
+/*************************************************************/
+PRIM(tpm_X2d_set_X2d_log_X2d_parameters)
+ int size = TOS.u; POP;
+ void *addr = TOS.a; POP;
+ tpm_set_log_parameters(addr, size);
+MIRP
diff --git a/lib/libtpm/tpm.in b/lib/libtpm/tpm.in
index 4933af5..06a0874 100644
--- a/lib/libtpm/tpm.in
+++ b/lib/libtpm/tpm.in
@@ -15,3 +15,4 @@
cod(tpm-start)
cod(tpm-unassert-physical-presence)
+cod(tpm-set-log-parameters)
--
2.4.3
More information about the SLOF
mailing list