《一个操作系统的实现》笔记(3)--中断和I/O保护


中断和异常机制

有时候普通的程序流必须可以被要求快速反应的处理事件中断。电脑提供了一个称为中断的结构来处理这些事件。
外部中断由CPU的外部引起。
例如:当一个鼠标移动了,硬件鼠标中断现在的程序来处理鼠标移动(移动鼠标,等等)。中断导致控制权转移到一个中断处理程序。中断处理程序是处理中断的程序。每种类型的 中断都分配了一个中断号。在物理内存的开始处,存在一张包含中断处理 程序段地址的中断向量 表。中断号是这张表中最基本的指针。
内部中断由CPU的内部引起,要么是由一个错误引起,要么由中断指令引 起。错误中断称为陷阱。由中断指令引起的中断称为软中断。DOS使 用这些类型的中断来实现它的API。
许多中断处理程序当它执行完成时,将控制权返回给被中断的程序。它 们恢复寄存器,里面的值与中断发生之前的值相同。因此,被中断的程序 就像没有任何事情发生一样运行(除了它失去了一些CPU周期)。

在实模式下能用的BIOS中断在保护模式下已经不能用了,实模式下的中断向量表被保护模式下的IDT所代替。
IDT的作用是将每一个中断向量和一个描述符对应起来。
联系调用门我们知道,其实中断门或者任务门的作用机理几乎是一样的,只不过使用调用门时使用call指令,而这里我们使用int指令。
中断过程调用:
中断过程调用

中断门和陷阱门的结构:
中断门和陷阱门的结构

外部中断需要建立硬件中断与向量号之间的对应关系,由CPU的引脚INTR来接收:
8259A

8259A是可编程中断控制器,通过向相应的端口写入特定的ICW(Initialization Command Word)来实现的,在写入ICW2时涉及与中断向量号的对应,这里IRQ8~IRQ15被设置成对应中断向量28h~2Fh,这个范围处于用户定义的中断向量。

Init8259A:
    mov al, 011h
    out 020h, al    ; 主8259, ICW1.
    call    io_delay

    out 0A0h, al    ; 从8259, ICW1.
    call    io_delay

    mov al, 028h    ; IRQ8 对应中断向量 0x28
    out 0A1h, al    ; 从8259, ICW2.
    call    io_delay
    ;...

中断或异常发生时的堆栈
中断或异常发生时的堆栈


保护模式下的I/O

保护模式下对I/O做了限制,用户进程如果不被许可是无法进行I/O操作的。主要通过IOPL和I/O位图来实现。

IOPL

IOPL位于寄存器eflags的第12、13位。
I/O敏感指令如in、out等只有在CPL<=IOPL时才能执行。

I/O许可位图

I/O许可位图位于TSS偏移102字节处,每一位表示一个字节的端口地址是否可用。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值