mirror of
https://github.com/KarolS/millfork.git
synced 2025-01-21 01:32:00 +00:00
More details on 8086 support
This commit is contained in:
parent
f46466365b
commit
6e4e5863c6
@ -79,6 +79,13 @@ as 8080's `DAD` changes only the carry flag, and 8086's `ADD` changes many flags
|
|||||||
Luckily, this is not an issue with Millfork code, as the optimizer does not assume anything about flags after that instruction.
|
Luckily, this is not an issue with Millfork code, as the optimizer does not assume anything about flags after that instruction.
|
||||||
The proper sequence is `LAHF`/`ADD r1,r2`/`RCR SI,1`/`SAHF`/`RCL SI,1`, but it is obviously too slow.
|
The proper sequence is `LAHF`/`ADD r1,r2`/`RCR SI,1`/`SAHF`/`RCL SI,1`, but it is obviously too slow.
|
||||||
|
|
||||||
|
* the converter translates the `INX` instruction (16-bit `INC` on Z80) to `INC`,
|
||||||
|
and similarly, the `DCX` instruction (16-bit `DEC` on Z80) to `DEC` ,
|
||||||
|
which may change behaviour of assembly code,
|
||||||
|
as 8080's `INX` and `DCX` don't change any flags, and 8086's `INC` and `DEC` change many flags.
|
||||||
|
Luckily, this is not an issue with Millfork code, as the optimizer does not assume anything about flags after that instruction.
|
||||||
|
The proper sequence is `LAHF`/`INC r` (or `DEC r`)/`SAHF`, but it is obviously too slow.
|
||||||
|
|
||||||
#### Register mapping
|
#### Register mapping
|
||||||
|
|
||||||
The registers are translated as following:
|
The registers are translated as following:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user