Freeze CPU at qemu startup while debug.

If we don't, the kernel might run into the infinite loop before GDB
connects to Qemu.
This commit is contained in:
garenchan 2018-11-16 15:49:01 +08:00
parent 02a77989c2
commit d7469c76b3
10 changed files with 10 additions and 10 deletions

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin & qemu-system-i386 -s -S -fda os-image.bin &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin & qemu-system-i386 -s -S -fda os-image.bin &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin & qemu-system-i386 -s -S -fda os-image.bin &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin & qemu-system-i386 -s -S -fda os-image.bin &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -29,7 +29,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -29,7 +29,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards

View File

@ -28,7 +28,7 @@ run: os-image.bin
# Open the connection to qemu and load our kernel-object file with symbols # Open the connection to qemu and load our kernel-object file with symbols
debug: os-image.bin kernel.elf debug: os-image.bin kernel.elf
qemu-system-i386 -s -fda os-image.bin -d guest_errors,int & qemu-system-i386 -s -S -fda os-image.bin -d guest_errors,int &
${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf" ${GDB} -ex "target remote localhost:1234" -ex "symbol-file kernel.elf"
# Generic rules for wildcards # Generic rules for wildcards