1

rt,比如在xv6代码mmu.h中,segdesc就是这样设计的

struct segdesc {
  uint lim_15_0 : 16;  // Low bits of segment limit
  uint base_15_0 : 16; // Low bits of segment base address
  uint base_23_16 : 8; // Middle bits of segment base address
  uint type : 4;       // Segment type (see STS_ constants)
  uint s : 1;          // 0 = system, 1 = application
  uint dpl : 2;        // Descriptor Privilege Level
  uint p : 1;          // Present
  uint lim_19_16 : 4;  // High bits of segment limit
  uint avl : 1;        // Unused (available for software use)
  uint rsv1 : 1;       // Reserved
  uint db : 1;         // 0 = 16-bit segment, 1 = 32-bit segment
  uint g : 1;          // Granularity: limit scaled by 4K when set
  uint base_31_24 : 8; // High bits of segment base address
};

为什么base被定义为base_15_0、base_23_16、base_31_24,而不是'uint base'?

我想这部分是因为每个子字段都有特殊的含义,所以分开存放而不是整体存放方便访问。但我不确定猜测是否完整或正确

4

1 回答 1

1

因为它不是任意好读的内部数据结构,而是硬件使用的数据结构的准确描述

在此处输入图像描述

来源:英特尔® 64 和 IA-32 架构软件开发人员手册

另见:http ://wiki.osdev.org/Global_Descriptor_Table

于 2014-10-29T09:46:36.867 回答