0xffffffff

esp

eip

GPR

0x00000000


struct intr_frame {
  /* Pushed by intr_entry in intr-stubs.S.
       These are the interrupted task's saved registers. */
  uint32_t edi;       /* Saved EDI. */
  uint32_t esi;       /* Saved ESI. */
  uint32_t ebp;       /* Saved EBP. */
  uint32_t esp_dummy; /* Not used. */
  uint32_t ebx;       /* Saved EBX. */
  uint32_t edx;       /* Saved EDX. */
  uint32_t ecx;       /* Saved ECX. */
  uint32_t eax;       /* Saved EAX. */
  uint16_t gs, : 16;  /* Saved GS segment register. */
  uint16_t fs, : 16;  /* Saved FS segment register. */
  uint16_t es, : 16;  /* Saved ES segment register. */
  uint16_t ds, : 16;  /* Saved DS segment register. */

  /* Pushed by intrNN_stub in intr-stubs.S. */
  uint32_t vec_no; /* Interrupt vector number. */

  /* Sometimes pushed by the CPU,
       otherwise for consistency pushed as 0 by intrNN_stub.
       The CPU puts it just under `eip', but we move it here. */
  uint32_t error_code; /* Error code. */

  /* Pushed by intrNN_stub in intr-stubs.S.
       This frame pointer eases interpretation of backtraces. */
  void* frame_pointer; /* Saved EBP (frame pointer). */

  /* Pushed by the CPU.
       These are the interrupted task's saved registers. */
  void (*eip)(void); /* Next instruction to execute. */
  uint16_t cs, : 16; /* Code segment for eip. */
  uint32_t eflags;   /* Saved CPU flags. */
  void* esp;         /* Saved stack pointer. */
  uint16_t ss, : 16; /* Data segment for esp. */
}