mirror of
https://github.com/apache/nuttx.git
synced 2026-05-27 19:36:35 +08:00
arch/x86_64: Reimplement the NuttX32 multiboot1 wrapper.
This commit reimplemented the NuttX32 multiboot1 wrapper: 1. Fixed the issue of SMP AP booting. 2. Reduced memory copy overhead. We only need to copy .realmode section now. 3. Move the multiboot1 header to intel64_head.S. Signed-off-by: ouyangxiangzhen <ouyangxiangzhen@xiaomi.com>
This commit is contained in:
committed by
Xiang Xiao
parent
45f4ce84ad
commit
edd7d718eb
@@ -136,7 +136,8 @@ endif
|
|||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_MULTIBOOT1),y)
|
ifeq ($(CONFIG_ARCH_MULTIBOOT1),y)
|
||||||
@echo "Generating: nuttx32 in ELF32/multiboot1"
|
@echo "Generating: nuttx32 in ELF32/multiboot1"
|
||||||
$(Q) $(OBJCOPY) -R .realmode -R.note.* -O binary $(NUTTX) $(NUTTX).bin \
|
$(Q) $(OBJCOPY) -R.realmode -R.note.* -O binary $(NUTTX) $(NUTTX).bin \
|
||||||
|
&& $(OBJCOPY) -j.realmode -O binary $(NUTTX) $(NUTTX)_realmode.bin \
|
||||||
&& $(CC) -m32 -no-pie -nostdlib common/multiboot1.S \
|
&& $(CC) -m32 -no-pie -nostdlib common/multiboot1.S \
|
||||||
-T common/multiboot1.ld -o $(NUTTX)32
|
-T common/multiboot1.ld -o $(NUTTX)32
|
||||||
endif
|
endif
|
||||||
|
|||||||
@@ -20,69 +20,37 @@
|
|||||||
|
|
||||||
/* Multiboot1 NuttX Naive Loader */
|
/* Multiboot1 NuttX Naive Loader */
|
||||||
|
|
||||||
.set ENTRY_ADDR, 0x100000 /* NuttX Entry Address */
|
|
||||||
|
|
||||||
.set MB_FLAG_ALIGNED, 1 /* All boot modules must be loaded aligned */
|
|
||||||
.set MB_FLAG_MEMINFO, 2 /* Boot with memory maps passing */
|
|
||||||
.set MB_FLAG_VIDEO, 4 /* Enable video mode */
|
|
||||||
|
|
||||||
.set MB_FLAGS, MB_FLAG_ALIGNED | MB_FLAG_MEMINFO
|
|
||||||
.set MB_MAGIC, 0x1BADB002
|
|
||||||
.set MB_CHECKSUM, -(MB_MAGIC + MB_FLAGS)
|
|
||||||
|
|
||||||
.balign 16
|
.balign 16
|
||||||
.code32
|
.code32
|
||||||
|
|
||||||
.globl _start
|
.globl _start
|
||||||
|
|
||||||
.section ".multiboot", "ax"
|
/* NuttX binary with multiboot1 header */
|
||||||
header:
|
|
||||||
.align 4
|
|
||||||
.long MB_MAGIC
|
|
||||||
.long MB_FLAGS
|
|
||||||
.long MB_CHECKSUM
|
|
||||||
|
|
||||||
.long 0 /* header_addr */
|
|
||||||
.long 0 /* load_addr */
|
|
||||||
.long 0 /* load_end_addr */
|
|
||||||
.long 0 /* bss_end_addr */
|
|
||||||
.long 0 /* entry_addr */
|
|
||||||
|
|
||||||
.long 0 /* Video mode type */
|
|
||||||
.long 1024 /* Video width */
|
|
||||||
.long 768 /* Video height */
|
|
||||||
.long 32 /* Video depth */
|
|
||||||
|
|
||||||
/* NuttX bin */
|
|
||||||
|
|
||||||
.section ".bin" , "ax"
|
.section ".bin" , "ax"
|
||||||
bin_start:
|
bin_start:
|
||||||
.incbin "../../../nuttx.bin"
|
.incbin "../../../nuttx.bin"
|
||||||
|
|
||||||
.align 8
|
|
||||||
bin_size:
|
|
||||||
.long . - bin_start
|
|
||||||
|
|
||||||
/* Multiboot args */
|
|
||||||
|
|
||||||
multiboot_info_struct:
|
multiboot_info_struct:
|
||||||
.long 0
|
.long 0
|
||||||
multiboot_magic:
|
multiboot_magic:
|
||||||
.long 0
|
.long 0
|
||||||
|
|
||||||
.section ".text"
|
.section ".text" , "ax"
|
||||||
_start:
|
_start:
|
||||||
|
|
||||||
|
/* We should manually copy .realmode section */
|
||||||
|
|
||||||
/* Saving multiboot args */
|
/* Saving multiboot args */
|
||||||
|
|
||||||
movl %ebx, multiboot_info_struct
|
movl %ebx, multiboot_info_struct
|
||||||
movl %eax, multiboot_magic
|
movl %eax, multiboot_magic
|
||||||
|
|
||||||
/* memcpy(ENTRY_ADDR, bin_start, bin_size) */
|
/* memcpy(0, realmode_start, realmode_size) */
|
||||||
|
|
||||||
movl (bin_size), %ecx
|
movl (realmode_size), %ecx
|
||||||
movl $bin_start, %esi
|
movl $realmode_start, %esi
|
||||||
movl $ENTRY_ADDR, %edi
|
movl $0, %edi
|
||||||
|
|
||||||
copy_loop:
|
copy_loop:
|
||||||
|
|
||||||
@@ -94,9 +62,23 @@ copy_loop:
|
|||||||
inc %edi
|
inc %edi
|
||||||
loop copy_loop
|
loop copy_loop
|
||||||
|
|
||||||
/* Jump to ENTRY_ADDR */
|
/* Jump to bin_start + 0x30, skip the multiboot1 header */
|
||||||
|
|
||||||
movl (multiboot_info_struct), %ebx
|
movl (multiboot_info_struct), %ebx
|
||||||
movl (multiboot_magic), %eax
|
movl (multiboot_magic), %eax
|
||||||
movl $ENTRY_ADDR, %ecx
|
movl $bin_start, %ecx
|
||||||
|
addl $0x30, %ecx
|
||||||
jmp *%ecx
|
jmp *%ecx
|
||||||
|
|
||||||
|
|
||||||
|
/* NuttX realmode section */
|
||||||
|
|
||||||
|
.section ".realmode", "ax"
|
||||||
|
realmode_start:
|
||||||
|
.incbin "../../../nuttx_realmode.bin"
|
||||||
|
|
||||||
|
.align 8
|
||||||
|
realmode_size:
|
||||||
|
.long . - realmode_start
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ SECTIONS {
|
|||||||
*(.multiboot)
|
*(.multiboot)
|
||||||
*(.bin)
|
*(.bin)
|
||||||
*(.text)
|
*(.text)
|
||||||
|
*(.realmode)
|
||||||
*(.note.gnu.*)
|
*(.note.gnu.*)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -149,7 +149,7 @@ __reset_entry:
|
|||||||
mov %eax, %cr0
|
mov %eax, %cr0
|
||||||
|
|
||||||
/* Long jump into protected mode. Hardcode the address. */
|
/* Long jump into protected mode. Hardcode the address. */
|
||||||
ljmpl $0x8, $0x100000
|
ljmpl $0x8, $start32_0
|
||||||
|
|
||||||
/* Loader GDT and GDTR */
|
/* Loader GDT and GDTR */
|
||||||
.align(16)
|
.align(16)
|
||||||
@@ -187,7 +187,7 @@ __ap_entry:
|
|||||||
mov %eax, %cr0
|
mov %eax, %cr0
|
||||||
|
|
||||||
/* Long jump into protected mode. Hardcode the address. */
|
/* Long jump into protected mode. Hardcode the address. */
|
||||||
ljmpl $0x8, $0x100000
|
ljmpl $0x8, $start32_0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@@ -195,6 +195,34 @@ __ap_entry:
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
.code32
|
.code32
|
||||||
|
.section ".multiboot1", "a"
|
||||||
|
#ifdef CONFIG_ARCH_MULTIBOOT1
|
||||||
|
.set MB_FLAG_ALIGNED, 1 /* All boot modules must be loaded aligned */
|
||||||
|
.set MB_FLAG_MEMINFO, 2 /* Boot with memory maps passing */
|
||||||
|
.set MB_FLAG_VIDEO, 4 /* Enable video mode */
|
||||||
|
|
||||||
|
.set MB_FLAGS, MB_FLAG_ALIGNED | MB_FLAG_MEMINFO
|
||||||
|
.set MB_MAGIC, 0x1BADB002
|
||||||
|
.set MB_CHECKSUM, -(MB_MAGIC + MB_FLAGS)
|
||||||
|
|
||||||
|
multiboot1_header:
|
||||||
|
.align 4
|
||||||
|
.long MB_MAGIC
|
||||||
|
.long MB_FLAGS
|
||||||
|
.long MB_CHECKSUM
|
||||||
|
|
||||||
|
.long 0 /* header_addr */
|
||||||
|
.long 0 /* load_addr */
|
||||||
|
.long 0 /* load_end_addr */
|
||||||
|
.long 0 /* bss_end_addr */
|
||||||
|
.long 0 /* entry_addr */
|
||||||
|
|
||||||
|
.long 0 /* Video mode type */
|
||||||
|
.long 1024 /* Video width */
|
||||||
|
.long 768 /* Video height */
|
||||||
|
.long 32 /* Video depth */
|
||||||
|
#endif
|
||||||
|
|
||||||
.section ".loader.text", "ax"
|
.section ".loader.text", "ax"
|
||||||
|
|
||||||
start32_0:
|
start32_0:
|
||||||
|
|||||||
@@ -34,6 +34,11 @@ SECTIONS
|
|||||||
. = 0x1M;
|
. = 0x1M;
|
||||||
_kernel_physical_start = .;
|
_kernel_physical_start = .;
|
||||||
|
|
||||||
|
.multiboot1 : {
|
||||||
|
. = ALIGN(8);
|
||||||
|
KEEP(*(.multiboot1))
|
||||||
|
}
|
||||||
|
|
||||||
.loader.text : {
|
.loader.text : {
|
||||||
. = ALIGN(8);
|
. = ALIGN(8);
|
||||||
*(.loader.text)
|
*(.loader.text)
|
||||||
|
|||||||
Reference in New Issue
Block a user