int)%idtr: point to the base address of IDTss0 & esp0iretdiv 1 0: user → kernel
idivl againb vector0x/6x $esp when entering kernelstruct trapframeman signalint z = 0; ticks = ticks / z; to idtinit()b vector0x/6x $espeip/cs/eflags; no ss/esp for kernel → kerneldiv.c: memset somethingb vector14x/6x $espkern/trap.cint 0x40 (64)usys.S (user) and syscall.c (kernel)gcc -nostdlib -m32strace#include <sys/syscall.h>
#include <unistd.h>
// syscall number: %eax
// syscall parameters %ebx, %ecx, %edx, %esi, %edi, %ebp
void _start(void)
{
int fd = 1;
char buf[] = "hello world!\n";
size_t count = sizeof(buf) - 1;
asm volatile ("int $0x80"
: /* ignore output */
: "a"(__NR_write), "b"(fd), "c"(buf), "d"(count)
: "cc", "edi", "esi", "memory"
);
asm volatile ("int $0x80"
: /* no output */
: "a"(__NR_exit), "b"(0)
);
}