Commit 638b642f authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab Committed by Jonathan Corbet

docs: riscv: convert boot-image-header.txt to ReST

Convert this small file to ReST format by:
   - Using a proper markup for the document title;
   - marking a code block as such;
   - use tags for Author and date;
   - use tables for bit map fields.

While here, fix a broken reference for a document with is
planned but is not here yet.
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Reviewed-by: default avatarAtish Patra <atish.patra@wdc.com>
Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
parent 54bfe6fe
Boot image header in RISC-V Linux =================================
============================================= Boot image header in RISC-V Linux
=================================
Author: Atish Patra <atish.patra@wdc.com> :Author: Atish Patra <atish.patra@wdc.com>
Date : 20 May 2019 :Date: 20 May 2019
This document only describes the boot image header details for RISC-V Linux. This document only describes the boot image header details for RISC-V Linux.
The complete booting guide will be available at Documentation/riscv/booting.txt.
The following 64-byte header is present in decompressed Linux kernel image. TODO:
Write a complete booting guide.
The following 64-byte header is present in decompressed Linux kernel image::
u32 code0; /* Executable code */ u32 code0; /* Executable code */
u32 code1; /* Executable code */ u32 code1; /* Executable code */
u64 text_offset; /* Image load offset, little endian */ u64 text_offset; /* Image load offset, little endian */
u64 image_size; /* Effective Image size, little endian */ u64 image_size; /* Effective Image size, little endian */
u64 flags; /* kernel flags, little endian */ u64 flags; /* kernel flags, little endian */
u32 version; /* Version of this header */ u32 version; /* Version of this header */
u32 res1 = 0; /* Reserved */ u32 res1 = 0; /* Reserved */
u64 res2 = 0; /* Reserved */ u64 res2 = 0; /* Reserved */
u64 magic = 0x5643534952; /* Magic number, little endian, "RISCV" */ u64 magic = 0x5643534952; /* Magic number, little endian, "RISCV" */
u32 res3; /* Reserved for additional RISC-V specific header */ u32 res3; /* Reserved for additional RISC-V specific header */
u32 res4; /* Reserved for PE COFF offset */ u32 res4; /* Reserved for PE COFF offset */
...@@ -25,16 +28,21 @@ This header format is compliant with PE/COFF header and largely inspired from ...@@ -25,16 +28,21 @@ This header format is compliant with PE/COFF header and largely inspired from
ARM64 header. Thus, both ARM64 & RISC-V header can be combined into one common ARM64 header. Thus, both ARM64 & RISC-V header can be combined into one common
header in future. header in future.
Notes: Notes
=====
- This header can also be reused to support EFI stub for RISC-V in future. EFI - This header can also be reused to support EFI stub for RISC-V in future. EFI
specification needs PE/COFF image header in the beginning of the kernel image specification needs PE/COFF image header in the beginning of the kernel image
in order to load it as an EFI application. In order to support EFI stub, in order to load it as an EFI application. In order to support EFI stub,
code0 should be replaced with "MZ" magic string and res5(at offset 0x3c) should code0 should be replaced with "MZ" magic string and res5(at offset 0x3c) should
point to the rest of the PE/COFF header. point to the rest of the PE/COFF header.
- version field indicate header version number. - version field indicate header version number
Bits 0:15 - Minor version
Bits 16:31 - Major version ========== =============
Bits 0:15 Minor version
Bits 16:31 Major version
========== =============
This preserves compatibility across newer and older version of the header. This preserves compatibility across newer and older version of the header.
The current version is defined as 0.1. The current version is defined as 0.1.
...@@ -44,7 +52,10 @@ Notes: ...@@ -44,7 +52,10 @@ Notes:
extension for RISC-V in future. For current version, it is set to be zero. extension for RISC-V in future. For current version, it is set to be zero.
- In current header, the flag field has only one field. - In current header, the flag field has only one field.
Bit 0: Kernel endianness. 1 if BE, 0 if LE.
===== ====================================
Bit 0 Kernel endianness. 1 if BE, 0 if LE.
===== ====================================
- Image size is mandatory for boot loader to load kernel image. Booting will - Image size is mandatory for boot loader to load kernel image. Booting will
fail otherwise. fail otherwise.
...@@ -5,6 +5,7 @@ RISC-V architecture ...@@ -5,6 +5,7 @@ RISC-V architecture
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1
boot-image-header
pmu pmu
.. only:: subproject and html .. only:: subproject and html
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment