* Is arch/x86/boot/main.c main obsolete?
@ 2022-06-25 23:35 ebashinskii
2022-06-26 2:05 ` Aruna Hewapathirane
2022-07-19 2:41 ` jim.cromie
0 siblings, 2 replies; 4+ messages in thread
From: ebashinskii @ 2022-06-25 23:35 UTC (permalink / raw)
To: kernelnewbies
[-- Attachment #1.1: Type: text/plain, Size: 868 bytes --]
CPU: Intel x86 KabyLake. I'm using 5.17 Kernel built from upstream and GRUB 2.04
When debugging the kernel initialization process I found out that there is a function void main(void) in the source file arch/x86/boot/main.c (source link: https://elixir.bootlin.com/linux/v5.17/source/arch/x86/boot/main.c#L134) which seems to be the entry point which the boot loader is supposed to jump into.
But objdump-ing the Kernel image shows that there is no such symbol as main. GDB attached to QEMU does not know about this symbol either.
The earliest stage of Kernel Initialization I could manage to catch with GDB is x86_64_start_kernel (source link: https://elixir.bootlin.com/linux/v5.17/source/arch/x86/kernel/head64.c#L467)
The question is what function GRUB actually jump into passing control to the Kernel code and what is the purpose of arch/x86/boot/main.c::main?
[-- Attachment #1.2: Type: text/html, Size: 1887 bytes --]
[-- Attachment #2: Type: text/plain, Size: 170 bytes --]
_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: Is arch/x86/boot/main.c main obsolete?
2022-06-25 23:35 Is arch/x86/boot/main.c main obsolete? ebashinskii
@ 2022-06-26 2:05 ` Aruna Hewapathirane
2022-06-26 13:38 ` ebashinskii
2022-07-19 2:41 ` jim.cromie
1 sibling, 1 reply; 4+ messages in thread
From: Aruna Hewapathirane @ 2022-06-26 2:05 UTC (permalink / raw)
To: ebashinskii; +Cc: kernelnewbies
[-- Attachment #1.1: Type: text/plain, Size: 1324 bytes --]
On Sat, Jun 25, 2022 at 7:35 PM ebashinskii <ebashinskii@proton.me> wrote:
> CPU: Intel x86 KabyLake. I'm using 5.17 Kernel built from upstream and
> GRUB 2.04
>
> When debugging the kernel initialization process I found out that there is
> a function *void main(void)* in the source file *arch/x86/boot/main.c* (source
> link:
> https://elixir.bootlin.com/linux/v5.17/source/arch/x86/boot/main.c#L134) which
> seems to be the entry point which the boot loader is supposed to jump into.
>
> But *objdump*-ing the Kernel image shows that there is no such symbol as
> *main*. GDB attached to QEMU does not know about this symbol either.
>
> The earliest stage of Kernel Initialization I could manage to catch with
> GDB is *x86_64_start_kernel* (source link:
> https://elixir.bootlin.com/linux/v5.17/source/arch/x86/kernel/head64.c#L467
> )
>
> The question is what function GRUB actually jump into passing control to
> the Kernel code and what is the purpose of *arch/x86/boot/main.c::main*?
>
This should answer most of the questions you may have about the kernel boot
process:
https://0xax.gitbooks.io/linux-insides/content/Booting/
:-)
> _______________________________________________
> Kernelnewbies mailing list
> Kernelnewbies@kernelnewbies.org
> https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
>
[-- Attachment #1.2: Type: text/html, Size: 2957 bytes --]
[-- Attachment #2: Type: text/plain, Size: 170 bytes --]
_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: Is arch/x86/boot/main.c main obsolete?
2022-06-26 2:05 ` Aruna Hewapathirane
@ 2022-06-26 13:38 ` ebashinskii
0 siblings, 0 replies; 4+ messages in thread
From: ebashinskii @ 2022-06-26 13:38 UTC (permalink / raw)
To: Aruna Hewapathirane; +Cc: kernelnewbies
[-- Attachment #1.1: Type: text/plain, Size: 363 bytes --]
I tried to set up a breakpoint inGDB and to lookup void main(void) and _start with objdumpon the kernel image without any success.
Actually it clearly says that the control Jump to the C code inarch/x86/boot/main.c. But as I mentioned before there's simply no such symbol as void main(void) in the Kernel image.
How can it jump to something that does not exist?
[-- Attachment #1.2: Type: text/html, Size: 1514 bytes --]
[-- Attachment #2: Type: text/plain, Size: 170 bytes --]
_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: Is arch/x86/boot/main.c main obsolete?
2022-06-25 23:35 Is arch/x86/boot/main.c main obsolete? ebashinskii
2022-06-26 2:05 ` Aruna Hewapathirane
@ 2022-07-19 2:41 ` jim.cromie
1 sibling, 0 replies; 4+ messages in thread
From: jim.cromie @ 2022-07-19 2:41 UTC (permalink / raw)
To: ebashinskii; +Cc: kernelnewbies
[-- Attachment #1.1: Type: text/plain, Size: 1143 bytes --]
On Sat, Jun 25, 2022 at 5:35 PM ebashinskii <ebashinskii@proton.me> wrote:
> CPU: Intel x86 KabyLake. I'm using 5.17 Kernel built from upstream and
> GRUB 2.04
>
> When debugging the kernel initialization process I found out that there is
> a function *void main(void)* in the source file *arch/x86/boot/main.c* (source
> link:
> https://elixir.bootlin.com/linux/v5.17/source/arch/x86/boot/main.c#L134) which
> seems to be the entry point which the boot loader is supposed to jump into.
>
> But *objdump*-ing the Kernel image shows that there is no such symbol as
> *main*. GDB attached to QEMU does not know about this symbol either.
>
> The earliest stage of Kernel Initialization I could manage to catch with
> GDB is *x86_64_start_kernel* (source link:
> https://elixir.bootlin.com/linux/v5.17/source/arch/x86/kernel/head64.c#L467
> )
>
>
What are you trying to do that start-kernel is insufficiently early ?
main.c 's that you dont hit dont really matter do they ?
fwiw, I really like virtme
virtme-run $KRUN_SHOW $KRUN_STDS $KDBG_OPTS $* $QM_OPTS --smp 3 -s -S
the -s -S stops me early enough to anything Ive needed to so far.
[-- Attachment #1.2: Type: text/html, Size: 2347 bytes --]
[-- Attachment #2: Type: text/plain, Size: 170 bytes --]
_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2022-07-19 2:42 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-06-25 23:35 Is arch/x86/boot/main.c main obsolete? ebashinskii
2022-06-26 2:05 ` Aruna Hewapathirane
2022-06-26 13:38 ` ebashinskii
2022-07-19 2:41 ` jim.cromie
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).