]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
x86: zboot: Move zimage definitions to the header file
authorSimon Glass <sjg@chromium.org>
Mon, 4 Dec 2023 00:29:26 +0000 (17:29 -0700)
committerTom Rini <trini@konsulko.com>
Wed, 10 Apr 2024 19:49:15 +0000 (13:49 -0600)
In preparation for splitting the zboot-command code into a separate
file, move the definitions into the header file.

While we are here, mention when load_address and base_ptr are set up
and explain bzimage_addr better. Make cmdline const since it cannot be
changed.

Signed-off-by: Simon Glass <sjg@chromium.org>
arch/x86/include/asm/zimage.h
arch/x86/lib/zimage.c

index 655675b66614bec04e26b75bca0215066d4694ba..a91cfb2b8dd05a3d010c1e3bbc44ade8b7a35aa6 100644 (file)
 #define BZIMAGE_LOAD_ADDR  0x100000
 #define ZIMAGE_LOAD_ADDR   0x10000
 
+enum {
+       ZBOOT_STATE_START       = BIT(0),
+       ZBOOT_STATE_LOAD        = BIT(1),
+       ZBOOT_STATE_SETUP       = BIT(2),
+       ZBOOT_STATE_INFO        = BIT(3),
+       ZBOOT_STATE_GO          = BIT(4),
+
+       /* This one doesn't execute automatically, so stop the count before 5 */
+       ZBOOT_STATE_DUMP        = BIT(5),
+       ZBOOT_STATE_COUNT       = 5,
+};
+
+/**
+ * struct zboot_state - Current state of the boot
+ *
+ * @bzimage_addr: Address of the bzImage to boot, or 0 if the image has already
+ *     been loaded and does not exist (as a cohesive whole) in memory
+ * @bzimage_size: Size of the bzImage, or 0 to detect this
+ * @initrd_addr: Address of the initial ramdisk, or 0 if none
+ * @initrd_size: Size of the initial ramdisk, or 0 if none
+ * @load_address: Address where the bzImage is moved before booting, either
+ *     BZIMAGE_LOAD_ADDR or ZIMAGE_LOAD_ADDR
+ *     This is set up when loading the zimage
+ * @base_ptr: Pointer to the boot parameters, typically at address
+ *     DEFAULT_SETUP_BASE
+ *     This is set up when loading the zimage
+ * @cmdline: Environment variable containing the 'override' command line, or
+ *     NULL to use the one in the setup block
+ */
+struct zboot_state {
+       ulong bzimage_addr;
+       ulong bzimage_size;
+       ulong initrd_addr;
+       ulong initrd_size;
+       ulong load_address;
+       struct boot_params *base_ptr;
+       const char *cmdline;
+};
+
+extern struct zboot_state state;
+
 /**
  * load_zimage() - Load a zImage or bzImage
  *
index a41e1ccf8a65ad47fdad6802941d0172a2d41390..b04d39b36dd4917fae6ff81cdecebf088b3461fc 100644 (file)
@@ -56,41 +56,7 @@ DECLARE_GLOBAL_DATA_PTR;
 
 #define COMMAND_LINE_SIZE      2048
 
-/**
- * struct zboot_state - Current state of the boot
- *
- * @bzimage_addr: Address of the bzImage to boot
- * @bzimage_size: Size of the bzImage, or 0 to detect this
- * @initrd_addr: Address of the initial ramdisk, or 0 if none
- * @initrd_size: Size of the initial ramdisk, or 0 if none
- * @load_address: Address where the bzImage is moved before booting, either
- *     BZIMAGE_LOAD_ADDR or ZIMAGE_LOAD_ADDR
- * @base_ptr: Pointer to the boot parameters, typically at address
- *     DEFAULT_SETUP_BASE
- * @cmdline: Environment variable containing the 'override' command line, or
- *     NULL to use the one in the setup block
- */
-struct zboot_state {
-       ulong bzimage_addr;
-       ulong bzimage_size;
-       ulong initrd_addr;
-       ulong initrd_size;
-       ulong load_address;
-       struct boot_params *base_ptr;
-       char *cmdline;
-} state;
-
-enum {
-       ZBOOT_STATE_START       = BIT(0),
-       ZBOOT_STATE_LOAD        = BIT(1),
-       ZBOOT_STATE_SETUP       = BIT(2),
-       ZBOOT_STATE_INFO        = BIT(3),
-       ZBOOT_STATE_GO          = BIT(4),
-
-       /* This one doesn't execute automatically, so stop the count before 5 */
-       ZBOOT_STATE_DUMP        = BIT(5),
-       ZBOOT_STATE_COUNT       = 5,
-};
+struct zboot_state state;
 
 static void build_command_line(char *command_line, int auto_boot)
 {