• Aucun résultat trouvé

SYSTEM CONTROL AND INITIALIZATION

Dans le document LITERATURE In addition to the product line (Page 169-177)

Special flags, registers, and instructions provide contol of the critical processes and interaction in iAPX 286 operations. The flag register includes 3 bits that represent the current I/O privilege level (IOPL: 2 bits) and the nested task bit (NT). Four additional registers support the virtual addressing and memory protection features, one points to the current Task State Segment and the other three point to the memory-based descriptor tables: GDT, LDT, and IDT. These flags and registers are discussed in the next section. The machine status word, (which indicates processor configuration and status) and the instructions that load and store it are discussed in section 10.2.2.

Similar instructions pertaining to the other registers are the subject of sections 10.2 and 10.3. A detailed description of initialization states and processes, which appears in section 10.4, is supplemented by the extensive exam ply in Appendix A. Instructions that validate descriptors and pointers are covered in section 11.3.

10.1 SYSTEM FLAGS AND REGISTERS The IOPL flag (bits 12 and 13 of the flags word) controls access to I/O operations and interrupt control instructions. These two bits represent the maximum privilege level (highest numerical CPL) at which the task is permitted to perform I/O instructions. Alter-ation of the 10PL flags is restricted to programs at level 0 or to a task switch.

IRET uses the NT flag to select the proper return: if NT=O, the normal return within a task is performed. As discussed in Chapter 8, the nested task flag (bit 14 of flags) is set when a task initiates a task switch via a

when a task initiates a task switch via a CALL or INT instruction. The old and new task state segments are marked busy and the backlink field of the new TSS is set to the old TSS selector. An interrupt that does not cause a task switch will clear NT after the old NT the new flag word is ignored by these instruc-tions. Note that the CLI and STI instructions are valid only when CPL :::::; 10PL; otherwise exception 13 occurs.

10.1.1 Descriptor Table Registers

The three descriptor tables used for all memory accesses are based at addresses supplied by (stored in) three registers: the global descriptor table register (GDTR), the interrupt descriptor table register (IDTR), and the local descriptor table register (LDTR). Each register contains a 24-bit base field and a 16-bit limit field. The base field gives the real memory address of the begin-ning of the table; the limit field tells the maximum offset permitted in accessing table entries. See figures 10-1 thru 10-3.

The LDTR also contains a selector field that identifies the descriptor for that table. LDT descriptors must reside in the GDT.

The task register (TR) points to the task state segment for the currently active task. It is

SYSTEM CONTROL AND INITIALIZATION

MEMORY

CPU , ,

15 0

23

J

GDTLIMIT

- JI

I

· · ·

I

GDT BASE I

GDTR

--15 0

LDTR

I

SELECTOR LDT LDT,

r-'i5----ii'

I I I I

· · ·

I

231

I

I LDT LIMIT

.- I

I

I

I ..J

I LDT BASE

-.-} CURRENT LDT

I I LDTn

I PROGRAM INVISIBLE I L _______ J

· ·

·

,.., ,..,

Figure 10-1. Local and Global Descriptor Table Definition

IDTR

I

23

~

CPU

15 0

J

IDTLIMIT f

-IDTBASE i

0

,~

MEMORY

GATE FOR INTERRUPT #n

GATE FOR INTERRUPT #n-1

· ·

·

GATE FOR INTERRUPT # 1

GATE FOR INTERRUPT #0

,

,

INTERRUPT DESCRIPTOR TASLE (IDT)

Figure 10-2. Interrupt Descriptor Table Definition

10-2

SYSTEM CONTROL AND INITIALIZATION

Figure 10-3. Data Type for Global Descriptor Table and Interrupt Descriptor Table

similar to a segment register, with selector, base, and limit fields, of which only the selec-tor field is readable under normal circum-stances. Each such selector serves as a unique identifier for its task. The uses of the TR are described in Chapter 8.

The instructions controlling these special registers are described in the next section.

10.2 SYSTEM CONTROL INSTRUCTIONS The instructions that load the GDTR and between the indicated descriptor table regis-ter and the effective real memory address supplied (see figure 10-3). The format of the 3 words is: a 2-byte limit, a 3-byte real base address, followed by an unused byte. These instructions are normally used during system initialization.

The LLDT instruction loads the LDT regis-ters from a descriptor in the GDT. LLDT uses

a selector operand to that descriptor rather than referencing the descriptor directly.

LLDT is only executable at privilege level 0;

otherwise exception 13 occurs. LLDT is normally required only during system initial-ization because the processor automatically exchanges the LDTR contents as part of the task-switch operation.

Executing an LLDT instruction does not automatically update the TSS or the register·

cache;. To properly change the LDT of the currently running task so that the change holds across task switches, you must perform, in order, the following three steps:

1. Store the new LDT selector into the appropriate word of TSS.

2. Load the new LDT selector into LDTR.

3. Reload the DS and ES registers if they refer to LDT-based descriptors.

Note that the current code segment and stack segment descriptors should reside in the GDT or be copied to the same location in the new LDT.

SLDT (store LDT) can be executed at any privilege level. SLDT stores the local descrip-tor table selecdescrip-tor from the program visible portion of the LDTR register.

Task Register loading or storing is again similar to that of the LDT. The L TR instruc-tion, operating only at level 0, loads the L TR at initialization time with a selector for the initial TSS. LTR does NOT cause a task switch; it just changes the current TSS. Note that the busy bit of the old TSS descriptor is not changed while the busy bit of the new TSS selector must be zero and will be set by L TR.

The LDT and any segment registers referring to the old LDT should be reloaded. STR, which permits the storing of TR contents into memory, can be executed at any privilege

SYSTEM CONTROL AND INITIALIZATION

level. L TR is not usually needed after initial-ization because the TR is managed by the task-switch operation.

10.2.2 Machine Status Word

The Machine Status Word (MSW) indicates the iAPX 286 configuration and status. It is not part of a task's state. The MSW word is loaded by the LMSW instruction executed in real address mode or at privilege level 0 only, or is stbred by the SMSW instruction execut-ing at any privilege level. MSW is a 16-bit register, the lower four bits of which are used by the iAPX 286. These bits have the allows WAIT instructions to cause a processor extension not-present exception (number 7) if TS is also set.

2 EM .Emulate processor extension causes a processor extension not-present exception (number 7) on ESC instructions to allow a processor extension to be emulated.

3 TS Iask switched indicates the next instruction using a processor extension will cause exception 7, allowing software to test whether the current processor extension context belongs to the current reset under software control. Once the TS flag is set, the next instruction using a processor extension causes a processor extension not-present exception (#7). This feature allows software to test whether the current proces-sor extension state belongs to the current task as discussed in section 11.4. If the current processor extension state belongs to a differ-ent task, the software can save the state of any processor extension with the state of the task that uses it. Thus, the TS bit protects a task from processor extension errors that result from the actions of a previous task.

The CLTS instruction is used to reset the TS flag after the exception handler has set up the proper processor extension state. The CLTS instruction can be executed at privilege level exten-sion not-present exception (#7).

MP flag tells whether a processor extension is present. If MP = 1 and TS = 1, escape and wait instructions will cause exception 7.

The PE flag indicates that the iAPX 286 is in the protected virtual address mode. Once the PE flag is set, it can be cleared only by a reset, which then puts the system in real address mode emulating the 8086.

Table 10-2 shows the recommended usage of the MSW. Other encodings of these bits are not recommended.

SYSTEM CONTROL AND INITIALIZATION

Table 10-2. Recommended MSW Encodings for Processor Extension Control Instructions

TS MP EM Recommended Use Causing

Exception 0 0 0 Initial encoding after RESET. iAPX 286 operation is identical to iAPX None

86,88.

0 0 1 No processor extension is available. Software will emulate its ESC function. Wait instructions do not cause exception 7.

1 0 1 No processor extension is available. Software will emulate its ESC function. The current processor extension context may belong to another task.

0 1 0 A processor extension exists. WAIT

(if TS=1) 1 1 0 A processor extension exists. The current processor extension ESC or

context may belong to another task. The exception on WAIT allows WAIT software to test for an error pending from a previous processor (ifTS=1) extension operation.

10.2.3 Other Instructions

Instructions that verify or adjust access rights, segment limits, or privilege levels can be used to avoid exceptions or faults that are correct-able. Section 10.3 describes such instructions.

10.3 PRIVILEGED AND TRUSTED INSTRUCTIONS

Instructions that execute only at CPL=O are called "privileged." An attempt to execute the privileged instructions at any other privilege level causes a general protection exception (#13) with an error code of zero. The privi-leged instructions manipulate descriptor tables or system registers. Incorrect use of these instructions can produce unrecoverable condi tions. Some of these instructions (LGDT, LLDT, and LTR) are discussed in section 10.2.

Other privileged instructions are:

• LIDT -Load interrupt descriptor table register

• LMSW-Load machine status word

• CL TS-Clear task switch flag

• HALT-Halt processor execution

• POPF (POP flags) or IRET can change the IF value only if the user is operating at a trusted privilege level. POPF does not change 10PL except at Level O.

"Trusted" instructions are restricted to execution at a privilege level of CPL >- 10PL.

For each task, the operating system defines a privilege level below which these instructions cannot be used. Most of these instructions deal with input/output or interrupt manage-ment. The IOPL field in the flag word that holds the privilege level limit can be changed only when CPL=O. The trusted instructions are:

• Input/Output-Block I/O, Input, and Output: IN, INW, OUT, OUTW, INSB, INSW, OUTSB, OUTSW

• Interrupts-Enable Interrupts, Disable Interrupts: STI, CLI

• Other-Lock Prefix

SYSTEM CONTROL AND INITIALIZATION

10.4 INITIALIZATION

Whenever the iAPX 286 is initialized or reset, certain registers are set to predefined values.

All additional desired initialization must be performed by user software. (See Appendix A for an example of a 286 initialization routine.) RESET forces the iAPX 286 to terminate all execution and local bus activity;

no instruction or bus action will occur as long as RESET is active. Execution in real address mode begins after RESET becomes inactive and an internal processing interval (3-4 clocks) occurs. The initial state at reset is:

FLAGS = 0002 system initialization area and the interrupt table area. The system initialization area begins at FFFFFOH (through FFFFFFH) and the interrupt table area begins at OOOOOOH (through 0003FFH). The interrupt

ta~le area is not reserved.

At this point, segment registers are valid and protection bits are set to O. The iAPX 286 begins operation in real address mode, with PE=O. Maskable interrupts are disabled, and no processor extension is assumed or emulated (EM=MP=O). location. Use of (or upgrade to) the protected mode can be supported by a bootstrap loader at the high end of the address space. As

10-6

mentioned in Chapter 5, location FFFOH ordinarily contains a JMP instruction whose target is the actual beginning of a system initialization or restart program.

After RESET, CS points to the top 64K bytes rupts-after insuring that a valid inter-rupt handler exists for each possible initialization procedure requires additional steps to operate correctly:

1. Load programs and associated descriptor tables.

SYSTEM CONTROL AND INITIALIZATION

2. Load valid GDT and IDT descriptor tables, setting the GDTR and IDTR to their correct value.

3. Set the PE bit to enter protected mode.

4. Execute an intra-segment JMP to clear the processor queues.

5. Load or construct a valid task state segment for the initial task to be executed in protected mode.

6. Load the LDTR selector from the task's GDT or OOOOH (nUll) if an LDT is not needed.

7. Set the stack pointer (SS, SP) to a valid location in a valid stack segment.

8. Mark all items not in memory as not-present.

9. Set FLAGS and MSW bits to correct values for the desired system configuation.

10. Initialize external devices.

11. Ensure that a valid interrupt handler exists for each possible interrupt.

12. Enable interrupts.

13. Execute.

The example in Appendix A shows the steps necessary to load all the required tables and registers that permit execution of the first task of a protected mode system. The program in Appendix A assumes that Intel development tools have been used to construct a prototype GDT, IDT, LDT, TSS, and all the data segments necessary to start up that first task.

Typically, these items are stored on EPROM;

on most systems it is necessary to copy them all into RAM to get going. Otherwise, the iAPX 286 will attempt to write into the EPROM to set the accessed or busy bits.

The example in Appendix A also illustrates the ability to allocate unused entries in descriptor tables to grow the tables dynami-cally during execution. Using suitable naming conventions, the builder can allocate alias data segments that are larger than the prototype EPROM version. The code in the example will zero out the extra entries to permit later dynamic usage.

Dans le document LITERATURE In addition to the product line (Page 169-177)