<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sat, Jun 25, 2022 at 5:35 PM ebashinskii <<a href="mailto:ebashinskii@proton.me">ebashinskii@proton.me</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="font-family:Arial;font-size:14px">CPU: Intel x86 KabyLake. I'm using 5.17 Kernel built from upstream and GRUB 2.04</div><div style="font-family:Arial;font-size:14px"><br></div><div style="font-family:Arial;font-size:14px">When debugging the kernel initialization process I found out that there is a function <b>void main(void)</b> in the source file <b>arch/x86/boot/main.c</b> (source link: <span><a rel="noreferrer nofollow noopener" href="https://elixir.bootlin.com/linux/v5.17/source/arch/x86/boot/main.c#L134" target="_blank">https://elixir.bootlin.com/linux/v5.17/source/arch/x86/boot/main.c#L134</a>)</span> which seems to be the entry point which the boot loader is supposed to jump into.</div><div style="font-family:Arial;font-size:14px"><br></div><div style="font-family:Arial;font-size:14px">But <b>objdump</b>-ing the Kernel image shows that there is no such symbol as <b>main</b>. GDB attached to QEMU does not know about this symbol either.</div><div style="font-family:Arial;font-size:14px"><br></div><div style="font-family:Arial;font-size:14px">The earliest stage of Kernel Initialization I could manage to catch with GDB is <b>x86_64_start_kernel</b> (source link: <span><a rel="noreferrer nofollow noopener" href="https://elixir.bootlin.com/linux/v5.17/source/arch/x86/kernel/head64.c#L467" target="_blank">https://elixir.bootlin.com/linux/v5.17/source/arch/x86/kernel/head64.c#L467</a>)</span></div><div style="font-family:Arial;font-size:14px"><span><br></span></div></blockquote><div><br></div><div><br></div><div>What are you trying to do that start-kernel is insufficiently early ?</div><div><br></div><div>main.c 's that you dont hit dont really matter do they ?</div><div><br></div><div>fwiw, I really like virtme</div><div><br></div><div>    virtme-run $KRUN_SHOW $KRUN_STDS $KDBG_OPTS $* $QM_OPTS --smp 3 -s -S<br><br></div><div>the -s -S stops me early enough to anything Ive needed to so far.<br></div><div> </div></div></div>