mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-11 08:30:55 +00:00
Expand commentary.
This commit is contained in:
parent
03a2d4df80
commit
60cec9fc67
@ -211,7 +211,15 @@ template <
|
||||
case Operation::IMUL_1: Primitive::imul<IntT>(pair_high(), pair_low(), source_r(), context); return;
|
||||
case Operation::DIV: Primitive::div<IntT>(pair_high(), pair_low(), source_r(), context); return;
|
||||
case Operation::IDIV: Primitive::idiv<false, IntT>(pair_high(), pair_low(), source_r(), context); return;
|
||||
case Operation::IDIV_REP: Primitive::idiv<true, IntT>(pair_high(), pair_low(), source_r(), context); return;
|
||||
case Operation::IDIV_REP:
|
||||
if constexpr (ContextT::model == Model::i8086) {
|
||||
Primitive::idiv<true, IntT>(pair_high(), pair_low(), source_r(), context);
|
||||
break;
|
||||
} else {
|
||||
// TODO: perform LEAVE as of the 80186.
|
||||
static_assert(int(Operation::IDIV_REP) == int(Operation::LEAVE));
|
||||
}
|
||||
return;
|
||||
|
||||
case Operation::INC: Primitive::inc<IntT>(destination_rmw(), context); break;
|
||||
case Operation::DEC: Primitive::dec<IntT>(destination_rmw(), context); break;
|
||||
|
@ -240,11 +240,11 @@ enum class Operation: uint8_t {
|
||||
|
||||
/// Checks whether the signed value in the destination register is within the bounds
|
||||
/// stored at the location indicated by the source register, which will point to two
|
||||
/// 16- or 32-bit words, the first being a signed lower bound and the signed upper.
|
||||
/// 16- or 32-bit words, the first being a signed lower bound and the second
|
||||
/// a signed upper.
|
||||
/// Raises a bounds exception if not.
|
||||
BOUND = SETMOC,
|
||||
|
||||
|
||||
/// Create stack frame. See operand() for the nesting level and offset()
|
||||
/// for the dynamic storage size.
|
||||
ENTER,
|
||||
@ -272,42 +272,70 @@ enum class Operation: uint8_t {
|
||||
// 80286 additions.
|
||||
//
|
||||
|
||||
// TODO: expand detail on all operations below.
|
||||
|
||||
/// Adjusts requested privilege level.
|
||||
/// Read a segment selector from the destination and one from the source.
|
||||
/// If the destination RPL is less than the source, set ZF and set the destination RPL to the source.
|
||||
/// Otherwise clear ZF and don't modify the destination selector.
|
||||
ARPL,
|
||||
/// Clears the task-switched flag.
|
||||
/// Clears the task-switched flag in CR0.
|
||||
CLTS,
|
||||
/// Loads access rights.
|
||||
LAR,
|
||||
|
||||
/// Loads the global descriptor table.
|
||||
/// Loads the global descriptor table register from the source.
|
||||
/// 32-bit operand: read a 16-bit limit followed by a 32-bit base.
|
||||
/// 16-bit operand: read a 16-bit limit followed by a 24-bit base.
|
||||
LGDT,
|
||||
/// Loads the interrupt descriptor table.
|
||||
LIDT,
|
||||
/// Loads the local descriptor table.
|
||||
LLDT,
|
||||
/// Stores the global descriptor table.
|
||||
/// Stores the global descriptor table register at the destination;
|
||||
/// Always stores a 16-bit limit followed by a 32-bit base though
|
||||
/// the highest byte may be zero.
|
||||
SGDT,
|
||||
/// Stores the interrupt descriptor table.
|
||||
|
||||
/// Loads the interrupt descriptor table register from the source.
|
||||
/// 32-bit operand: read a 16-bit limit followed by a 32-bit base.
|
||||
/// 16-bit operand: read a 16-bit limit followed by a 24-bit base.
|
||||
LIDT,
|
||||
/// Stores the interrupt descriptor table register at the destination.
|
||||
/// Always stores a 16-bit limit followed by a 32-bit base though
|
||||
/// the highest byte may be zero.
|
||||
SIDT,
|
||||
/// Stores the local descriptor table.
|
||||
|
||||
/// Loads the local descriptor table register.
|
||||
/// The source will contain a segment selector pointing into the local descriptor table.
|
||||
/// That selector is loaded into the local descriptor table register, along with the corresponding
|
||||
/// segment limit and base from the global descriptor table.
|
||||
LLDT,
|
||||
/// Stores the local descriptor table register.
|
||||
SLDT,
|
||||
|
||||
/// Verifies a segment for reading.
|
||||
/// Verifies the segment indicated by source for reading, setting ZF.
|
||||
///
|
||||
/// ZF is set if: (i) the selector is not null; (ii) the selector is within GDT or LDT bounds;
|
||||
/// (iii) the selector points to code or data; (iv) the segment is readable;
|
||||
/// (v) the segment is either a conforming code segment, or the segment's DPL
|
||||
/// is greater than or equal to both the CPL and the selector's RPL.
|
||||
///
|
||||
/// Otherwise ZF is clear.
|
||||
VERR,
|
||||
/// Verifies a segment for writing.
|
||||
/// Verifies a segment for writing. Operates as per VERR but checks for writeability
|
||||
/// rather than readability.
|
||||
VERW,
|
||||
|
||||
/// Loads the machine status word.
|
||||
/// Loads a 16-bit value from source into the machine status word.
|
||||
/// The low order four bits of the source are copied into CR0, with the caveat
|
||||
/// that if PE is set, the processor will enter protected mode, but if PE is clear
|
||||
/// then there will be no change in protected mode.
|
||||
///
|
||||
/// Usurped in function by MOV CR0 as of the 80286.
|
||||
LMSW,
|
||||
/// Stores the machine status word.
|
||||
/// Stores the machine status word, i.e. copies the low 16 bits of CR0 into the destination.
|
||||
SMSW,
|
||||
/// Loads a segment limit
|
||||
|
||||
/// Load the segment limit from descriptor specified by source into destination,
|
||||
/// setting ZF if successful.
|
||||
LSL,
|
||||
/// Loads the task register.
|
||||
/// Load the source operand into the segment selector field of the task register.
|
||||
LTR,
|
||||
/// Stores the task register.
|
||||
/// Store the segment seleector of the task register into the destination.
|
||||
STR,
|
||||
|
||||
/// Three-operand form of IMUL; multiply the immediate by the source and write to the destination.
|
||||
@ -320,6 +348,8 @@ enum class Operation: uint8_t {
|
||||
// 80386 additions.
|
||||
//
|
||||
|
||||
// TODO: expand detail on all operations below.
|
||||
|
||||
/// Loads a pointer to FS.
|
||||
LFS,
|
||||
/// Loads a pointer to GS.
|
||||
|
Loading…
x
Reference in New Issue
Block a user