diff mbox series

[v8,23/24] MPIPL: Prepare architected registers data tag

Message ID 20190616171024.22799-24-hegdevasant@linux.vnet.ibm.com
State Superseded
Headers show
Series MPIPL support | expand

Checks

Context Check Description
snowpatch_ozlabs/apply_patch success Successfully applied on branch master (dbf27b6c4af84addb36bd3be34f96580aba9c873)
snowpatch_ozlabs/snowpatch_job_snowpatch-skiboot fail Test snowpatch/job/snowpatch-skiboot on branch master
snowpatch_ozlabs/snowpatch_job_snowpatch-skiboot-dco success Signed-off-by present

Commit Message

Vasant Hegde June 16, 2019, 5:10 p.m. UTC
Post MPIPL kernel needs saved CPU register details to create vmcore/opalcore.
This patch prepares CPU register data tag and add tags list.

Signed-off-by: Vasant Hegde <hegdevasant@linux.vnet.ibm.com>
---
 core/opal-dump.c | 41 ++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 40 insertions(+), 1 deletion(-)
diff mbox series

Patch

diff --git a/core/opal-dump.c b/core/opal-dump.c
index 88b18f857..f034ea0c0 100644
--- a/core/opal-dump.c
+++ b/core/opal-dump.c
@@ -53,6 +53,7 @@  static struct mpipl_metadata    *mpipl_metadata;
 
 /* Dump metadata area */
 static struct mpipl_fadump *mpipl_opal_data;
+static struct mpipl_fadump *mpipl_cpu_data;
 
 /*
  * Number of tags passed by OPAL to kernel after MPIPL boot.
@@ -373,6 +374,42 @@  static uint64_t opal_mpipl_query_tag(uint32_t idx, uint64_t *tag)
 	return OPAL_SUCCESS;
 }
 
+static void post_mpipl_arch_regs_data(void)
+{
+	struct proc_dump_area *proc_dump = (void *)(PROC_DUMP_AREA_BASE);
+
+	if (proc_dump->dest_addr == 0) {
+		prlog(PR_DEBUG, "Invalid CPU registers destination address\n");
+		return;
+	}
+
+	if (proc_dump->act_size == 0) {
+		prlog(PR_DEBUG, "Invalid CPU registers destination size\n");
+		return;
+	}
+
+	mpipl_cpu_data = zalloc(sizeof(struct mpipl_fadump) +
+				sizeof(struct fadump_region));
+	if (!mpipl_cpu_data) {
+		prlog(PR_ERR, "Failed to allocate memory\n");
+		return;
+	}
+
+	/* Fill CPU register details */
+	mpipl_cpu_data->type    = MPIPL_FADUMP_TYPE_CPU;
+	mpipl_cpu_data->version = MPIPL_FADUMP_VERSION;
+	mpipl_cpu_data->cpu_data_version = proc_dump->version;
+	mpipl_cpu_data->cpu_data_size = proc_dump->thread_size;
+	mpipl_cpu_data->fadump_region_cnt = cpu_to_be32(1);
+
+	mpipl_cpu_data->region[0].src  = proc_dump->dest_addr & ~(HRMOR_BIT);
+	mpipl_cpu_data->region[0].dest = proc_dump->dest_addr & ~(HRMOR_BIT);
+	mpipl_cpu_data->region[0].size = proc_dump->act_size;
+
+	/* Update tag */
+	mpipl_tags[max_tags++] = (u64)mpipl_cpu_data;
+}
+
 static void post_mpipl_get_opal_data(void)
 {
 	struct mdrt_table *mdrt = (void *)(MDRT_TABLE_BASE);
@@ -453,8 +490,10 @@  void opal_mpipl_init(void)
 	/* Get metadata area pointer */
 	mpipl_metadata = (void *)(DUMP_METADATA_AREA_BASE);
 
-	if (dt_find_property(dump_node, "mpipl-boot"))
+	if (dt_find_property(dump_node, "mpipl-boot")) {
 		post_mpipl_get_opal_data();
+		post_mpipl_arch_regs_data();
+	}
 
 	/* Clear OPAL metadata area */
 	if (sizeof(struct mpipl_metadata) > DUMP_METADATA_AREA_SIZE) {