summaryrefslogtreecommitdiffstats
path: root/src/usr/nvram/import
diff options
context:
space:
mode:
authorIlya Smirnov <ismirno@us.ibm.com>2018-11-08 12:56:45 -0600
committerDaniel M. Crowell <dcrowell@us.ibm.com>2019-01-04 14:18:46 -0600
commit36bd1dae218877ae8124a0ce8a9420c04e20c1d0 (patch)
treef08fd193013bb0da0b34233442af05a6bee3e0e9 /src/usr/nvram/import
parent24f66ecb7882be36eba5ef13cbc414acb642c2af (diff)
downloadblackbird-hostboot-36bd1dae218877ae8124a0ce8a9420c04e20c1d0.tar.gz
blackbird-hostboot-36bd1dae218877ae8124a0ce8a9420c04e20c1d0.zip
Unit Tests For NVRAM Checking/Reading
This change introduces the unit tests for testing the ported NVRAM checking and reading logic. nvram_format was also ported to be able to format the test NVRAM "partition" to then run the tests on it. Change-Id: Idca01dc84d43caf0e32ba556b6407c78d66f053a RTC: 192411 Reviewed-on: http://rchgit01.rchland.ibm.com/gerrit1/68612 Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com> Tested-by: Jenkins OP Build CI <op-jenkins+hostboot@us.ibm.com> Reviewed-by: Nicholas E. Bofferding <bofferdn@us.ibm.com> Tested-by: Jenkins OP HW <op-hw-jenkins+hostboot@us.ibm.com> Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com> Reviewed-by: Roland Veloz <rveloz@us.ibm.com> Reviewed-by: Daniel M. Crowell <dcrowell@us.ibm.com>
Diffstat (limited to 'src/usr/nvram/import')
-rw-r--r--src/usr/nvram/import/nvram-format.C79
1 files changed, 72 insertions, 7 deletions
diff --git a/src/usr/nvram/import/nvram-format.C b/src/usr/nvram/import/nvram-format.C
index d57f9ab51..072fb8f4d 100644
--- a/src/usr/nvram/import/nvram-format.C
+++ b/src/usr/nvram/import/nvram-format.C
@@ -25,13 +25,6 @@
#include <skiboot.h>
#include <nvram.h>
-struct chrp_nvram_hdr {
- uint8_t sig;
- uint8_t cksum;
- be16 len;
- char name[12];
-};
-
static struct chrp_nvram_hdr *skiboot_part_hdr;
static uint8_t chrp_nv_cksum(struct chrp_nvram_hdr *hdr)
@@ -54,10 +47,82 @@ static uint8_t chrp_nv_cksum(struct chrp_nvram_hdr *hdr)
#define NVRAM_SIG_FW_PRIV 0x51
#define NVRAM_SIG_SYSTEM 0x70
+#define NVRAM_SIG_FREE 0x7f
#define NVRAM_NAME_COMMON "common"
#define NVRAM_NAME_FW_PRIV "ibm,skiboot"
+#define NVRAM_NAME_FREE "wwwwwwwwwwww"
+#define NVRAM_SIZE_COMMON 0x10000
#define NVRAM_SIZE_FW_PRIV 0x1000
+int nvram_format(void *nvram_image, uint32_t nvram_size)
+{
+ struct chrp_nvram_hdr *h;
+ unsigned int offset = 0;
+
+ prerror("NVRAM: Re-initializing (size: 0x%08x)\n", nvram_size);
+ memset(nvram_image, 0, nvram_size);
+
+ /* Create private partition */
+ if (nvram_size - offset < NVRAM_SIZE_FW_PRIV)
+ return -1;
+ h =
+#ifdef __HOSTBOOT_MODULE
+ reinterpret_cast<chrp_nvram_hdr*>(
+ static_cast<uint8_t*>(nvram_image) + offset);
+#else
+ nvram_image + offset;
+#endif
+ h->sig = NVRAM_SIG_FW_PRIV;
+ h->len = cpu_to_be16(NVRAM_SIZE_FW_PRIV >> 4);
+ strcpy(h->name, NVRAM_NAME_FW_PRIV);
+ h->cksum = chrp_nv_cksum(h);
+ prlog(PR_DEBUG, "NVRAM: Created '%s' partition at 0x%08x"
+ " for size 0x%08x with cksum 0x%02x\n",
+ NVRAM_NAME_FW_PRIV, offset,
+ be16_to_cpu(h->len), h->cksum);
+ offset += NVRAM_SIZE_FW_PRIV;
+
+ /* Create common partition */
+ if (nvram_size - offset < NVRAM_SIZE_COMMON)
+ return -1;
+ h =
+#ifdef __HOSTBOOT_MODULE
+ reinterpret_cast<chrp_nvram_hdr*>(
+ static_cast<uint8_t*>(nvram_image) + offset);
+#else
+ nvram_image + offset;
+#endif
+ h->sig = NVRAM_SIG_SYSTEM;
+ h->len = cpu_to_be16(NVRAM_SIZE_COMMON >> 4);
+ strcpy(h->name, NVRAM_NAME_COMMON);
+ h->cksum = chrp_nv_cksum(h);
+ prlog(PR_DEBUG, "NVRAM: Created '%s' partition at 0x%08x"
+ " for size 0x%08x with cksum 0x%02x\n",
+ NVRAM_NAME_COMMON, offset,
+ be16_to_cpu(h->len), h->cksum);
+ offset += NVRAM_SIZE_COMMON;
+
+ /* Create free space partition */
+ if (nvram_size - offset < sizeof(struct chrp_nvram_hdr))
+ return -1;
+ h =
+#ifdef __HOSTBOOT_MODULE
+ reinterpret_cast<chrp_nvram_hdr*>(
+ static_cast<uint8_t*>(nvram_image) + offset);
+#else
+ nvram_image + offset;
+#endif
+ h->sig = NVRAM_SIG_FREE;
+ h->len = cpu_to_be16((nvram_size - offset) >> 4);
+ /* We have the full 12 bytes here */
+ memcpy(h->name, NVRAM_NAME_FREE, 12);
+ h->cksum = chrp_nv_cksum(h);
+ prlog(PR_DEBUG, "NVRAM: Created '%s' partition at 0x%08x"
+ " for size 0x%08x with cksum 0x%02x\n",
+ NVRAM_NAME_FREE, offset, be16_to_cpu(h->len), h->cksum);
+ return 0;
+}
+
static const char *find_next_key(const char *start, const char *end)
{
/*
OpenPOWER on IntegriCloud