前面我们讲了linux操作系统在保护模式下的一些情况,在保护模式下段寄存器存放的不再是段地址,而是段选择符,用来索引段描述符。接下来我们来说一说一个逻辑地址如何使如何转换成线性地址的。
为此我画了一张图,如下:
首先,逻辑地址是由段地址和偏移量组成,当系统想要访问某一个段时,会将相应的段选择符装入段寄存器。首先会检测TI的值,即我的段描述符在全局描述符表中,还是在局部描述符表中。知道了描述符表的位置,接下来就要在表中找描述符了,怎么找呢?首先每个段描述符表占8个字节,因此我们的段选择符需要x8,然后加上段描述符表的首地址,就可以得到段描述符的地址,进而得到段首地址,最后加上偏移地址,就得到了线性地址。
另外要提一句,为了减少对内存的访问,x86处理器提供了一种非编程的寄存器,供段寄存器使用,当段寄存器中放入段选择符时,会将该选择符索引的段描述符放入该寄存器,这样如果待会访问的是同一个段,那么就不会去访问内存了,加速了对段的访问。只有当段寄存器中的值更新时,非编程寄存器中的值才会被改变。
linux中的分段机制
终于要开始讲分段机制了,前边为什么