mirror of
https://github.com/hsoft/collapseos.git
synced 2025-01-12 21:18:05 +11:00
8086asm: clarify operands and fix stupidities
This commit is contained in:
parent
5033f17be2
commit
507c2c12e7
16
blk/730
16
blk/730
@ -2,15 +2,15 @@
|
|||||||
|
|
||||||
Work in progress. Load with "750 LOAD".
|
Work in progress. Load with "750 LOAD".
|
||||||
|
|
||||||
|
Mnemonics are followed by argument types. For example, MOVri,
|
||||||
|
moves 8-bit immediate to 8-bit register.
|
||||||
|
|
||||||
|
'r' = 8-bit register 'x' = 16-bit register
|
||||||
|
'i' = immediate, size depends on other operand.
|
||||||
|
's' = SREG register
|
||||||
|
|
||||||
|
Mnemonics that only have one signature (for example INT,) don't
|
||||||
|
have operands letters.
|
||||||
|
|
||||||
|
For jumps, it's special. 's' is SHORT, 'n' is NEAR, 'f' is FAR.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
4
blk/751
4
blk/751
@ -3,6 +3,6 @@ CREATE BIN( 0 , : BIN(+ BIN( @ + ;
|
|||||||
VARIABLE L1 VARIABLE L2 VARIABLE L3 VARIABLE L4
|
VARIABLE L1 VARIABLE L2 VARIABLE L3 VARIABLE L4
|
||||||
: AL 0 ; : CL 1 ; : DL 2 ; : BL 3 ;
|
: AL 0 ; : CL 1 ; : DL 2 ; : BL 3 ;
|
||||||
: AH 4 ; : CH 5 ; : DH 6 ; : BH 7 ;
|
: AH 4 ; : CH 5 ; : DH 6 ; : BH 7 ;
|
||||||
: AX 8 ; : CX 9 ; : DX 10 ; : BX 11 ;
|
: AX 0 ; : CX 1 ; : DX 2 ; : BX 3 ;
|
||||||
: SP 12 ; : BP 13 ; : SI 14 ; : DI 15 ;
|
: SP 4 ; : BP 5 ; : SI 6 ; : DI 7 ;
|
||||||
: ES 0 ; : CS 1 ; : SS 2 ; : DS 3 ;
|
: ES 0 ; : CS 1 ; : SS 2 ; : DS 3 ;
|
||||||
|
2
blk/752
2
blk/752
@ -4,5 +4,3 @@
|
|||||||
;
|
;
|
||||||
: PC H@ ORG @ - BIN( @ + ;
|
: PC H@ ORG @ - BIN( @ + ;
|
||||||
: A, C, ;
|
: A, C, ;
|
||||||
( dst8 src8 -- modrm )
|
|
||||||
: MODRMrr 0x7 AND 3 LSHIFT SWAP 0x7 AND OR 0xc0 OR ;
|
|
||||||
|
8
blk/753
8
blk/753
@ -4,9 +4,9 @@
|
|||||||
( no argument, jumps with abs addrs are special )
|
( no argument, jumps with abs addrs are special )
|
||||||
0xeb OP1 JMPs, 0xe9 OP1 JMPn, 0x74 OP1 JZ,
|
0xeb OP1 JMPs, 0xe9 OP1 JMPn, 0x74 OP1 JZ,
|
||||||
: MOVri, SWAP 0xb0 OR A, A, ;
|
: MOVri, SWAP 0xb0 OR A, A, ;
|
||||||
: MOVrI, SWAP 0xb0 OR A, SPLITB A, A, ;
|
: MOVxi, SWAP 0xb8 OR A, SPLITB A, A, ;
|
||||||
: MOVsx, 0x8e A, SWAP MODRMrr A, ;
|
: MOVsx, 0x8e A, SWAP 3 LSHIFT OR 0xc0 OR A, ;
|
||||||
: INT, 0xcd A, A, ;
|
: INT, 0xcd A, A, ;
|
||||||
: JMPr, 0xff A, 7 AND 0xe0 OR A, ;
|
: JMPr, 0xff A, 7 AND 0xe0 OR A, ;
|
||||||
: ORrr, 0x08 A, MODRMrr A, ;
|
: OPrr CREATE C, DOES> C@ A, 3 LSHIFT OR 0xc0 OR A, ;
|
||||||
: XORxx, 0x31 A, MODRMrr A, ;
|
0x31 OPrr XORxx, 0x08 OPrr ORrr,
|
||||||
|
6
blk/811
6
blk/811
@ -3,8 +3,8 @@ JMPs, L1 FWRs ( start )
|
|||||||
ORG @ 0x25 + HERE ! ( bypass BPB )
|
ORG @ 0x25 + HERE ! ( bypass BPB )
|
||||||
L1 FSET ( start )
|
L1 FSET ( start )
|
||||||
CLI, CLD, AX AX XORxx, DS AX MOVsx, ES AX MOVsx,
|
CLI, CLD, AX AX XORxx, DS AX MOVsx, ES AX MOVsx,
|
||||||
SS AX MOVsx, SP 0xffff MOVrI, STI,
|
SS AX MOVsx, SP 0xffff MOVxi, STI,
|
||||||
AH 2 MOVri, DX 0 MOVrI, CH 0 MOVri, CL 2 MOVri, AL 1 MOVri,
|
AH 2 MOVri, DX 0 MOVxi, CH 0 MOVri, CL 2 MOVri, AL 1 MOVri,
|
||||||
BX 0x8000 MOVrI, 0x13 INT, ( read 2nd sector of boot floppy )
|
BX 0x8000 MOVxi, 0x13 INT, ( read 2nd sector of boot floppy )
|
||||||
BX JMPr,
|
BX JMPr,
|
||||||
ORG @ 0x1fe + HERE ! 0x55 A, 0xaa A,
|
ORG @ 0x1fe + HERE ! 0x55 A, 0xaa A,
|
||||||
|
2
blk/812
2
blk/812
@ -2,7 +2,7 @@ H@ ORG ! 0x8000 BIN( !
|
|||||||
JMPs, L1 FWRs ( start )
|
JMPs, L1 FWRs ( start )
|
||||||
L2 ( msg ) BSET ," Hello World!" 0 A,
|
L2 ( msg ) BSET ," Hello World!" 0 A,
|
||||||
L1 FSET ( start )
|
L1 FSET ( start )
|
||||||
SI L2 @ ( msg ) MOVrI, AH 0x0e MOVri, ( print char )
|
SI L2 @ ( msg ) MOVxi, AH 0x0e MOVri, ( print char )
|
||||||
L1 BSET ( loop ) LODSB, AL AL ORrr, ( end of str? )
|
L1 BSET ( loop ) LODSB, AL AL ORrr, ( end of str? )
|
||||||
JZ, L2 FWRs ( next ) 0x10 INT, ( print char )
|
JZ, L2 FWRs ( next ) 0x10 INT, ( print char )
|
||||||
JMPs, L1 ( loop ) BWR
|
JMPs, L1 ( loop ) BWR
|
||||||
|
Loading…
Reference in New Issue
Block a user