Blame SOURCES/kvm-s390x-ipl-support-extended-kernel-command-line-size.patch

0727d3
From ddfee9d393af322938e4df466cd01b8f9570a1c9 Mon Sep 17 00:00:00 2001
0727d3
From: Thomas Huth <thuth@redhat.com>
0727d3
Date: Tue, 5 Apr 2022 10:20:59 +0200
0727d3
Subject: [PATCH 1/6] s390x/ipl: support extended kernel command line size
0727d3
0727d3
RH-Author: Thomas Huth <thuth@redhat.com>
0727d3
RH-MergeRequest: 144: s390x/ipl: support extended kernel command line size
0727d3
RH-Commit: [1/1] be227e50af5dbe7802605f873db29ac5358aa196
0727d3
RH-Bugzilla: 2043830
0727d3
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
0727d3
RH-Acked-by: Cornelia Huck <cohuck@redhat.com>
0727d3
RH-Acked-by: David Hildenbrand <david@redhat.com>
0727d3
0727d3
Bugzilla: http://bugzilla.redhat.com/2043830
0727d3
0727d3
commit b2173046a64beed76715f310f98538f159276af1
0727d3
Author: Marc Hartmayer <mhartmay@linux.ibm.com>
0727d3
Date:   Mon Nov 22 12:29:09 2021 +0100
0727d3
0727d3
    s390x/ipl: support extended kernel command line size
0727d3
0727d3
    In the past s390 used a fixed command line length of 896 bytes. This has changed
0727d3
    with the Linux commit 5ecb2da660ab ("s390: support command lines longer than 896
0727d3
    bytes"). There is now a parm area indicating the maximum command line size. This
0727d3
    parm area has always been initialized to zero, so with older kernels this field
0727d3
    would read zero and we must then assume that only 896 bytes are available.
0727d3
0727d3
    Signed-off-by: Marc Hartmayer <mhartmay@linux.ibm.com>
0727d3
    Reviewed-by: David Hildenbrand <david@redhat.com>
0727d3
    Reviewed-by: Christian Borntraeger <borntraeger@de.ibm.com>
0727d3
    Acked-by: Viktor Mihajlovski <mihajlov@de.ibm.com>
0727d3
    Message-Id: <20211122112909.18138-1-mhartmay@linux.ibm.com>
0727d3
    [thuth: Cosmetic fixes, and use PRIu64 instead of %lu]
0727d3
    Signed-off-by: Thomas Huth <thuth@redhat.com>
0727d3
0727d3
Signed-off-by: Thomas Huth <thuth@redhat.com>
0727d3
---
0727d3
 hw/s390x/ipl.c | 27 +++++++++++++++++++++++----
0727d3
 1 file changed, 23 insertions(+), 4 deletions(-)
0727d3
0727d3
diff --git a/hw/s390x/ipl.c b/hw/s390x/ipl.c
0727d3
index 7ddca0127f..eb7fc4c4ae 100644
0727d3
--- a/hw/s390x/ipl.c
0727d3
+++ b/hw/s390x/ipl.c
0727d3
@@ -37,8 +37,9 @@
0727d3
 
0727d3
 #define KERN_IMAGE_START                0x010000UL
0727d3
 #define LINUX_MAGIC_ADDR                0x010008UL
0727d3
+#define KERN_PARM_AREA_SIZE_ADDR        0x010430UL
0727d3
 #define KERN_PARM_AREA                  0x010480UL
0727d3
-#define KERN_PARM_AREA_SIZE             0x000380UL
0727d3
+#define LEGACY_KERN_PARM_AREA_SIZE      0x000380UL
0727d3
 #define INITRD_START                    0x800000UL
0727d3
 #define INITRD_PARM_START               0x010408UL
0727d3
 #define PARMFILE_START                  0x001000UL
0727d3
@@ -110,6 +111,21 @@ static uint64_t bios_translate_addr(void *opaque, uint64_t srcaddr)
0727d3
     return srcaddr + dstaddr;
0727d3
 }
0727d3
 
0727d3
+static uint64_t get_max_kernel_cmdline_size(void)
0727d3
+{
0727d3
+    uint64_t *size_ptr = rom_ptr(KERN_PARM_AREA_SIZE_ADDR, sizeof(*size_ptr));
0727d3
+
0727d3
+    if (size_ptr) {
0727d3
+        uint64_t size;
0727d3
+
0727d3
+        size = be64_to_cpu(*size_ptr);
0727d3
+        if (size) {
0727d3
+            return size;
0727d3
+        }
0727d3
+    }
0727d3
+    return LEGACY_KERN_PARM_AREA_SIZE;
0727d3
+}
0727d3
+
0727d3
 static void s390_ipl_realize(DeviceState *dev, Error **errp)
0727d3
 {
0727d3
     MachineState *ms = MACHINE(qdev_get_machine());
0727d3
@@ -197,10 +213,13 @@ static void s390_ipl_realize(DeviceState *dev, Error **errp)
0727d3
             ipl->start_addr = KERN_IMAGE_START;
0727d3
             /* Overwrite parameters in the kernel image, which are "rom" */
0727d3
             if (parm_area) {
0727d3
-                if (cmdline_size > KERN_PARM_AREA_SIZE) {
0727d3
+                uint64_t max_cmdline_size = get_max_kernel_cmdline_size();
0727d3
+
0727d3
+                if (cmdline_size > max_cmdline_size) {
0727d3
                     error_setg(errp,
0727d3
-                               "kernel command line exceeds maximum size: %zu > %lu",
0727d3
-                               cmdline_size, KERN_PARM_AREA_SIZE);
0727d3
+                               "kernel command line exceeds maximum size:"
0727d3
+                               " %zu > %" PRIu64,
0727d3
+                               cmdline_size, max_cmdline_size);
0727d3
                     return;
0727d3
                 }
0727d3
 
0727d3
-- 
0727d3
2.27.0
0727d3