bf143f
From 411f5354b809f6b783946e58d7655135814fb809 Mon Sep 17 00:00:00 2001
bf143f
From: Janosch Frank <frankja@linux.ibm.com>
bf143f
Date: Thu, 11 Aug 2022 12:10:58 +0000
bf143f
Subject: [PATCH 26/42] dump: Rework filter area variables
bf143f
MIME-Version: 1.0
bf143f
Content-Type: text/plain; charset=UTF-8
bf143f
Content-Transfer-Encoding: 8bit
bf143f
bf143f
RH-Author: Cédric Le Goater <clg@redhat.com>
bf143f
RH-MergeRequest: 226: s390: Enhanced Interpretation for PCI Functions and Secure Execution guest dump
bf143f
RH-Bugzilla: 1664378 2043909
bf143f
RH-Acked-by: Thomas Huth <thuth@redhat.com>
bf143f
RH-Acked-by: Cornelia Huck <cohuck@redhat.com>
bf143f
RH-Acked-by: Jon Maloy <jmaloy@redhat.com>
bf143f
RH-Commit: [26/41] f10a5523dfd2724f7a8637fca3ed68ba6df659a5
bf143f
bf143f
While the DumpState begin and length variables directly mirror the API
bf143f
variable names they are not very descriptive. So let's add a
bf143f
"filter_area_" prefix and make has_filter a function checking length > 0.
bf143f
bf143f
Signed-off-by: Janosch Frank <frankja@linux.ibm.com>
bf143f
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
bf143f
Message-Id: <20220811121111.9878-6-frankja@linux.ibm.com>
bf143f
(cherry picked from commit dddf725f70bfe7f5adb41fa31dbd06e767271bda)
bf143f
Signed-off-by: Cédric Le Goater <clg@redhat.com>
bf143f
---
bf143f
 dump/dump.c           | 53 +++++++++++++++++++++++++------------------
bf143f
 include/sysemu/dump.h | 13 ++++++++---
bf143f
 2 files changed, 41 insertions(+), 25 deletions(-)
bf143f
bf143f
diff --git a/dump/dump.c b/dump/dump.c
bf143f
index e6aa037f59..f6fe13e258 100644
bf143f
--- a/dump/dump.c
bf143f
+++ b/dump/dump.c
bf143f
@@ -60,6 +60,11 @@ static inline bool dump_is_64bit(DumpState *s)
bf143f
     return s->dump_info.d_class == ELFCLASS64;
bf143f
 }
bf143f
 
bf143f
+static inline bool dump_has_filter(DumpState *s)
bf143f
+{
bf143f
+    return s->filter_area_length > 0;
bf143f
+}
bf143f
+
bf143f
 uint16_t cpu_to_dump16(DumpState *s, uint16_t val)
bf143f
 {
bf143f
     if (s->dump_info.d_endian == ELFDATA2LSB) {
bf143f
@@ -444,29 +449,30 @@ static void get_offset_range(hwaddr phys_addr,
bf143f
     *p_offset = -1;
bf143f
     *p_filesz = 0;
bf143f
 
bf143f
-    if (s->has_filter) {
bf143f
-        if (phys_addr < s->begin || phys_addr >= s->begin + s->length) {
bf143f
+    if (dump_has_filter(s)) {
bf143f
+        if (phys_addr < s->filter_area_begin ||
bf143f
+            phys_addr >= s->filter_area_begin + s->filter_area_length) {
bf143f
             return;
bf143f
         }
bf143f
     }
bf143f
 
bf143f
     QTAILQ_FOREACH(block, &s->guest_phys_blocks.head, next) {
bf143f
-        if (s->has_filter) {
bf143f
-            if (block->target_start >= s->begin + s->length ||
bf143f
-                block->target_end <= s->begin) {
bf143f
+        if (dump_has_filter(s)) {
bf143f
+            if (block->target_start >= s->filter_area_begin + s->filter_area_length ||
bf143f
+                block->target_end <= s->filter_area_begin) {
bf143f
                 /* This block is out of the range */
bf143f
                 continue;
bf143f
             }
bf143f
 
bf143f
-            if (s->begin <= block->target_start) {
bf143f
+            if (s->filter_area_begin <= block->target_start) {
bf143f
                 start = block->target_start;
bf143f
             } else {
bf143f
-                start = s->begin;
bf143f
+                start = s->filter_area_begin;
bf143f
             }
bf143f
 
bf143f
             size_in_block = block->target_end - start;
bf143f
-            if (s->begin + s->length < block->target_end) {
bf143f
-                size_in_block -= block->target_end - (s->begin + s->length);
bf143f
+            if (s->filter_area_begin + s->filter_area_length < block->target_end) {
bf143f
+                size_in_block -= block->target_end - (s->filter_area_begin + s->filter_area_length);
bf143f
             }
bf143f
         } else {
bf143f
             start = block->target_start;
bf143f
@@ -639,12 +645,12 @@ static void dump_iterate(DumpState *s, Error **errp)
bf143f
     int64_t memblock_size, memblock_start;
bf143f
 
bf143f
     QTAILQ_FOREACH(block, &s->guest_phys_blocks.head, next) {
bf143f
-        memblock_start = dump_filtered_memblock_start(block, s->begin, s->length);
bf143f
+        memblock_start = dump_filtered_memblock_start(block, s->filter_area_begin, s->filter_area_length);
bf143f
         if (memblock_start == -1) {
bf143f
             continue;
bf143f
         }
bf143f
 
bf143f
-        memblock_size = dump_filtered_memblock_size(block, s->begin, s->length);
bf143f
+        memblock_size = dump_filtered_memblock_size(block, s->filter_area_begin, s->filter_area_length);
bf143f
 
bf143f
         /* Write the memory to file */
bf143f
         write_memory(s, block, memblock_start, memblock_size, errp);
bf143f
@@ -1513,14 +1519,14 @@ static int validate_start_block(DumpState *s)
bf143f
 {
bf143f
     GuestPhysBlock *block;
bf143f
 
bf143f
-    if (!s->has_filter) {
bf143f
+    if (!dump_has_filter(s)) {
bf143f
         return 0;
bf143f
     }
bf143f
 
bf143f
     QTAILQ_FOREACH(block, &s->guest_phys_blocks.head, next) {
bf143f
         /* This block is out of the range */
bf143f
-        if (block->target_start >= s->begin + s->length ||
bf143f
-            block->target_end <= s->begin) {
bf143f
+        if (block->target_start >= s->filter_area_begin + s->filter_area_length ||
bf143f
+            block->target_end <= s->filter_area_begin) {
bf143f
             continue;
bf143f
         }
bf143f
         return 0;
bf143f
@@ -1559,10 +1565,10 @@ static int64_t dump_calculate_size(DumpState *s)
bf143f
     int64_t size = 0, total = 0, left = 0, right = 0;
bf143f
 
bf143f
     QTAILQ_FOREACH(block, &s->guest_phys_blocks.head, next) {
bf143f
-        if (s->has_filter) {
bf143f
+        if (dump_has_filter(s)) {
bf143f
             /* calculate the overlapped region. */
bf143f
-            left = MAX(s->begin, block->target_start);
bf143f
-            right = MIN(s->begin + s->length, block->target_end);
bf143f
+            left = MAX(s->filter_area_begin, block->target_start);
bf143f
+            right = MIN(s->filter_area_begin + s->filter_area_length, block->target_end);
bf143f
             size = right - left;
bf143f
             size = size > 0 ? size : 0;
bf143f
         } else {
bf143f
@@ -1652,9 +1658,12 @@ static void dump_init(DumpState *s, int fd, bool has_format,
bf143f
     }
bf143f
 
bf143f
     s->fd = fd;
bf143f
-    s->has_filter = has_filter;
bf143f
-    s->begin = begin;
bf143f
-    s->length = length;
bf143f
+    if (has_filter && !length) {
bf143f
+        error_setg(errp, QERR_INVALID_PARAMETER, "length");
bf143f
+        goto cleanup;
bf143f
+    }
bf143f
+    s->filter_area_begin = begin;
bf143f
+    s->filter_area_length = length;
bf143f
 
bf143f
     memory_mapping_list_init(&s->list);
bf143f
 
bf143f
@@ -1787,8 +1796,8 @@ static void dump_init(DumpState *s, int fd, bool has_format,
bf143f
         return;
bf143f
     }
bf143f
 
bf143f
-    if (s->has_filter) {
bf143f
-        memory_mapping_filter(&s->list, s->begin, s->length);
bf143f
+    if (dump_has_filter(s)) {
bf143f
+        memory_mapping_filter(&s->list, s->filter_area_begin, s->filter_area_length);
bf143f
     }
bf143f
 
bf143f
     /*
bf143f
diff --git a/include/sysemu/dump.h b/include/sysemu/dump.h
bf143f
index 7fce1d4af6..b62513d87d 100644
bf143f
--- a/include/sysemu/dump.h
bf143f
+++ b/include/sysemu/dump.h
bf143f
@@ -166,9 +166,16 @@ typedef struct DumpState {
bf143f
     hwaddr memory_offset;
bf143f
     int fd;
bf143f
 
bf143f
-    bool has_filter;
bf143f
-    int64_t begin;
bf143f
-    int64_t length;
bf143f
+    /*
bf143f
+     * Dump filter area variables
bf143f
+     *
bf143f
+     * A filtered dump only contains the guest memory designated by
bf143f
+     * the start address and length variables defined below.
bf143f
+     *
bf143f
+     * If length is 0, no filtering is applied.
bf143f
+     */
bf143f
+    int64_t filter_area_begin;  /* Start address of partial guest memory area */
bf143f
+    int64_t filter_area_length; /* Length of partial guest memory area */
bf143f
 
bf143f
     uint8_t *note_buf;          /* buffer for notes */
bf143f
     size_t note_buf_offset;     /* the writing place in note_buf */
bf143f
-- 
bf143f
2.37.3
bf143f