Diff for /np2/i286a/i286a_mn.s between versions 1.2 and 1.8

version 1.2, 2003/12/16 09:26:50 version 1.8, 2003/12/18 19:14:08
Line 1 Line 1
   
         INCLUDE         i286a.inc          INCLUDE         i286a.inc
           INCLUDE         i286aea.inc
         INCLUDE         i286aalu.inc          INCLUDE         i286aalu.inc
         INCLUDE         i286aop.inc          INCLUDE         i286aop.inc
           INCLUDE         i286apic.inc
   
         IMPORT          i286core          IMPORT          i286core
         IMPORT          _szpcflag8          IMPORT          _szpcflag8
           IMPORT          i286a_localint
         IMPORT          i286a_ea          IMPORT          i286a_ea
         IMPORT          i286a_lea          IMPORT          i286a_lea
           IMPORT          i286a_a
   
         IMPORT          i286_memoryread          IMPORT          i286_memoryread
         IMPORT          i286_memoryread_w          IMPORT          i286_memoryread_w
         IMPORT          i286_memorywrite          IMPORT          i286_memorywrite
         IMPORT          i286_memorywrite_w          IMPORT          i286_memorywrite_w
   
         IMPORT          iocore_inp8          IMPORT          iocore_inp8
         IMPORT          iocore_inp16          IMPORT          iocore_inp16
         IMPORT          iocore_out8          IMPORT          iocore_out8
         IMPORT          iocore_out16          IMPORT          iocore_out16
   
           IMPORT          biosfunc
   
           IMPORT          pic
           IMPORT          extirq_pop
   
           IMPORT          i286a_cts
   
           IMPORT          i286aop80
           IMPORT          i286aop81
           IMPORT          i286aop83
   
           IMPORT          i286asft8_1
           IMPORT          i286asft16_1
           IMPORT          i286asft8_cl
           IMPORT          i286asft8_d8
           IMPORT          i286asft16_cl
           IMPORT          i286asft16_d8
   
           IMPORT          i286aopf6
           IMPORT          i286aopf7
   
           IMPORT          i286aopfe
           IMPORT          i286aopff
   
         EXPORT          i286a_step          EXPORT          i286a_step
         EXPORT          optbl1          EXPORT          optbl1
   
Line 37  or_r16_ea  OP_R16_EA OR16, #2, #7 Line 67  or_r16_ea  OP_R16_EA OR16, #2, #7
 or_al_d8                OP_AL_D8        OR8, #3  or_al_d8                OP_AL_D8        OR8, #3
 or_ax_d16               OP_AX_D16       OR16, #3  or_ax_d16               OP_AX_D16       OR16, #3
 push_cs                 REGPUSH         #CPU_CS, #3  push_cs                 REGPUSH         #CPU_CS, #3
   ; ope0f
   
 adc_ea_r8               OP_EA_R8        ADC8, #2, #7  adc_ea_r8               OP_EA_R8        ADC8, #2, #7
 adc_ea_r16              OP_EA_R16       ADC16, #2, #7  adc_ea_r16              OP_EA_R16       ADC16, #2, #7
Line 129  pop_di   REGPOP  #CPU_DI, #5 Line 159  pop_di   REGPOP  #CPU_DI, #5
   
 ; pusha                 *  ; pusha                 *
 ; popa                  *  ; popa                  *
 ; bound  ; bound                 +
 ; arpl  ; arpl                  +
 ; push_d16              *  ; push_d16              *
 ; imul_r_ea_d16  ; imul_r_ea_d16 +
 ; push_d8               *  ; push_d8               *
 ; imul_r_ea_d8  ; imul_r_ea_d8  +
 ; insb                  *  ; insb                  *
 ; insw                  *  ; insw                  *
 ; outsb                 *  ; outsb                 *
Line 152  js_short  JMPNE  #S_FLAG, #2, #7 Line 182  js_short  JMPNE  #S_FLAG, #2, #7
 jns_short               JMPEQ           #S_FLAG, #2, #7  jns_short               JMPEQ           #S_FLAG, #2, #7
 jp_short                JMPNE           #P_FLAG, #2, #7  jp_short                JMPNE           #P_FLAG, #2, #7
 jnp_short               JMPEQ           #P_FLAG, #2, #7  jnp_short               JMPEQ           #P_FLAG, #2, #7
 ; jl_short  ; jl_short              +
 ; jnl_short  ; jnl_short             +
 ; jle_short  ; jle_short             +
 ; jnle_short  ; jnle_short    +
   
 ; calc_ea8_i8  ; calc_ea8_i8   +
 ; calc_ea16_i16  ; calc_ea16_i16 +
 ; calc_ea16_i8  ; calc_ea16_i8  +
 test_ea_r8              S_EA_R8         AND8, #2, #6  test_ea_r8              S_EA_R8         AND8, #2, #6
 test_ea_r16             S_EA_R16        AND16, #2, #6  test_ea_r16             S_EA_R16        AND16, #2, #6
 ; xchg_ea_r8    *  ; xchg_ea_r8    *
Line 168  test_ea_r16  S_EA_R16 AND16, #2, #6 Line 198  test_ea_r16  S_EA_R16 AND16, #2, #6
 ; mov_ea_r16    *  ; mov_ea_r16    *
 ; mov_r8_ea             *  ; mov_r8_ea             *
 ; mov_r16_ea    *  ; mov_r16_ea    *
 ; mov_ea_seg  ; mov_ea_seg    +
 ; lea_r16_ea  ; lea_r16_ea    +
 ; mov_seg_ea            !  ; mov_seg_ea            !
 ; pop_ea                *  ; pop_ea                *
   
Line 226  mov_di_imm  MOVIMM16 #CPU_DI, #2 Line 256  mov_di_imm  MOVIMM16 #CPU_DI, #2
   
 ; shift_ea8_d8  ; shift_ea8_d8
 ; shift_ea16_d8  ; shift_ea16_d8
 ; ret_near_d16  ; ret_near_d16  +
 ; ret_near  ; ret_near              +
 ; les_r16_ea  ; les_r16_ea    +
 ; lds_r16_ea  ; lds_r16_ea    +
 ; mov_ea8_d8  ; mov_ea8_d8    *
 ; mov_ea16_d16  ; mov_ea16_d16  *
 ; enter  ; enter
 ; leave  ; leave                 +
 ; ret_far_d16  ; ret_far_d16   +
 ; ret_far  ; ret_far               +
 ; int_03  ; int_03                +
 ; int_d8  ; int_d8                +
 ; into  ; into                  +
 ; iret                          !  ; iret                          !
   
 ; shift_ea8_1  ; shift_ea8_1
 ; shift_ea16_1  ; shift_ea16_1
 ; shift_ea8_cl  ; shift_ea8_cl
 ; shift_ea16_cl  ; shift_ea16_cl
 ; aam  ; aam                   +
 ; aad  ; aad                   *
 ; setalc                *  ; setalc                *
 ; xlat                  *  ; xlat                  *
 ; esc                   *  ; esc                   *
Line 271  jmp_short  JMPS #7 Line 301  jmp_short  JMPS #7
 ; lock                  *  ; lock                  *
 ; repne                         !  ; repne                         !
 ; repe                          !  ; repe                          !
 ; hlt                           !  ; hlt                   +
 ; cmc                   *  ; cmc                   *
 ; ope0xf6  ; ope0xf6
 ; ope0xf7  ; ope0xf7
 ; clc                   *  ; clc                   *
 ; stc                   *  ; stc                   *
 ; cli  ; cli                   *
 ; sti                           !  ; sti                           !
 ; cld                   *  ; cld                   *
 ; std                   *  ; std                   *
Line 287  jmp_short  JMPS #7 Line 317  jmp_short  JMPS #7
   
 ; ----  ; ----
   
 daa                             CPUWORK #3  reserved                mov             r6, #6
                                 ldrb    r0, [r9, #CPU_AL]                                  sub             r8, r8, #(1 << 16)
                                   b               i286a_localint
   
   daa                             ldrb    r0, [r9, #CPU_AL]
                                 bic             r8, r8, #O_FLAG                                  bic             r8, r8, #O_FLAG
                                   CPUWORK #3
                                 eor             r2, r0, #&80                                  eor             r2, r0, #&80
                                 tst             r8, #A_FLAG                                  tst             r8, #A_FLAG
                                 bne             daalo2                                  bne             daalo2
Line 334  daslo   tst  r8, #A_FLAG Line 368  daslo   tst  r8, #A_FLAG
 daslo2                  sub             r0, r0, #6  daslo2                  sub             r0, r0, #6
                                 orr             r8, r8, r0 lsr #31                                  orr             r8, r8, r0 lsr #31
                                 and             r0, r0, #&ff                                  and             r0, r0, #&ff
 dasflg                  strb    r0, [r9, #CPU_AL]  dasflg                  ldrb    r1, [r10, r0]
                                 ldrb    r1, [r10, r0]                                  strb    r0, [r9, #CPU_AL]
                                 bic             r8, r8, #(&ff - A_FLAG - C_FLAG)                                  bic             r8, r8, #(&ff - A_FLAG - C_FLAG)
                                 orr             r8, r1, r8                                  orr             r8, r1, r8
                                 mov             pc, r11                                  mov             pc, r11
Line 372  aas1   orr  r8, r8, #(A_FLAG + C_FLAG) Line 406  aas1   orr  r8, r8, #(A_FLAG + C_FLAG)
   
 pusha                   ldrh    r4, [r9, #CPU_SP]  pusha                   ldrh    r4, [r9, #CPU_SP]
                                 ldr             r5, [r9, #CPU_SS_BASE]                                  ldr             r5, [r9, #CPU_SS_BASE]
                                   CPUWORK #17
                                 mov             r6, r4                                  mov             r6, r4
                                 mov             r4, r4 lsl #16                                  mov             r4, r4 lsl #16
                                 ldrh    r1, [r9, #CPU_AX]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_AX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_CX]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_CX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_DX]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_DX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_BX]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_BX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 mov             r1, r6                                  mov             r1, r6
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_BP]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_BP]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_SI]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_SI]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 ldrh    r1, [r9, #CPU_DI]  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   ldrh    r1, [r9, #CPU_DI]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w
                                 mov             r0, r4 lsr #16                                  mov             r0, r4 lsr #16
Line 412  pusha   ldrh r4, [r9, #CPU_SP] Line 447  pusha   ldrh r4, [r9, #CPU_SP]
   
 popa                    ldrh    r4, [r9, #CPU_SP]  popa                    ldrh    r4, [r9, #CPU_SP]
                                 ldr             r5, [r9, #CPU_SS_BASE]                                  ldr             r5, [r9, #CPU_SS_BASE]
                                   CPUWORK #19
                                 add             r0, r5, r4                                  add             r0, r5, r4
                                 mov             r4, r4 lsl #16                                  mov             r4, r4 lsl #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_DI]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_DI]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_SI]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_SI]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_BP]  
                                 add             r4, r4, #(4 << 16)                                  add             r4, r4, #(4 << 16)
                                   strh    r0, [r9, #CPU_BP]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_BX]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_BX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_DX]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_DX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_CX]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_CX]
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 strh    r0, [r9, #CPU_AX]  
                                 add             r4, r4, #(2 << 16)                                  add             r4, r4, #(2 << 16)
                                   strh    r0, [r9, #CPU_AX]
                                 mov             r0, r4 lsr #16                                  mov             r0, r4 lsr #16
                                 strh    r0, [r9, #CPU_SP]                                  strh    r0, [r9, #CPU_SP]
                                 mov             pc, r11                                  mov             pc, r11
   
   bound                   GETPC8
                                   cmp             r0, #&c0
                                   bcs             bndreg
                                   CPUWORK #13
                                   R16DST  r0, r12
                                   ldrh    r5, [r12, #CPU_REG]
                                   bl              i286a_a
                                   add             r4, r0, #2
                                   add             r0, r0, r6
                                   bl              i286_memoryread_w
                                   cmp             r5, r0
                                   bcc             bndout
                                   bic             r4, r4, #(1 << 16)
                                   add             r0, r4, r6
                                   bl              i286_memoryread_w
                                   cmp             r5, r0
                                   movls   pc, r11
   bndout                  mov             r6, #5
                                   b               i286a_localint
   bndreg                  mov             r6, #6
                                   sub             r8, r8, #(2 << 16)
                                   b               i286a_localint
   
 push_d16                CPUWORK #3  push_d16                CPUWORK #3
                                 GETPC16                                  GETPC16
                                 ldrh    r2, [r9, #CPU_SP]                                  ldrh    r2, [r9, #CPU_SP]
                                 ldr             r3, [r9, #CPU_SS_BASE]                                  ldr             r3, [r9, #CPU_SS_BASE]
                                   mov             r1, r0
                                 subs    r2, r2, #2                                  subs    r2, r2, #2
                                 addcc   r2, r2, #&10000                                  addcc   r2, r2, #&10000
                                 mov             r1, r0  
                                 strh    r2, [r9, #CPU_SP]                                  strh    r2, [r9, #CPU_SP]
                                 add             r0, r2, r3                                  add             r0, r2, r3
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
   imul_r_ea_d16   REG16EA r5, #21, #24
                                   mov             r4, r0, lsl #16
                                   GETPC16
                                   mov             r0, r0, lsl #16
                                   mov             r4, r4, asr #16
                                   mov             r0, r0, asr #16
                                   mul             r1, r0, r4
                                   add             r12, r1, #&8000
                                   strh    r1, [r5, #CPU_REG]
                                   movs    r12, r12 lsr #16
                                   biceq   r8, r8, #O_FLAG
                                   biceq   r8, r8, #C_FLAG
                                   orrne   r8, r8, #O_FLAG
                                   orrne   r8, r8, #C_FLAG
                                   mov             pc, r11
   
 push_d8                 CPUWORK #3  push_d8                 CPUWORK #3
                                 GETPC8                                  GETPC8
                                 ldrh    r2, [r9, #CPU_SP]                                  ldrh    r2, [r9, #CPU_SP]
                                 ldr             r3, [r9, #CPU_SS_BASE]                                  ldr             r3, [r9, #CPU_SS_BASE]
                                   mov             r0, r0 lsl #24
                                 subs    r2, r2, #2                                  subs    r2, r2, #2
                                 addcc   r2, r2, #&10000                                  addcc   r2, r2, #&10000
                                 mov             r0, r0 lsl #24  
                                 mov             r1, r0 asr #24                                  mov             r1, r0 asr #24
                                 strh    r2, [r9, #CPU_SP]                                  strh    r2, [r9, #CPU_SP]
                                 add             r0, r2, r3                                  add             r0, r2, r3
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 insb                    ldrh    r0, [r9, #CPU_DX]  imul_r_ea_d8    REG16EA r5, #21, #24
                                   mov             r4, r0, lsl #16
                                   GETPC8
                                   mov             r0, r0, lsl #24
                                   mov             r4, r4, asr #16
                                   mov             r0, r0, asr #24
                                   mul             r1, r0, r4
                                   add             r12, r1, #&8000
                                   strh    r1, [r5, #CPU_REG]
                                   movs    r12, r12 lsr #16
                                   biceq   r8, r8, #O_FLAG
                                   biceq   r8, r8, #C_FLAG
                                   orrne   r8, r8, #O_FLAG
                                   orrne   r8, r8, #C_FLAG
                                   mov             pc, r11
   
   insb                    CPUWORK #5
                                   ldrh    r0, [r9, #CPU_DX]
                                   CPUSV
                                 bl              iocore_inp8                                  bl              iocore_inp8
                                   CPULD
                                 ldrh    r2, [r9, #CPU_DI]                                  ldrh    r2, [r9, #CPU_DI]
                                 ldr             r3, [r9, #CPU_ES_BASE]                                  ldr             r3, [r9, #CPU_ES_BASE]
                                 mov             r1, r0                                  mov             r1, r0
Line 483  insb   ldrh r0, [r9, #CPU_DX] Line 577  insb   ldrh r0, [r9, #CPU_DX]
                                 strh    r2, [r9, #CPU_DI]                                  strh    r2, [r9, #CPU_DI]
                                 b               i286_memorywrite                                  b               i286_memorywrite
   
 insw                    ldrh    r0, [r9, #CPU_DX]  insw                    CPUWORK #5
                                   ldrh    r0, [r9, #CPU_DX]
                                   CPUSV
                                 bl              iocore_inp16                                  bl              iocore_inp16
                                   CPULD
                                 ldrh    r2, [r9, #CPU_DI]                                  ldrh    r2, [r9, #CPU_DI]
                                 ldr             r3, [r9, #CPU_ES_BASE]                                  ldr             r3, [r9, #CPU_ES_BASE]
                                 mov             r1, r0                                  mov             r1, r0
Line 496  insw   ldrh r0, [r9, #CPU_DX] Line 593  insw   ldrh r0, [r9, #CPU_DX]
                                 strh    r2, [r9, #CPU_DI]                                  strh    r2, [r9, #CPU_DI]
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 outsb                   ldrh    r1, [r9, #CPU_SI]  outsb                   CPUWORK #3
                                   ldrh    r1, [r9, #CPU_SI]
                                 ldr             r2, [r9, #CPU_DS_FIX]                                  ldr             r2, [r9, #CPU_DS_FIX]
                                 add             r0, r1, r2                                  add             r0, r1, r2
                                 tst             r8, #D_FLAG                                  tst             r8, #D_FLAG
Line 506  outsb   ldrh r1, [r9, #CPU_SI] Line 604  outsb   ldrh r1, [r9, #CPU_SI]
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                 mov             r1, r0                                  mov             r1, r0
                                 ldr             r0, [r9, #CPU_DX]                                  ldr             r0, [r9, #CPU_DX]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out8                                  bl              iocore_out8
                                   CPULD
                                   mov             pc, r11
   
 outsw                   ldrh    r1, [r9, #CPU_SI]  outsw                   CPUWORK #3
                                   ldrh    r1, [r9, #CPU_SI]
                                 ldr             r2, [r9, #CPU_DS_FIX]                                  ldr             r2, [r9, #CPU_DS_FIX]
                                 add             r0, r1, r2                                  add             r0, r1, r2
                                 tst             r8, #D_FLAG                                  tst             r8, #D_FLAG
Line 519  outsw   ldrh r1, [r9, #CPU_SI] Line 620  outsw   ldrh r1, [r9, #CPU_SI]
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 mov             r1, r0                                  mov             r1, r0
                                 ldr             r0, [r9, #CPU_DX]                                  ldr             r0, [r9, #CPU_DX]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out16                                  bl              iocore_out16
                                   CPULD
                                   mov             pc, r11
   
   jle_short               tst             r8, #Z_FLAG
                                   bne             jmps
   jl_short                eor             r0, r8, r8 lsr #4
                                   tst             r0, #S_FLAG
                                   bne             jmps
   nojmps                  CPUWORK #2
                                   add             r8, r8, #(1 << 16)
                                   mov             pc, r11
   
   jnle_short              tst             r8, #Z_FLAG
                                   bne             nojmps
   jnl_short               eor             r0, r8, r8 lsr #4
                                   tst             r0, #S_FLAG
                                   bne             nojmps
   jmps                    JMPS    #7
   
   
 xchg_ea_r8              EAREG8  r6  xchg_ea_r8              EAREG8  r6
Line 608  movear16_1  CPUWORK #5 Line 727  movear16_1  CPUWORK #5
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 mov_r8_ea               REG8EA  r5, #2, #5  mov_r8_ea               REG8EA  r5, #2, #5
                                 ldrb    r0, [r5, #CPU_REG]                                  strb    r0, [r5, #CPU_REG]
                                 mov             pc, r11                                  mov             pc, r11
   
 mov_r16_ea              REG16EA r5, #2, #5  mov_r16_ea              REG16EA r5, #2, #5
                                 ldrh    r0, [r5, #CPU_REG]                                  strh    r0, [r5, #CPU_REG]
                                   mov             pc, r11
   
   mov_ea_seg              GETPC8
                                   and             r1, r0, #(3 << 3)
                                   add             r1, r9, r1 lsr #2
                                   ldrh    r5, [r1, #CPU_SEG]
                                   cmp             r0, #&c0
                                   bcc             measegm
                                   CPUWORK #2
                                   R16SRC  r0, r4
                                   strh    r5, [r4, #CPU_REG]
                                   mov             pc, r11
   measegm                 CPUWORK #3
                                   bl              i286a_ea
                                   mov             r1, r5
                                   mov             lr, r11
                                   b               i286_memorywrite_w
   
   lea_r16_ea              CPUWORK #3
                                   GETPC8
                                   cmp             r0, #&c0
                                   bcs             leareg
                                   R16DST  r0, r5
                                   bl              i286a_lea
                                   strh    r0, [r5, #CPU_REG]
                                 mov             pc, r11                                  mov             pc, r11
   leareg                  mov             r6, #6
                                   sub             r8, r8, #(2 << 16)
                                   b               i286a_localint
   
   mov_seg_ea              GETPC8
                                   adr             r6, msegea_tbl
                                   and             r1, r0, #(3 << 3)
                                   mov             r5, r8
                                   ldr             r6, [r6, r1 lsr #1]
                                   cmp             r0, #&c0
                                   bcc             msegeam
                                   CPUWORK #2
                                   R16SRC  r0, r4
                                   ldrh    r0, [r4, #CPU_REG]
                                   mov             pc, r6
   msegeam                 CPUWORK #5
                                   bl              i286a_ea
                                   bl              i286_memoryread_w
                                   mov             pc, r6
   msegea_tbl              dcd             msegea_es
                                   dcd             msegea_cs
                                   dcd             msegea_ss
                                   dcd             msegea_ds
   msegea_es               mov             r1, r0 lsl #4
                                   strh    r0, [r9, #CPU_ES]
                                   str             r1, [r9, #CPU_ES_BASE]
                                   mov             pc, r11
   msegea_ds               mov             r1, r0 lsl #4
                                   strh    r0, [r9, #CPU_DS]
                                   str             r1, [r9, #CPU_DS_BASE]
                                   str             r1, [r9, #CPU_DS_FIX]
                                   mov             pc, r11
   msegea_ss               mov             r1, r0 lsl #4
                                   strh    r0, [r9, #CPU_SS]
                                   str             r1, [r9, #CPU_SS_BASE]
                                   str             r1, [r9, #CPU_SS_FIX]
                                   NEXT_OPCODE
   msegea_cs               sub             r8, r5, #(2 << 16)
                                   mov             r6, #6
                                   b               i286a_localint
   
 pop_ea                  POP             #5  pop_ea                  POP             #5
                                 mov             r4, r0                                  mov             r5, r0
                                 GETPC8                                  GETPC8
                                 cmp             r0, #&c0                                  cmp             r0, #&c0
                                 bcs             popreg                                  bcs             popreg
                                 bl              i286a_ea                                  bl              i286a_ea
                                 mov             r1, r4                                  mov             r1, r5
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
 popreg                  R16DST  r0, r1  popreg                  R16SRC  r0, r1
                                 ldrh    r4, [r1, #CPU_REG]                                  strh    r4, [r1, #CPU_REG]
                                 mov             pc, r11                                  mov             pc, r11
   
   
   nopandbios              sub             r0, r8, #(1 << 16)
                                   CPUWORK #3
                           ;       ldr             r5, [r9, #CPU_CS_BASE]
                                   add             r0, r5, r0 lsr #16
                                   cmp             r0, #&0f8000
                                   movcc   pc, r11
                                   cmp             r0, #&100000
                                   movcs   pc, r11
                                   CPUSV
                                   bl              biosfunc
                                   CPULD
                                   ldrh    r0, [r9, #CPU_ES]
                                   ldrh    r1, [r9, #CPU_CS]
                                   ldrh    r2, [r9, #CPU_SS]
                                   ldrh    r3, [r9, #CPU_DS]
                                   mov             r0, r0 lsl #4
                                   mov             r1, r1 lsl #4
                                   mov             r2, r2 lsl #4
                                   mov             r3, r3 lsl #4
                                   str             r0, [r9, #CPU_ES_BASE]
                                   str             r1, [r9, #CPU_CS_BASE]
                                   str             r2, [r9, #CPU_SS_BASE]
                                   str             r3, [r9, #CPU_DS_BASE]
                                   str             r2, [r9, #CPU_SS_FIX]
                                   str             r3, [r9, #CPU_DS_FIX]
                                   mov             pc, r11
   
 cbw                             CPUWORK #2  cbw                             CPUWORK #2
                                 ldrb    r0, [r9, #CPU_AL]                                  ldrb    r0, [r9, #CPU_AL]
                                 mov             r1, r0 lsl #24                                  mov             r1, r0 lsl #24
Line 644  cwd    CPUWORK #2 Line 855  cwd    CPUWORK #2
                                 mov             pc, r11                                  mov             pc, r11
   
 call_far                CPUWORK #13  call_far                CPUWORK #13
                                 ldrh    r1, [r9, #CPU_CS]  
                                 ldrh    r4, [r9, #CPU_SP]                                  ldrh    r4, [r9, #CPU_SP]
                                   ldrh    r1, [r9, #CPU_CS]
                                 ldr             r5, [r9, #CPU_SS_BASE]                                  ldr             r5, [r9, #CPU_SS_BASE]
                                 mov             r4, r4 lsl #16                                  mov             r4, r4 lsl #16
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                 add             r0, r5, r4 lsr #16                                  add             r0, r5, r4 lsr #16
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w                      ; cs
                                 add             r12, r8, #(4 << 16)  
                                 sub             r4, r4, #(2 << 16)                                  sub             r4, r4, #(2 << 16)
                                   add             r12, r8, #(4 << 16)
                                   mov             r4, r4, lsr #16
                                 mov             r1, r12 lsr #16                                  mov             r1, r12 lsr #16
                                 add             r0, r5, r4 lsr #16                                  add             r0, r4, r5
                                 bl              i286_memorywrite_w                                  bl              i286_memorywrite_w                      ; ip
                                 ldr             r5, [r9, #CPU_CS_BASE]                                  ldr             r5, [r9, #CPU_CS_BASE]
                                 strh    r4, [r9, #CPU_SP]                                  strh    r4, [r9, #CPU_SP]
                                 add             r0, r5, r8 lsr #16                                  add             r0, r5, r8 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w                       ; newip
                                 add             r8, r8, #(2 << 16)                                  add             r8, r8, #(2 << 16)
                                 mov             r4, r0 lsl #16                                  mov             r4, r0 lsl #16
                                 add             r0, r5, r8 lsr #16                                  add             r0, r5, r8 lsr #16
Line 675  wait   CPUWORK #2 Line 887  wait   CPUWORK #2
                                 mov             pc, r11                                  mov             pc, r11
   
 pushf                   CPUWORK #3  pushf                   CPUWORK #3
                                 ldrh    r1, [r9, #CPU_SP]                                  ldrh    r3, [r9, #CPU_SP]
                                 ldr             r2, [r9, #CPU_SS_BASE]                                  ldr             r2, [r9, #CPU_SS_BASE]
                                 sub             r0, r1, #2  
                                 mov             r3, r0 lsl #16  
                                 strh    r0, [r9, #CPU_SP]  
                                 add             r0, r2, r3 lsr #16  
                                 mov             r1, r8                                  mov             r1, r8
                                   subs    r3, r3, #2
                                   addcc   r3, r3, #&10000
                                   strh    r3, [r9, #CPU_SP]
                                   add             r0, r3, r2
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
   popf                    POP             #5
                                   mov             r2, #3
                                   mov             r8, r8 lsr #16
                                   and             r2, r2, r0 lsr #8
                                   bic             r1, r0, #&f000                                  ; i286
                                   ands    r2, r2, r2 lsr #1
                                   orr             r8, r1, r8 lsl #16
                                   strb    r2, [r9, #CPU_TRAP]
                                   bne             popf_withirq
                                   ldr             r0, popf_pic
                                   tst             r8, #I_FLAG
                                   moveq   pc, r11
                                   PICEXISTINTR
                                   moveq   pc, r11
   popf_withirq    I286IRQCHECKTERM
   popf_pic                dcd             pic
   
 sahf                    CPUWORK #2  sahf                    CPUWORK #2
                                 ldrb    r0, [r9, #CPU_AH]                                  ldrb    r0, [r9, #CPU_AH]
                                 bic             r8, r8, #&ff                                  bic             r8, r8, #&ff
Line 729  mov_m16_ax  CPUWORK #5 Line 958  mov_m16_ax  CPUWORK #5
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 movsb                   CPUWORK #5  movsb                   CPUWORK #5
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   tst             r8, #D_FLAG
                                   moveq   r4, #1
                                   movne   r4, #-1
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                 ldr             r2, [r9, #CPU_ES_BASE]  
                                 ldrh    r3, [r9, #CPU_DI]                                  ldrh    r3, [r9, #CPU_DI]
                                 and             r12, r8, #D_FLAG                                  ldr             r2, [r9, #CPU_ES_BASE]
                                   add             r5, r5, r4
                                 mov             r1, r0                                  mov             r1, r0
                                 mov             r12, r12 lsr #(10 - 1)                                  add             r0, r3, r2
                                 add             r0, r2, r3                                  add             r3, r3, r4
                                 add             r2, r12, #-1  
                                 mov             lr, r11  
                                 add             r5, r2, r5  
                                 add             r3, r2, r3  
                                 strh    r5, [r9, #CPU_SI]                                  strh    r5, [r9, #CPU_SI]
                                 strh    r3, [r9, #CPU_DI]                                  strh    r3, [r9, #CPU_DI]
                                   mov             lr, r11
                                 b               i286_memorywrite                                  b               i286_memorywrite
   
 movsw                   CPUWORK #5  movsw                   CPUWORK #5
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   tst             r8, #D_FLAG
                                   moveq   r4, #2
                                   movne   r4, #-2
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 ldr             r2, [r9, #CPU_ES_BASE]  
                                 ldrh    r3, [r9, #CPU_DI]                                  ldrh    r3, [r9, #CPU_DI]
                                 and             r12, r8, #D_FLAG                                  ldr             r2, [r9, #CPU_ES_BASE]
                                   add             r5, r5, r4
                                 mov             r1, r0                                  mov             r1, r0
                                 mov             r12, r12 lsr #(10 - 2)                                  add             r0, r3, r2
                                 add             r0, r2, r3                                  add             r3, r3, r4
                                 add             r2, r12, #-2  
                                 mov             lr, r11  
                                 add             r5, r2, r5  
                                 add             r3, r2, r3  
                                 strh    r5, [r9, #CPU_SI]                                  strh    r5, [r9, #CPU_SI]
                                 strh    r3, [r9, #CPU_DI]                                  strh    r3, [r9, #CPU_DI]
                                   mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 cmpsb                   CPUWORK #8  cmpsb                   CPUWORK #8
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   ;
                                   ;
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                 ldr             r2, [r9, #CPU_ES_BASE]                                  ldr             r2, [r9, #CPU_ES_BASE]
Line 777  cmpsb   CPUWORK #8 Line 1008  cmpsb   CPUWORK #8
                                 and             r12, r8, #D_FLAG                                  and             r12, r8, #D_FLAG
                                 mov             r12, r12 lsr #(10 - 1)                                  mov             r12, r12 lsr #(10 - 1)
                                 add             r0, r2, r3                                  add             r0, r2, r3
                                 add             r2, r12, #-1                                  rsb             r2, r12, #1
                                 add             r5, r2, r5                                  add             r5, r2, r5
                                 add             r3, r2, r3                                  add             r3, r2, r3
                                 strh    r5, [r9, #CPU_SI]                                  strh    r5, [r9, #CPU_SI]
Line 787  cmpsb   CPUWORK #8 Line 1018  cmpsb   CPUWORK #8
                                 mov             pc, r11                                  mov             pc, r11
   
 cmpsw                   CPUWORK #8  cmpsw                   CPUWORK #8
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   ;
                                   ;
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 ldr             r2, [r9, #CPU_ES_BASE]                                  ldr             r2, [r9, #CPU_ES_BASE]
Line 797  cmpsw   CPUWORK #8 Line 1030  cmpsw   CPUWORK #8
                                 and             r12, r8, #D_FLAG                                  and             r12, r8, #D_FLAG
                                 mov             r12, r12 lsr #(10 - 2)                                  mov             r12, r12 lsr #(10 - 2)
                                 add             r0, r2, r3                                  add             r0, r2, r3
                                 add             r2, r12, #-2                                  rsb             r2, r12, #2
                                 add             r5, r2, r5                                  add             r5, r2, r5
                                 add             r3, r2, r3                                  add             r3, r2, r3
                                 strh    r5, [r9, #CPU_SI]                                  strh    r5, [r9, #CPU_SI]
Line 807  cmpsw   CPUWORK #8 Line 1040  cmpsw   CPUWORK #8
                                 mov             pc, r11                                  mov             pc, r11
   
 stosb                   CPUWORK #3  stosb                   CPUWORK #3
                                 ldr             r0, [r9, #CPU_ES_BASE]  
                                 ldrb    r1, [r9, #CPU_AL]                                  ldrb    r1, [r9, #CPU_AL]
                                 ldrh    r2, [r9, #CPU_DI]                                  ldrh    r2, [r9, #CPU_DI]
                                 add             r0, r2, r0                                  ldr             r0, [r9, #CPU_ES_BASE]
                                 tst             r8, #D_FLAG                                  tst             r8, #D_FLAG
                                 addeq   r2, r2, #1                                  addeq   r3, r2, #1
                                 subne   r2, r2, #1                                  subne   r3, r2, #1
                                 strh    r2, [r9, #CPU_DI]                                  add             r0, r2, r0
                                   strh    r3, [r9, #CPU_DI]
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite                                  b               i286_memorywrite
   
 stosw                   CPUWORK #3  stosw                   CPUWORK #3
                                 ldr             r0, [r9, #CPU_ES_BASE]  
                                 ldrh    r1, [r9, #CPU_AX]                                  ldrh    r1, [r9, #CPU_AX]
                                 ldrh    r2, [r9, #CPU_DI]                                  ldrh    r2, [r9, #CPU_DI]
                                 add             r0, r2, r0                                  ldr             r0, [r9, #CPU_ES_BASE]
                                 tst             r8, #D_FLAG                                  tst             r8, #D_FLAG
                                 addeq   r2, r2, #2                                  addeq   r3, r2, #2
                                 subne   r2, r2, #2                                  subne   r3, r2, #2
                                 strh    r2, [r9, #CPU_DI]                                  add             r0, r2, r0
                                   strh    r3, [r9, #CPU_DI]
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 lodsb                   CPUWORK #5  lodsb                   CPUWORK #5
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   tst             r8, #D_FLAG
                                   addeq   r6, r5, #1
                                   subne   r6, r5, #1
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                 tst             r8, #D_FLAG  
                                 addeq   r5, r5, #1  
                                 subne   r5, r5, #1  
                                 strb    r0, [r9, #CPU_AL]                                  strb    r0, [r9, #CPU_AL]
                                 strh    r5, [r9, #CPU_SI]                                  strh    r6, [r9, #CPU_SI]
                                 mov             pc, r11                                  mov             pc, r11
   
 lodsw                   CPUWORK #5  lodsw                   CPUWORK #5
                                 ldr             r0, [r9, #CPU_DS_FIX]  
                                 ldrh    r5, [r9, #CPU_SI]                                  ldrh    r5, [r9, #CPU_SI]
                                   ldr             r0, [r9, #CPU_DS_FIX]
                                   tst             r8, #D_FLAG
                                   addeq   r6, r5, #2
                                   subne   r6, r5, #2
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 tst             r8, #D_FLAG  
                                 addeq   r5, r5, #2  
                                 subne   r5, r5, #2  
                                 strh    r0, [r9, #CPU_AX]                                  strh    r0, [r9, #CPU_AX]
                                 strh    r5, [r9, #CPU_SI]                                  strh    r6, [r9, #CPU_SI]
                                 mov             pc, r11                                  mov             pc, r11
   
 scasb                   CPUWORK #7  scasb                   CPUWORK #7
                                 ldr             r0, [r9, #CPU_DS_FIX]                                  ldrh    r5, [r9, #CPU_DI]
                                 ldrh    r5, [r9, #CPU_SI]                                  ldr             r0, [r9, #CPU_ES_BASE]
                                   tst             r8, #D_FLAG
                                   addeq   r6, r5, #1
                                   subne   r6, r5, #1
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                 tst             r8, #D_FLAG  
                                 addeq   r5, r5, #1  
                                 subne   r5, r5, #1  
                                 strh    r5, [r9, #CPU_SI]  
                                 ldrb    r5, [r9, #CPU_AL]                                  ldrb    r5, [r9, #CPU_AL]
                                   strh    r6, [r9, #CPU_DI]
                                 SUB8    r5, r0                                  SUB8    r5, r0
                                 mov             pc, r11                                  mov             pc, r11
   
 scasw                   CPUWORK #7  scasw                   CPUWORK #7
                                 ldr             r0, [r9, #CPU_DS_FIX]                                  ldrh    r5, [r9, #CPU_DI]
                                 ldrh    r5, [r9, #CPU_SI]                                  ldr             r0, [r9, #CPU_ES_BASE]
                                   tst             r8, #D_FLAG
                                   addeq   r6, r5, #2
                                   subne   r6, r5, #2
                                 add             r0, r5, r0                                  add             r0, r5, r0
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 tst             r8, #D_FLAG  
                                 addeq   r5, r5, #2  
                                 subne   r5, r5, #2  
                                 strh    r5, [r9, #CPU_SI]  
                                 ldrh    r5, [r9, #CPU_AX]                                  ldrh    r5, [r9, #CPU_AX]
                                   strh    r6, [r9, #CPU_DI]
                                 SUB16   r5, r0                                  SUB16   r5, r0
                                 mov             pc, r11                                  mov             pc, r11
   
   
 setalc                  CPUWORK #2  ret_near_d16    GETPC16
                                 mov             r0, r8 lsr #31                                  ldrh    r1, [r9, #CPU_SP]
                                 mov             r0, r0 asr #31                                  ldr             r2, [r9, #CPU_SS_BASE]
                                 strb    r0, [r9, #CPU_AL]                                  CPUWORK #11
                                   add             r3, r0, r1
                                   add             r0, r1, r2
                                   add             r3, r3, #2
                                   strh    r3, [r9, #CPU_SP]
                                   bl              i286_memoryread_w
                                   mov             r8, r8 lsl #16
                                   mov             r8, r8 lsr #16
                                   orr             r8, r8, r0 lsl #16
                                 mov             pc, r11                                  mov             pc, r11
   
 xlat                    CPUWORK #5  ret_near                CPUWORK #11
                                 ldrb    r0, [r9, #CPU_AL]                                  ldrh    r1, [r9, #CPU_SP]
                                 ldrh    r1, [r9, #CPU_BX]                                  ldr             r0, [r9, #CPU_SS_BASE]
                                 ldr             r2, [r9, #CPU_DS_FIX]                                  mov             r8, r8 lsl #16
                                   add             r2, r1, #2
                                 add             r0, r1, r0                                  add             r0, r1, r0
                                 bic             r0, r0, #(1 << 16)                                  strh    r2, [r9, #CPU_SP]
                                 add             r0, r2, r0                                  mov             r8, r8 lsr #16
                                 bl              i286_memoryread                                  bl              i286_memoryread_w
                                 strb    r0, [r9, #CPU_AL]                                  orr             r8, r8, r0 lsl #16
                                 mov             pc, r11                                  mov             pc, r11
   
 esc                             CPUWORK #2  les_r16_ea              GETPC8
                                 GETPC8  
                                 cmp             r0, #&c0                                  cmp             r0, #&c0
                                 movcs   pc, r11                                  bcs             lr16_r
                                 mov             lr, r11                                  CPUWORK #3
                                 b               i286a_ea                                  R16DST  r0, r5
                                   bl              i286a_a
                                   add             r4, r0, #2
 loopnz                  ldrh    r0, [r9, #CPU_CX]                                  add             r0, r0, r6
                                 subs    r0, r0, #1                                  bic             r4, r4, #(1 << 16)
                                 strh    r0, [r9, #CPU_CX]                                  bl              i286_memoryread_w
                                 beq             lpnznoj                                  strh    r0, [r5, #CPU_REG]
                                 tst             r8, #Z_FLAG                                  add             r0, r4, r6
                                 bne             lpnznoj                                  bl              i286_memoryread_w
                                 JMPS    #8                                  mov             r1, r0 lsl #4
 lpnznoj                 CPUWORK #4                                  strh    r0, [r9, #CPU_ES]
                                 add             r8, r8, #(1 << 16)                                  str             r1, [r9, #CPU_ES_BASE]
                                 mov             pc, r11                                  mov             pc, r11
   lr16_r                  mov             r6, #6
                                   sub             r8, r8, #(2 << 16)
                                   b               i286a_localint
   
 loopz                   ldrh    r0, [r9, #CPU_CX]  lds_r16_ea              GETPC8
                                 subs    r0, r0, #1                                  cmp             r0, #&c0
                                 strh    r0, [r9, #CPU_CX]                                  bcs             lr16_r
                                 beq             lpznoj                                  CPUWORK #3
                                 tst             r8, #Z_FLAG                                  R16DST  r0, r5
                                 beq             lpnznoj                                  bl              i286a_a
                                 JMPS    #8                                  add             r4, r0, #2
 lpznoj                  CPUWORK #4                                  add             r0, r0, r6
                                 add             r8, r8, #(1 << 16)                                  bic             r4, r4, #(1 << 16)
                                   bl              i286_memoryread_w
                                   strh    r0, [r5, #CPU_REG]
                                   add             r0, r4, r6
                                   bl              i286_memoryread_w
                                   mov             r1, r0 lsl #4
                                   strh    r0, [r9, #CPU_DS]
                                   str             r1, [r9, #CPU_DS_BASE]
                                   str             r1, [r9, #CPU_DS_FIX]
                                 mov             pc, r11                                  mov             pc, r11
   
 loop                    ldrh    r0, [r9, #CPU_CX]  mov_ea8_d8              GETPC8
                                 subs    r0, r0, #1                                  cmp             r0, #&c0
                                 strh    r0, [r9, #CPU_CX]                                  bcs             med8_r
                                 beq             lpnoj                                  CPUWORK #3
                                 JMPS    #8                                  bl              i286a_ea
 lpnoj                   CPUWORK #4                                  mov             r4, r0
                                 add             r8, r8, #(1 << 16)                                  GETPC8
                                   mov             r1, r0
                                   mov             r0, r4
                                   mov             lr, r11
                                   b               i286_memorywrite
   med8_r                  CPUWORK #2
                                   R8DST   r0, r4
                                   GETPC8
                                   strb    r0, [r4, #CPU_REG]
                                 mov             pc, r11                                  mov             pc, r11
   
 jcxz                    ldrh    r0, [r9, #CPU_CX]  mov_ea16_d16    GETPC8
                                 cmp             r0, #0                                  cmp             r0, #&c0
                                 beq             jcxzj                                  bcs             med16_r
                                 CPUWORK #4                                  CPUWORK #3
                                 add             r8, r8, #(1 << 16)                                  bl              i286a_ea
                                   mov             r4, r0
                                   GETPC16
                                   mov             r1, r0
                                   mov             r0, r4
                                   mov             lr, r11
                                   b               i286_memorywrite_w
   med16_r                 CPUWORK #2
                                   R16DST  r0, r4
                                   GETPC16
                                   strh    r0, [r4, #CPU_REG]
                                 mov             pc, r11                                  mov             pc, r11
 jcxzj                   JMPS    #8  
   enter                   ldrh    r4, [r9, #CPU_SP]
                                   ldrh    r5, [r9, #CPU_BP]
                                   ldr             r0, [r9, #CPU_SS_BASE]
                                   subs    r4, r4, #2
                                   addcc   r4, r4, #&10000
                                   mov             r1, r5
                                   add             r0, r4, r0
                                   bl              i286_memorywrite_w
                                   GETPC16
                                   mov             r6, r0
                                   GETPC8
                                   ands    r0, r0, #&1f
                                   bne             enterlv1
                                   CPUWORK #11
                                   sub             r0, r4, r6
                                   strh    r4, [r9, #CPU_BP]
                                   strh    r0, [r9, #CPU_SP]
                                   mov             pc, r11
   enterlv1                cmp             r0, #1
                                   bne             enterlv2
                                   CPUWORK #15
                                   strh    r4, [r9, #CPU_BP]
                                   ldr             r0, [r9, #CPU_SS_BASE]
                                   mov             r1, r4
                                   subs    r4, r4, #2
                                   addcc   r4, r4, #&10000
                                   add             r0, r4, r0
                                   sub             r2, r4, r6
                                   mov             lr, r11
                                   strh    r2, [r9, #CPU_SP]
                                   bl              i286_memorywrite_w
   enterlv2                mov             r1, r0, lsl #2
                                   add             r1, r1, #12
                                   CPUWORK r1
                                   strh    r4, [r9, #CPU_BP]
                                   str             r11, [sp, #-4]!
                                   mov             r4, r4 lsl #16
                                   sub             r2, r4, r0 lsl #17
                                   sub             r2, r4, #(2 << 16)
                                   mov             r2, r2 lsr #16
                                   sub             r3, r2, r6
                                   strh    r3, [r9, #CPU_SP]
                                   mov             r6, r0
                                   ldr             r11, [r9, #CPU_SS_BASE]
                                   mov             r1, r5
                                   mov             r5, r5 lsl #16
                                   add             r0, r11, r2
                                   bl              i286_memorywrite_w
   entlv2lp                sub             r5, r5, #(2 << 16)
                                   sub             r4, r4, #(2 << 16)
                                   add             r0, r11, r5 lsr #16
                                   bl              i286_memoryread_w
                                   mov             r1, r0
                                   add             r0, r11, r4
                                   bl              i286_memorywrite_w
                                   subs    r6, r6, #1
                                   bne             entlv2lp
                                   ldr             pc, [sp], #4
   
   leave                   ldrh    r1, [r9, #CPU_BP]
                                   ldr             r0, [r9, #CPU_SS_BASE]
                                   CPUWORK #5
                                   add             r4, r1, #2
                                   add             r0, r1, r0
                                   bl              i286_memoryread_w
                                   strh    r4, [r9, #CPU_SP]
                                   strh    r0, [r9, #CPU_BP]
                                   mov             pc, r11
   
   ret_far_d16             CPUWORK #15
                                   GETPC16
                                   mov             r6, r0
                                   ldrh    r4, [r9, #CPU_SP]
                                   ldr             r5, [r9, #CPU_SS_BASE]
                                   ;
                                   ;
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   mov             r8, r8 lsl #16
                                   mov             r8, r8 lsr #16
                                   orr             r8, r8, r0 lsl #16
                                   bic             r4, r4, #(1 << 16)
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   add             r4, r6, r4
                                   mov             r1, r0 lsl #4
                                   strh    r4, [r9, #CPU_SP]
                                   strh    r0, [r9, #CPU_CS]
                                   str             r1, [r9, #CPU_CS_BASE]
                                   mov             pc, r11
   
   ret_far                 CPUWORK #15
                                   ldrh    r4, [r9, #CPU_SP]
                                   ldr             r5, [r9, #CPU_SS_BASE]
                                   ;
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   mov             r8, r8 lsl #16
                                   mov             r8, r8 lsr #16
                                   orr             r8, r8, r0 lsl #16
                                   bic             r4, r4, #(1 << 16)
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   mov             r1, r0 lsl #4
                                   strh    r4, [r9, #CPU_SP]
                                   strh    r0, [r9, #CPU_CS]
                                   str             r1, [r9, #CPU_CS_BASE]
                                   mov             pc, r11
   
   int_03                  CPUWORK #3
                                   mov             r6, #3
                                   b               i286a_localint
   
   int_d8                  CPUWORK #3
                                   GETPC8
                                   mov             r6, r0
                                   b               i286a_localint
   
   into                    CPUWORK #4
                                   tst             r8, #O_FLAG
                                   moveq   pc, r11
                                   mov             r6, #4
                                   b               i286a_localint
   
   iret                    bl              extirq_pop
                                   CPUWORK #31
                                   ldrh    r1, [r9, #CPU_SP]
                                   ldr             r5, [r9, #CPU_SS_BASE]
                                   ;
                                   add             r4, r1, #2
                                   add             r0, r1, r5
                                   bl              i286_memoryread_w
                                   bic             r4, r4, #(1 << 16)
                                   mov             r8, r0 lsl #16
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   mov             r1, r0 lsl #4
                                   strh    r0, [r9, #CPU_CS]
                                   str             r1, [r9, #CPU_CS_BASE]
                                   bic             r4, r4, #(1 << 16)
                                   add             r0, r4, r5
                                   add             r4, r4, #2
                                   bl              i286_memoryread_w
                                   strh    r4, [r9, #CPU_SP]
                                   mov             r2, #3
                                   bic             r1, r0, #&f000                                  ; i286
                                   and             r2, r2, r0 lsr #8
                                   orr             r8, r1, r8
                                   ands    r2, r2, r2 lsr #1
                                   strb    r2, [r9, #CPU_TRAP]
                                   bne             iret_withirq
                                   ldr             r0, iret_pic
                                   tst             r8, #I_FLAG
                                   moveq   pc, r11
                                   PICEXISTINTR
                                   moveq   pc, r11
   iret_withirq    I286IRQCHECKTERM
   iret_pic                dcd             pic
   
   
   aam                             CPUWORK #16
                                   GETPC8
                                   movs    r0, r0, lsl #7
                                   beq             aamzero
                                   ldrb    r1, [r9, #CPU_AL]
                                   mov             r2, #&80
                                   mov             r3, #0
   aamlp                   cmp             r1, r0
                                   subcs   r1, r1, r0
                                   orrcs   r3, r2, r3
                                   movs    r2, r2 lsr #1
                                   bne             aamlp
                                   ldrb    r2, [r10, r1]
                                   add             r1, r1, r3 lsl #8
                                   bic             r8, r8, #(S_FLAG + Z_FLAG + P_FLAG)
                                   movs    r3, r1 lsl #16
                                   orreq   r8, r8, #Z_FLAG
                                   orrmi   r8, r8, #S_FLAG
                                   and             r2, r2, #P_FLAG
                                   orr             r8, r2, r8
                                   strh    r1, [r9, #CPU_AX]
                                   mov             pc, r11
   aamzero                 sub             r8, r8, #(2 << 16)
                                   mov             r6, #0
                                   b               i286a_localint
   
   aad                             CPUWORK #14
                                   GETPC8
                                   ldrh    r1, [r9, #CPU_AX]
                                   bic             r8, r8, #(S_FLAG + Z_FLAG + P_FLAG)
                                   ;
                                   mov             r2, r1 lsr #8
                                   mla             r3, r2, r0, r1
                                   ;
                                   and             r1, r3, #&ff
                                   ;
                                   ldrb    r2, [r10, r1]
                                   strh    r1, [r9, #CPU_AX]
                                   ;
                                   orr             r8, r2, r8
                                   mov             pc, r11
   
   setalc                  CPUWORK #2
                                   mov             r0, r8 lsr #31
                                   mov             r0, r0 asr #31
                                   strb    r0, [r9, #CPU_AL]
                                   mov             pc, r11
   
   xlat                    ldrb    r0, [r9, #CPU_AL]
                                   ldrh    r1, [r9, #CPU_BX]
                                   ldr             r2, [r9, #CPU_DS_FIX]
                                   CPUWORK #5
                                   add             r0, r1, r0
                                   bic             r0, r0, #(1 << 16)
                                   add             r0, r2, r0
                                   bl              i286_memoryread
                                   strb    r0, [r9, #CPU_AL]
                                   mov             pc, r11
   
   esc                             CPUWORK #2
                                   GETPC8
                                   cmp             r0, #&c0
                                   movcs   pc, r11
                                   mov             lr, r11
                                   b               i286a_ea
   
   
   loopnz                  ldrh    r0, [r9, #CPU_CX]
                                   ;
                                   ;
                                   subs    r0, r0, #1
                                   strh    r0, [r9, #CPU_CX]
                                   beq             lpnznoj
                                   tst             r8, #Z_FLAG
                                   bne             lpnznoj
                                   JMPS    #8
   lpnznoj                 CPUWORK #4
                                   add             r8, r8, #(1 << 16)
                                   mov             pc, r11
   
   loopz                   ldrh    r0, [r9, #CPU_CX]
                                   ;
                                   ;
                                   subs    r0, r0, #1
                                   strh    r0, [r9, #CPU_CX]
                                   beq             lpznoj
                                   tst             r8, #Z_FLAG
                                   beq             lpznoj
                                   JMPS    #8
   lpznoj                  CPUWORK #4
                                   add             r8, r8, #(1 << 16)
                                   mov             pc, r11
   
   loop                    ldrh    r0, [r9, #CPU_CX]
                                   ;
                                   ;
                                   subs    r0, r0, #1
                                   strh    r0, [r9, #CPU_CX]
                                   beq             lpnoj
                                   JMPS    #8
   lpnoj                   CPUWORK #4
                                   add             r8, r8, #(1 << 16)
                                   mov             pc, r11
   
   jcxz                    ldrh    r0, [r9, #CPU_CX]
                                   ;
                                   ;
                                   cmp             r0, #0
                                   beq             jcxzj
                                   CPUWORK #4
                                   add             r8, r8, #(1 << 16)
                                   mov             pc, r11
   jcxzj                   JMPS    #8
   
 in_al_d8                CPUWORK #5  in_al_d8                CPUWORK #5
                                 GETPC8                                  GETPC8
                                   add             r3, r0, r8 lsr #16
                                   CPUSV
                                   str             r3, [r9, #CPU_INPUT]
                                 bl              iocore_inp8                                  bl              iocore_inp8
                                   CPULD
                                   mov             r3, #0
                                 strb    r0, [r9, #CPU_AL]                                  strb    r0, [r9, #CPU_AL]
                                   str             r3, [r9, #CPU_INPUT]
                                 mov             pc, r11                                  mov             pc, r11
   
 in_ax_d8                CPUWORK #5  in_ax_d8                CPUWORK #5
                                 GETPC8                                  GETPC8
                                   CPUSV
                                 bl              iocore_inp16                                  bl              iocore_inp16
                                   CPULD
                                 strh    r0, [r9, #CPU_AX]                                  strh    r0, [r9, #CPU_AX]
                                 mov             pc, r11                                  mov             pc, r11
   
 out_d8_al               CPUWORK #3  out_d8_al               CPUWORK #3
                                 GETPC8                                  GETPC8
                                 ldrb    r1, [r9, #CPU_AL]                                  ldrb    r1, [r9, #CPU_AL]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out8                                  bl              iocore_out8
                                   CPULD
                                   mov             pc, r11
   
 out_d8_ax               CPUWORK #3  out_d8_ax               CPUWORK #3
                                 GETPC8                                  GETPC8
                                 ldrh    r1, [r9, #CPU_AX]                                  ldrh    r1, [r9, #CPU_AX]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out16                                  bl              iocore_out16
                                   CPULD
                                   mov             pc, r11
   
 call_near               CPUWORK #7  call_near               CPUWORK #7
                                 GETPC16                                  GETPC16
                                 ldrh    r2, [r9, #CPU_SP]                                  ldrh    r2, [r9, #CPU_SP]
                                 ldr             r3, [r9, #CPU_SS_BASE]                                  ldr             r3, [r9, #CPU_SS_BASE]
                                   ;
                                 sub             r1, r2, #2                                  sub             r1, r2, #2
                                 mov             r2, r1 lsl #16                                  mov             r2, r1 lsl #16
                                 strh    r1, [r9, #CPU_SP]                                  strh    r1, [r9, #CPU_SP]
Line 982  call_near  CPUWORK #7 Line 1543  call_near  CPUWORK #7
                                 mov             lr, r11                                  mov             lr, r11
                                 b               i286_memorywrite_w                                  b               i286_memorywrite_w
   
 jmp_near                CPUWORK #7  jmp_near                ldr             r4, [r9, #CPU_CS_BASE]
                                 GETPC16                                  add             r5, r8, #(2 << 16)
                                 add             r8, r8, r0 lsl #16                                  CPUWORK #7
                                   add             r0, r4, r8 lsr #16
                                   bl              i286_memoryread_w
                                   add             r8, r5, r0 lsl #16
                                 mov             pc, r11                                  mov             pc, r11
   
 jmp_far                 CPUWORK #11  jmp_far                 CPUWORK #11
                                 ldr             r4, [r9, #CPU_CS_BASE]                                  ldr             r4, [r9, #CPU_CS_BASE]
                                   add             r5, r8, #(2 << 16)
                                   mov             r6, r8 lsl #16
                                 add             r0, r4, r8 lsr #16                                  add             r0, r4, r8 lsr #16
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                 add             r8, r8, #(2 << 16)                                  mov             r8, r0 lsl #16
                                 mov             r1, r0, lsl #16                                  add             r0, r4, r5 lsr #16
                                 add             r0, r4, r8 lsr #16  
                                 mov             r8, r8, lsl #16  
                                 orr             r8, r0, r8 lsr #16  
                                 bl              i286_memoryread_w                                  bl              i286_memoryread_w
                                   add             r8, r8, r6 lsr #16
                                 mov             r1, r0 lsl #4                                  mov             r1, r0 lsl #4
                                 strh    r0, [r9, #CPU_CS]                                  strh    r0, [r9, #CPU_CS]
                                 str             r1, [r9, #CPU_CS_BASE]                                  str             r1, [r9, #CPU_CS_BASE]
Line 1004  jmp_far   CPUWORK #11 Line 1568  jmp_far   CPUWORK #11
   
 in_al_dx                CPUWORK #5  in_al_dx                CPUWORK #5
                                 ldrh    r0, [r9, #CPU_DX]                                  ldrh    r0, [r9, #CPU_DX]
                                   CPUSV
                                 bl              iocore_inp8                                  bl              iocore_inp8
                                   CPULD
                                 strb    r0, [r9, #CPU_AL]                                  strb    r0, [r9, #CPU_AL]
                                 mov             pc, r11                                  mov             pc, r11
   
 in_ax_dx                CPUWORK #5  in_ax_dx                CPUWORK #5
                                 ldrh    r0, [r9, #CPU_DX]                                  ldrh    r0, [r9, #CPU_DX]
                                   CPUSV
                                 bl              iocore_inp16                                  bl              iocore_inp16
                                   CPULD
                                 strh    r0, [r9, #CPU_AX]                                  strh    r0, [r9, #CPU_AX]
                                 mov             pc, r11                                  mov             pc, r11
   
 out_dx_al               CPUWORK #3  out_dx_al               CPUWORK #3
                                 ldrb    r1, [r9, #CPU_AL]                                  ldrb    r1, [r9, #CPU_AL]
                                 ldrh    r0, [r9, #CPU_DX]                                  ldrh    r0, [r9, #CPU_DX]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out8                                  bl              iocore_out8
                                   CPULD
                                   mov             pc, r11
   
 out_dx_ax               CPUWORK #3  out_dx_ax               CPUWORK #3
                                 ldrh    r1, [r9, #CPU_AX]                                  ldrh    r1, [r9, #CPU_AX]
                                 ldrh    r0, [r9, #CPU_DX]                                  ldrh    r0, [r9, #CPU_DX]
                                 mov             lr, r11                                  CPUSV
                                 b               iocore_out16                                  bl              iocore_out16
                                   CPULD
                                   mov             pc, r11
   
   
 lock                    CPUWORK #2  lock                    CPUWORK #2
                                 mov             pc, r11                                  mov             pc, r11
   
   hlt                             CREMSET #-1
                                   sub             r8, r8, #(1 << 16)
                                   mov             pc, r11
   
 cmc                             CPUWORK #2  cmc                             CPUWORK #2
                                 eor             r8, r8, #C_FLAG                                  eor             r8, r8, #C_FLAG
                                 mov             pc, r11                                  mov             pc, r11
Line 1042  stc    CPUWORK #2 Line 1618  stc    CPUWORK #2
                                 orr             r8, r8, #C_FLAG                                  orr             r8, r8, #C_FLAG
                                 mov             pc, r11                                  mov             pc, r11
   
   cli                             CPUWORK #2
                                   mov             r0, #0
                                   bic             r8, r8, #I_FLAG
                                   strb    r0, [r9, #CPU_TRAP]
                                   mov             pc, r11
   
   sti                             CPUWORK #2
                                   tst             r8, #I_FLAG
                                   bne             sti_noirq
   sti_set                 orr             r8, r8, #I_FLAG
                                   mov             r1, #(T_FLAG >> 8)
                                   ands    r1, r1, r8 lsr #8
                                   ldr             r0, sti_pic
                                   strneb  r1, [r9, #CPU_TRAP]
                                   bne             sti_withirq
                                   PICEXISTINTR
                                   bne             sti_withirq
   sti_noirq               NEXT_OPCODE
   sti_pic                 dcd             pic
   sti_withirq             REMAIN_ADJUST   #1
   
 cld                             CPUWORK #2  cld                             CPUWORK #2
                                 bic             r8, r8, #D_FLAG                                  bic             r8, r8, #D_FLAG
                                 mov             pc, r11                                  mov             pc, r11
Line 1051  std    CPUWORK #2 Line 1648  std    CPUWORK #2
                                 mov             pc, r11                                  mov             pc, r11
   
   
           MACRO
   $label  SEGPREFIX       $b
   $label          ldr             r1, [r9, $b]
                           ldrb    r6, [r9, #CPU_PREFIX]
                           add             r0, r5, r8 lsr #16
                           str             r1, [r9, #CPU_SS_FIX]
                           str             r1, [r9, #CPU_DS_FIX]
                           adr             r2, removeprefix
                           cmp             r2, r11
                           strne   r11, [sp, #-4]!
                           movne   r11, r2
                           add             r6, r6, #1
                           cmp             r6, #MAX_PREFIX
                           bcs             prefix_segfault
                           bl              i286_memoryread
                           ldr             r1, [r4, r0 lsl #2]
                           add             r8, r8, #(1 << 16)
                           strb    r6, [r9, #CPU_PREFIX]
                           mov             pc, r1
           MEND
   
   segprefix_es    SEGPREFIX       #CPU_ES_BASE
   segprefix_cs    SEGPREFIX       #CPU_CS_BASE
   segprefix_ss    SEGPREFIX       #CPU_SS_BASE
   segprefix_ds    SEGPREFIX       #CPU_DS_BASE
   
   prefix_fault    adr             r1, removeprefix
                                   cmp             r1, r11
                                   strne   r11, [sp, #-4]!
   prefix_segfault sub             r8, r8, #(MAX_PREFIX << 16)
                                   mov             r6, #6
                                   mov             r11, pc
                                   b               i286a_localint
   removeprefix    ldr             r0, [r9, #CPU_SS_BASE]
                                   ldr             r1, [r9, #CPU_DS_BASE]
                                   mov             r2, #0
                                   str             r0, [r9, #CPU_SS_FIX]
                                   str             r1, [r9, #CPU_DS_FIX]
                                   strb    r2, [r9, #CPU_PREFIX]
                                   ldr             pc, [sp], #4
   
   
   ; ---- cpu execute
   
 i286a_step              stmdb   sp!, {r4 - r11, lr}  i286a_step              stmdb   sp!, {r4 - r11, lr}
                                 ldr             r9, ias_r9                                  ldr             r9, ias_r9
                                 ldr             r10, ias_r10                                  ldr             r10, ias_r10
                                   ;
                                   ldr             r5, [r9, #CPU_CS_BASE]
                 ;               ldr             r7, [r9, #CPU_REMAINCLOCK]                  ;               ldr             r7, [r9, #CPU_REMAINCLOCK]
                                 ldr             r8, [r9, #CPU_FLAG]                                  ldr             r8, [r9, #CPU_FLAG]
   
                                 ldr             r0, [r9, #CPU_CS_BASE]                                  adr             r4, optbl1
                                 add             r0, r0, r8 lsr #16                                  add             r0, r5, r8 lsr #16
                                 bl              i286_memoryread                                  bl              i286_memoryread
                                   ldr             r1, [r4, r0 lsl #2]
                                 add             r8, r8, #(1 << 16)                                  add             r8, r8, #(1 << 16)
   
                                 adr             r1, optbl1  
                                 mov             r11, pc                                  mov             r11, pc
                                 ldr             pc, [r1, r0 lsl #2]                                  mov             pc, r1
   
                                 str             r8, [r9, #CPU_FLAG]                                  str             r8, [r9, #CPU_FLAG]
   
                                 ldmia   sp!, {r4 - r11, pc}                                  ldmia   sp!, {r4 - r11, pc}
   
 ias_r9                  dcd             i286core - CPU_REG  ias_r9                  dcd             i286core - CPU_REG
 ias_r10                 dcd             _szpcflag8  ias_r10                 dcd             _szpcflag8
   
 optbl1                  dcd             add_ea_r8  optbl1                  dcd             add_ea_r8                       ; 00
                                 dcd             add_ea_r16                                  dcd             add_ea_r16
                                 dcd             add_r8_ea                                  dcd             add_r8_ea
                                 dcd             add_r16_ea                                  dcd             add_r16_ea
Line 1089  optbl1   dcd  add_ea_r8 Line 1729  optbl1   dcd  add_ea_r8
                                 dcd             or_al_d8                                  dcd             or_al_d8
                                 dcd             or_ax_d16                                  dcd             or_ax_d16
                                 dcd             push_cs                                  dcd             push_cs
                                 dcd             0                                       ; op_0f/pop_cs                                  dcd             i286a_cts
   
                                 dcd             adc_ea_r8                                  dcd             adc_ea_r8                       ; 10
                                 dcd             adc_ea_r16                                  dcd             adc_ea_r16
                                 dcd             adc_r8_ea                                  dcd             adc_r8_ea
                                 dcd             adc_r16_ea                                  dcd             adc_r16_ea
Line 1108  optbl1   dcd  add_ea_r8 Line 1748  optbl1   dcd  add_ea_r8
                                 dcd             push_ds                                  dcd             push_ds
                                 dcd             pop_ds                                  dcd             pop_ds
   
                                 dcd             and_ea_r8                                  dcd             and_ea_r8                       ; 20
                                 dcd             and_ea_r16                                  dcd             and_ea_r16
                                 dcd             and_r8_ea                                  dcd             and_r8_ea
                                 dcd             and_r16_ea                                  dcd             and_r16_ea
                                 dcd             and_al_d8                                  dcd             and_al_d8
                                 dcd             and_ax_d16                                  dcd             and_ax_d16
                                 dcd             0                               ; segprefix_es                                  dcd             0                                       ; segprefix_es
                                 dcd             0                               ; daa                                  dcd                     daa
                                 dcd             sub_ea_r8                                  dcd             sub_ea_r8
                                 dcd             sub_ea_r16                                  dcd             sub_ea_r16
                                 dcd             sub_r8_ea                                  dcd             sub_r8_ea
                                 dcd             sub_r16_ea                                  dcd             sub_r16_ea
                                 dcd             sub_al_d8                                  dcd             sub_al_d8
                                 dcd             sub_ax_d16                                  dcd             sub_ax_d16
                                 dcd             0                               ; segprefix_cs                                  dcd             0                                       ; segprefix_cs
                                 dcd             0                               ; das                                  dcd                     das
   
                                 dcd             xor_ea_r8                                  dcd             xor_ea_r8                       ; 30
                                 dcd             xor_ea_r16                                  dcd             xor_ea_r16
                                 dcd             xor_r8_ea                                  dcd             xor_r8_ea
                                 dcd             xor_r16_ea                                  dcd             xor_r16_ea
                                 dcd             xor_al_d8                                  dcd             xor_al_d8
                                 dcd             xor_ax_d16                                  dcd             xor_ax_d16
                                 dcd             0                               ; segprefix_ss                                  dcd             0                                       ; segprefix_ss
                                 dcd             0                               ; aaa                                  dcd                     aaa
                                 dcd             cmp_ea_r8                                  dcd             cmp_ea_r8
                                 dcd             cmp_ea_r16                                  dcd             cmp_ea_r16
                                 dcd             cmp_r8_ea                                  dcd             cmp_r8_ea
                                 dcd             cmp_r16_ea                                  dcd             cmp_r16_ea
                                 dcd             cmp_al_d8                                  dcd             cmp_al_d8
                                 dcd             cmp_ax_d16                                  dcd             cmp_ax_d16
                                 dcd             0                               ; segprefix_ds                                  dcd             0                                       ; segprefix_ds
                                 dcd             0                               ; aas                                  dcd                     aas
   
                                 dcd             inc_ax                                  dcd             inc_ax                          ; 40
                                 dcd             inc_cx                                  dcd             inc_cx
                                 dcd             inc_dx                                  dcd             inc_dx
                                 dcd             inc_bx                                  dcd             inc_bx
Line 1159  optbl1   dcd  add_ea_r8 Line 1799  optbl1   dcd  add_ea_r8
                                 dcd             dec_si                                  dcd             dec_si
                                 dcd             dec_di                                  dcd             dec_di
   
                                 dcd             push_ax                                  dcd             push_ax                         ; 50
                                 dcd             push_cx                                  dcd             push_cx
                                 dcd             push_dx                                  dcd             push_dx
                                 dcd             push_bx                                  dcd             push_bx
Line 1176  optbl1   dcd  add_ea_r8 Line 1816  optbl1   dcd  add_ea_r8
                                 dcd             pop_si                                  dcd             pop_si
                                 dcd             pop_di                                  dcd             pop_di
   
                                 dcd             0                               ; pusha                                  dcd             pusha                           ; 60
                                 dcd             0                               ; popa                                  dcd             popa
                                 dcd             0                               ; bound                                  dcd                     bound
                                 dcd             0                               ; arpl                                  dcd             reserved                        ; arpl(reserved)
                                 dcd             0                               ; reserved                                  dcd             reserved
                                 dcd             0                               ; reserved                                  dcd             reserved
                                 dcd             0                               ; reserved                                  dcd             reserved
                                 dcd             0                               ; reserved                                  dcd             reserved
                                 dcd             0                               ; push_d16                                  dcd                     push_d16
                                 dcd             0                               ; imul_reg_ea_d16                                  dcd                     imul_r_ea_d16
                                 dcd             0                               ; push_d8                                  dcd                     push_d8
                                 dcd             0                               ; imul_reg_ea_d8                                  dcd                     imul_r_ea_d8
                                 dcd             0                               ; insb                                  dcd                     insb
                                 dcd             0                               ; insw                                  dcd                     insw
                                 dcd             0                               ; outsb                                  dcd             outsb
                                 dcd             0                               ; outsw                                  dcd             outsw
   
                                 dcd             jo_short                                  dcd             jo_short                        ; 70
                                 dcd             jno_short                                  dcd             jno_short
                                 dcd             jc_short                                  dcd             jc_short
                                 dcd             jnc_short                                  dcd             jnc_short
Line 1205  optbl1   dcd  add_ea_r8 Line 1845  optbl1   dcd  add_ea_r8
                                 dcd             jns_short                                  dcd             jns_short
                                 dcd             jp_short                                  dcd             jp_short
                                 dcd             jnp_short                                  dcd             jnp_short
                                 dcd             0                               ; jl_short                                  dcd                     jl_short
                                 dcd             0                               ; jnl_short                                  dcd                     jnl_short
                                 dcd             0                               ; jle_short                                  dcd                     jle_short
                                 dcd             0                               ; jnle_short                                  dcd                     jnle_short
   
                                 dcd             0                               ; calc_ea8_i8                                  dcd             i286aop80                       ; 80
                                 dcd             0                               ; calc_ea16_i16                                  dcd             i286aop81
                                 dcd             0                               ; calc_ea8_i8                                  dcd             i286aop80
                                 dcd             0                               ; calc_ea16_i8                                  dcd             i286aop83
                                 dcd             test_ea_r8                                  dcd             test_ea_r8
                                 dcd             test_ea_r16                                  dcd             test_ea_r16
                                 dcd             xchg_ea_r8                                  dcd             xchg_ea_r8
Line 1222  optbl1   dcd  add_ea_r8 Line 1862  optbl1   dcd  add_ea_r8
                                 dcd             mov_ea_r16                                  dcd             mov_ea_r16
                                 dcd             mov_r8_ea                                  dcd             mov_r8_ea
                                 dcd             mov_r16_ea                                  dcd             mov_r16_ea
                                 dcd             0                               ; mov_ea_seg                                  dcd                     mov_ea_seg
                                 dcd             0                               ; lea_r16_ea                                  dcd                     lea_r16_ea
                                 dcd             0                               ; mov_seg_ea                                  dcd                     mov_seg_ea
                                 dcd             0                               ; pop_ea                                  dcd                     pop_ea
   
                                 dcd             0                               ; nop                                  dcd             nopandbios                      ; 90
                                 dcd             xchg_ax_cx                                  dcd             xchg_ax_cx
                                 dcd             xchg_ax_dx                                  dcd             xchg_ax_dx
                                 dcd             xchg_ax_bx                                  dcd             xchg_ax_bx
Line 1237  optbl1   dcd  add_ea_r8 Line 1877  optbl1   dcd  add_ea_r8
                                 dcd             xchg_ax_di                                  dcd             xchg_ax_di
                                 dcd             cbw                                  dcd             cbw
                                 dcd             cwd                                  dcd             cwd
                                 dcd             0                               ; call_far                                  dcd             call_far
                                 dcd             wait                                  dcd             wait
                                 dcd             0                               ; pushf                                  dcd                     pushf
                                 dcd             0                               ; popf                                  dcd                     popf
                                 dcd             sahf                                  dcd             sahf
                                 dcd             lahf                                  dcd             lahf
   
                                 dcd             mov_al_m8                                  dcd             mov_al_m8                       ; a0
                                 dcd             mov_ax_m16                                  dcd             mov_ax_m16
                                 dcd             mov_m8_al                                  dcd             mov_m8_al
                                 dcd             mov_m16_ax                                  dcd             mov_m16_ax
                                 dcd             0                               ; movsb                                  dcd             movsb
                                 dcd             0                               ; movsw                                  dcd             movsw
                                 dcd             0                               ; cmpsb                                  dcd                     cmpsb
                                 dcd             0                               ; cmpsw                                  dcd                     cmpsw
                                 dcd             test_al_d8                                  dcd             test_al_d8
                                 dcd             test_ax_d16                                  dcd             test_ax_d16
                                 dcd             0                               ; stosb                                  dcd             stosb
                                 dcd             0                               ; stosw                                  dcd             stosw
                                 dcd             0                               ; lodsb                                  dcd             lodsb
                                 dcd             0                               ; lodsw                                  dcd             lodsw
                                 dcd             0                               ; scasb                                  dcd             scasb
                                 dcd             0                               ; scasw                                  dcd             scasw
   
                                 dcd             mov_al_imm                                  dcd             mov_al_imm                      ; b0
                                 dcd             mov_cl_imm                                  dcd             mov_cl_imm
                                 dcd             mov_dl_imm                                  dcd             mov_dl_imm
                                 dcd             mov_bl_imm                                  dcd             mov_bl_imm
Line 1278  optbl1   dcd  add_ea_r8 Line 1918  optbl1   dcd  add_ea_r8
                                 dcd             mov_si_imm                                  dcd             mov_si_imm
                                 dcd             mov_di_imm                                  dcd             mov_di_imm
   
                                 dcd             0                               ; shift_ea8_d8                                  dcd             i286asft8_d8            ; c0
                                 dcd             0                               ; shift_ea16_d8                                  dcd             i286asft16_d8
                                 dcd             0                               ; ret_near_d16                                  dcd                     ret_near_d16
                                 dcd             0                               ; ret_near                                  dcd             ret_near
                                 dcd             0                               ; les_r16_ea                                  dcd             0                                       ; les_r16_ea (now testing i286a_a)
                                 dcd             0                               ; lds_r16_ea                                  dcd             0                                       ; lds_r16_ea (now testing i286a_a)
                                 dcd             0                               ; mov_ea8_d8                                  dcd                     mov_ea8_d8
                                 dcd             0                               ; mov_ea16_d16                                  dcd                     mov_ea16_d16
                                 dcd             0                               ; enter                                  dcd             enter
                                 dcd             0                               ; leave                                  dcd             leave
                                 dcd             0                               ; ret_far_d16                                  dcd                     ret_far_d16
                                 dcd             0                               ; ret_far                                  dcd             ret_far
                                 dcd             0                               ; int_03                                  dcd             int_03
                                 dcd             0                               ; int_d8                                  dcd             int_d8
                                 dcd             0                               ; into                                  dcd             into
                                 dcd             0                               ; iret                                  dcd                     iret
   
                                 dcd             0                               ; shift_ea8_1                                  dcd             i286asft8_1                     ; d0
                                 dcd             0                               ; shift_ea16_1                                  dcd             i286asft16_1
                                 dcd             0                               ; shift_ea8_cl                                  dcd             i286asft8_cl
                                 dcd             0                               ; shift_ea16_cl                                  dcd             i286asft16_cl
                                 dcd             0                               ; aam                                  dcd                     aam
                                 dcd             0                               ; aad                                  dcd                     aad
                                 dcd             0                               ; setalc                                  dcd                     setalc
                                 dcd             0                               ; xlat                                  dcd                     xlat
                                 dcd             0                               ; esc0                                  dcd             esc
                                 dcd             0                               ; esc1                                  dcd             esc
                                 dcd             0                               ; esc2                                  dcd             esc
                                 dcd             0                               ; esc3                                  dcd             esc
                                 dcd             0                               ; esc4                                  dcd             esc
                                 dcd             0                               ; esc5                                  dcd             esc
                                 dcd             0                               ; esc6                                  dcd             esc
                                 dcd             0                               ; esc7                                  dcd             esc
   
                                 dcd             0                               ; loopnz                                  dcd             loopnz                          ; e0
                                 dcd             0                               ; loopz                                  dcd             loopz
                                 dcd             0                               ; loop                                  dcd             loop
                                 dcd             0                               ; jcxz                                  dcd             jcxz
                                 dcd             0                               ; in_al_d8                                  dcd                     in_al_d8
                                 dcd             0                               ; in_ax_d8                                  dcd                     in_ax_d8
                                 dcd             0                               ; out_d8_al                                  dcd             out_d8_al
                                 dcd             0                               ; out_d8_ax                                  dcd             out_d8_ax
                                 dcd             0                               ; call_near                                  dcd             call_near
                                 dcd             0                               ; jmp_near                                  dcd             jmp_near
                                 dcd             0                               ; jmp_far                                  dcd             jmp_far
                                 dcd             jmp_short                                  dcd             jmp_short
                                 dcd             0                               ; in_al_dx                                  dcd                     in_al_dx
                                 dcd             0                               ; in_ax_dx                                  dcd                     in_ax_dx
                                 dcd             0                               ; out_dx_al                                  dcd             out_dx_al
                                 dcd             0                               ; out_dx_ax                                  dcd             out_dx_ax
   
                                 dcd             0                               ; lock                                  dcd             lock                            ; f0
                                 dcd             0                               ; lock                                  dcd             lock
                                 dcd             0                               ; repne                                  dcd             0                                       ; repne
                                 dcd             0                               ; repe                                  dcd             0                                       ; repe
                                 dcd             0                               ; hlt                                  dcd             hlt
                                 dcd             0                               ; cmc                                  dcd             cmc
                                 dcd             0                               ; ope0xf6                                  dcd                     i286aopf6
                                 dcd             0                               ; ope0xf7                                  dcd                     i286aopf7
                                 dcd             0                               ; clc                                  dcd             clc
                                 dcd             0                               ; stc                                  dcd             stc
                                 dcd             0                               ; cli                                  dcd             cli
                                 dcd             0                               ; sti                                  dcd                     sti
                                 dcd             0                               ; cld                                  dcd             cld
                                 dcd             0                               ; std                                  dcd             std
                                 dcd             0                               ; ope0xfe                                  dcd             i286aopfe
                                 dcd             0                               ; ope0xff                                  dcd                     i286aopff
   
   
   ; ---- repne
   
   repne                   ldrb    r6, [r9, #CPU_PREFIX]
                                   adr             r4, optblne
                                   add             r0, r5, r8 lsr #16
                                   add             r6, r6, #1
                                   cmp             r6, #MAX_PREFIX
                                   bcs             prefix_fault
                                   bl              i286_memoryread
                                   ldr             r1, [r4, r0 lsl #2]
                                   add             r8, r8, #(1 << 16)
                                   strb    r6, [r9, #CPU_PREFIX]
                                   mov             pc, r1
   
   optblne                 dcd             add_ea_r8                       ; 00
                                   dcd             add_ea_r16
                                   dcd             add_r8_ea
                                   dcd             add_r16_ea
                                   dcd             add_al_d8
                                   dcd             add_ax_d16
                                   dcd             push_es
                                   dcd             pop_es
                                   dcd             or_ea_r8
                                   dcd             or_ea_r16
                                   dcd             or_r8_ea
                                   dcd             or_r16_ea
                                   dcd             or_al_d8
                                   dcd             or_ax_d16
                                   dcd             push_cs
                                   dcd             i286a_cts
   
                                   dcd             adc_ea_r8                       ; 10
                                   dcd             adc_ea_r16
                                   dcd             adc_r8_ea
                                   dcd             adc_r16_ea
                                   dcd             adc_al_d8
                                   dcd             adc_ax_d16
                                   dcd             push_ss
                                   dcd             pop_ss
                                   dcd             sbb_ea_r8
                                   dcd             sbb_ea_r16
                                   dcd             sbb_r8_ea
                                   dcd             sbb_r16_ea
                                   dcd             sbb_al_d8
                                   dcd             sbb_ax_d16
                                   dcd             push_ds
                                   dcd             pop_ds
   
                                   dcd             and_ea_r8                       ; 20
                                   dcd             and_ea_r16
                                   dcd             and_r8_ea
                                   dcd             and_r16_ea
                                   dcd             and_al_d8
                                   dcd             and_ax_d16
                                   dcd             segprefix_es
                                   dcd             daa
                                   dcd             sub_ea_r8
                                   dcd             sub_ea_r16
                                   dcd             sub_r8_ea
                                   dcd             sub_r16_ea
                                   dcd             sub_al_d8
                                   dcd             sub_ax_d16
                                   dcd             segprefix_cs
                                   dcd             das
   
                                   dcd             xor_ea_r8                       ; 30
                                   dcd             xor_ea_r16
                                   dcd             xor_r8_ea
                                   dcd             xor_r16_ea
                                   dcd             xor_al_d8
                                   dcd             xor_ax_d16
                                   dcd             segprefix_ss
                                   dcd             aaa
                                   dcd             cmp_ea_r8
                                   dcd             cmp_ea_r16
                                   dcd             cmp_r8_ea
                                   dcd             cmp_r16_ea
                                   dcd             cmp_al_d8
                                   dcd             cmp_ax_d16
                                   dcd             segprefix_ds
                                   dcd             aas
   
                                   dcd             inc_ax                          ; 40
                                   dcd             inc_cx
                                   dcd             inc_dx
                                   dcd             inc_bx
                                   dcd             inc_sp
                                   dcd             inc_bp
                                   dcd             inc_si
                                   dcd             inc_di
                                   dcd             dec_ax
                                   dcd             dec_cx
                                   dcd             dec_dx
                                   dcd             dec_bx
                                   dcd             dec_sp
                                   dcd             dec_bp
                                   dcd             dec_si
                                   dcd             dec_di
   
                                   dcd             push_ax                         ; 50
                                   dcd             push_cx
                                   dcd             push_dx
                                   dcd             push_bx
                                   dcd             push_sp
                                   dcd             push_bp
                                   dcd             push_si
                                   dcd             push_di
                                   dcd             pop_ax
                                   dcd             pop_cx
                                   dcd             pop_dx
                                   dcd             pop_bx
                                   dcd             pop_sp
                                   dcd             pop_bp
                                   dcd             pop_si
                                   dcd             pop_di
   
                                   dcd             pusha                           ; 60
                                   dcd             popa
                                   dcd             bound
                                   dcd             reserved                        ; arpl(reserved)
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             push_d16
                                   dcd             imul_r_ea_d16
                                   dcd             push_d8
                                   dcd             imul_r_ea_d8
                                   dcd             0 ; i286a_rep_insb
                                   dcd             0 ; i286a_rep_insw
                                   dcd             0 ; i286a_rep_outsb
                                   dcd             0 ; i286a_rep_outsw
   
                                   dcd             jo_short                        ; 70
                                   dcd             jno_short
                                   dcd             jc_short
                                   dcd             jnc_short
                                   dcd             jz_short
                                   dcd             jnz_short
                                   dcd             jna_short
                                   dcd             ja_short
                                   dcd             js_short
                                   dcd             jns_short
                                   dcd             jp_short
                                   dcd             jnp_short
                                   dcd             jl_short
                                   dcd             jnl_short
                                   dcd             jle_short
                                   dcd             jnle_short
   
                                   dcd             i286aop80                       ; 80
                                   dcd             i286aop81
                                   dcd             i286aop80
                                   dcd             i286aop83
                                   dcd             test_ea_r8
                                   dcd             test_ea_r16
                                   dcd             xchg_ea_r8
                                   dcd             xchg_ea_r16
                                   dcd             mov_ea_r8
                                   dcd             mov_ea_r16
                                   dcd             mov_r8_ea
                                   dcd             mov_r16_ea
                                   dcd             mov_ea_seg
                                   dcd             lea_r16_ea
                                   dcd             mov_seg_ea
                                   dcd             pop_ea
   
                                   dcd             nopandbios                      ; 90
                                   dcd             xchg_ax_cx
                                   dcd             xchg_ax_dx
                                   dcd             xchg_ax_bx
                                   dcd             xchg_ax_sp
                                   dcd             xchg_ax_bp
                                   dcd             xchg_ax_si
                                   dcd             xchg_ax_di
                                   dcd             cbw
                                   dcd             cwd
                                   dcd             call_far
                                   dcd             wait
                                   dcd             pushf
                                   dcd             popf
                                   dcd             sahf
                                   dcd             lahf
   
                                   dcd             mov_al_m8                       ; a0
                                   dcd             mov_ax_m16
                                   dcd             mov_m8_al
                                   dcd             mov_m16_ax
                                   dcd             0 ; i286a_rep_movsb
                                   dcd             0 ; i286a_rep_movsw
                                   dcd             0 ; i286a_repne_cmpsb
                                   dcd             0 ; i286a_repne_cmpsw
                                   dcd             test_al_d8
                                   dcd             test_ax_d16
                                   dcd             0 ; i286a_rep_stosb
                                   dcd             0 ; i286a_rep_stosw
                                   dcd             0 ; i286a_rep_lodsb
                                   dcd             0 ; i286a_rep_lodsw
                                   dcd             0 ; i286a_repne_scasb
                                   dcd             0 ; i286a_repne_scasw
   
                                   dcd             mov_al_imm                      ; b0
                                   dcd             mov_cl_imm
                                   dcd             mov_dl_imm
                                   dcd             mov_bl_imm
                                   dcd             mov_ah_imm
                                   dcd             mov_ch_imm
                                   dcd             mov_dh_imm
                                   dcd             mov_bh_imm
                                   dcd             mov_ax_imm
                                   dcd             mov_cx_imm
                                   dcd             mov_dx_imm
                                   dcd             mov_bx_imm
                                   dcd             mov_sp_imm
                                   dcd             mov_bp_imm
                                   dcd             mov_si_imm
                                   dcd             mov_di_imm
   
                                   dcd             i286asft8_d8            ; c0
                                   dcd             i286asft16_d8
                                   dcd             ret_near_d16
                                   dcd             ret_near
                                   dcd             les_r16_ea
                                   dcd             lds_r16_ea
                                   dcd             mov_ea8_d8
                                   dcd             mov_ea16_d16
                                   dcd             enter
                                   dcd             leave
                                   dcd             ret_far_d16
                                   dcd             ret_far
                                   dcd             int_03
                                   dcd             int_d8
                                   dcd             into
                                   dcd             iret
   
                                   dcd             i286asft8_1                     ; d0
                                   dcd             i286asft16_1
                                   dcd             i286asft8_cl
                                   dcd             i286asft16_cl
                                   dcd             aam
                                   dcd             aad
                                   dcd             setalc
                                   dcd             xlat
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
   
                                   dcd             loopnz                          ; e0
                                   dcd             loopz
                                   dcd             loop
                                   dcd             jcxz
                                   dcd             in_al_d8
                                   dcd             in_ax_d8
                                   dcd             out_d8_al
                                   dcd             out_d8_ax
                                   dcd             call_near
                                   dcd             jmp_near
                                   dcd             jmp_far
                                   dcd             jmp_short
                                   dcd             in_al_dx
                                   dcd             in_ax_dx
                                   dcd             out_dx_al
                                   dcd             out_dx_ax
   
                                   dcd             lock                            ; f0
                                   dcd             lock
                                   dcd             repne
                                   dcd             repe
                                   dcd             hlt
                                   dcd             cmc
                                   dcd             i286aopf6
                                   dcd             i286aopf7
                                   dcd             clc
                                   dcd             stc
                                   dcd             cli
                                   dcd             sti
                                   dcd             cld
                                   dcd             std
                                   dcd             i286aopfe
                                   dcd             i286aopff
   
   ; ---- repe
   
   repe                    ldrb    r6, [r9, #CPU_PREFIX]
                                   adr             r4, optble
                                   add             r0, r5, r8 lsr #16
                                   add             r6, r6, #1
                                   cmp             r6, #MAX_PREFIX
                                   bcs             prefix_fault
                                   bl              i286_memoryread
                                   ldr             r1, [r4, r0 lsl #2]
                                   add             r8, r8, #(1 << 16)
                                   strb    r6, [r9, #CPU_PREFIX]
                                   mov             pc, r1
   
   optble                  dcd             add_ea_r8                       ; 00
                                   dcd             add_ea_r16
                                   dcd             add_r8_ea
                                   dcd             add_r16_ea
                                   dcd             add_al_d8
                                   dcd             add_ax_d16
                                   dcd             push_es
                                   dcd             pop_es
                                   dcd             or_ea_r8
                                   dcd             or_ea_r16
                                   dcd             or_r8_ea
                                   dcd             or_r16_ea
                                   dcd             or_al_d8
                                   dcd             or_ax_d16
                                   dcd             push_cs
                                   dcd             i286a_cts
   
                                   dcd             adc_ea_r8                       ; 10
                                   dcd             adc_ea_r16
                                   dcd             adc_r8_ea
                                   dcd             adc_r16_ea
                                   dcd             adc_al_d8
                                   dcd             adc_ax_d16
                                   dcd             push_ss
                                   dcd             pop_ss
                                   dcd             sbb_ea_r8
                                   dcd             sbb_ea_r16
                                   dcd             sbb_r8_ea
                                   dcd             sbb_r16_ea
                                   dcd             sbb_al_d8
                                   dcd             sbb_ax_d16
                                   dcd             push_ds
                                   dcd             pop_ds
   
                                   dcd             and_ea_r8                       ; 20
                                   dcd             and_ea_r16
                                   dcd             and_r8_ea
                                   dcd             and_r16_ea
                                   dcd             and_al_d8
                                   dcd             and_ax_d16
                                   dcd             segprefix_es
                                   dcd             daa
                                   dcd             sub_ea_r8
                                   dcd             sub_ea_r16
                                   dcd             sub_r8_ea
                                   dcd             sub_r16_ea
                                   dcd             sub_al_d8
                                   dcd             sub_ax_d16
                                   dcd             segprefix_cs
                                   dcd             das
   
                                   dcd             xor_ea_r8                       ; 30
                                   dcd             xor_ea_r16
                                   dcd             xor_r8_ea
                                   dcd             xor_r16_ea
                                   dcd             xor_al_d8
                                   dcd             xor_ax_d16
                                   dcd             segprefix_ss
                                   dcd             aaa
                                   dcd             cmp_ea_r8
                                   dcd             cmp_ea_r16
                                   dcd             cmp_r8_ea
                                   dcd             cmp_r16_ea
                                   dcd             cmp_al_d8
                                   dcd             cmp_ax_d16
                                   dcd             segprefix_ds
                                   dcd             aas
   
                                   dcd             inc_ax                          ; 40
                                   dcd             inc_cx
                                   dcd             inc_dx
                                   dcd             inc_bx
                                   dcd             inc_sp
                                   dcd             inc_bp
                                   dcd             inc_si
                                   dcd             inc_di
                                   dcd             dec_ax
                                   dcd             dec_cx
                                   dcd             dec_dx
                                   dcd             dec_bx
                                   dcd             dec_sp
                                   dcd             dec_bp
                                   dcd             dec_si
                                   dcd             dec_di
   
                                   dcd             push_ax                         ; 50
                                   dcd             push_cx
                                   dcd             push_dx
                                   dcd             push_bx
                                   dcd             push_sp
                                   dcd             push_bp
                                   dcd             push_si
                                   dcd             push_di
                                   dcd             pop_ax
                                   dcd             pop_cx
                                   dcd             pop_dx
                                   dcd             pop_bx
                                   dcd             pop_sp
                                   dcd             pop_bp
                                   dcd             pop_si
                                   dcd             pop_di
   
                                   dcd             pusha                           ; 60
                                   dcd             popa
                                   dcd             bound
                                   dcd             reserved                        ; arpl(reserved)
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             reserved
                                   dcd             push_d16
                                   dcd             imul_r_ea_d16
                                   dcd             push_d8
                                   dcd             imul_r_ea_d8
                                   dcd             0 ; i286a_rep_insb
                                   dcd             0 ; i286a_rep_insw
                                   dcd             0 ; i286a_rep_outsb
                                   dcd             0 ; i286a_rep_outsw
   
                                   dcd             jo_short                        ; 70
                                   dcd             jno_short
                                   dcd             jc_short
                                   dcd             jnc_short
                                   dcd             jz_short
                                   dcd             jnz_short
                                   dcd             jna_short
                                   dcd             ja_short
                                   dcd             js_short
                                   dcd             jns_short
                                   dcd             jp_short
                                   dcd             jnp_short
                                   dcd             jl_short
                                   dcd             jnl_short
                                   dcd             jle_short
                                   dcd             jnle_short
   
                                   dcd             i286aop80                       ; 80
                                   dcd             i286aop81
                                   dcd             i286aop80
                                   dcd             i286aop83
                                   dcd             test_ea_r8
                                   dcd             test_ea_r16
                                   dcd             xchg_ea_r8
                                   dcd             xchg_ea_r16
                                   dcd             mov_ea_r8
                                   dcd             mov_ea_r16
                                   dcd             mov_r8_ea
                                   dcd             mov_r16_ea
                                   dcd             mov_ea_seg
                                   dcd             lea_r16_ea
                                   dcd             mov_seg_ea
                                   dcd             pop_ea
   
                                   dcd             nopandbios                      ; 90
                                   dcd             xchg_ax_cx
                                   dcd             xchg_ax_dx
                                   dcd             xchg_ax_bx
                                   dcd             xchg_ax_sp
                                   dcd             xchg_ax_bp
                                   dcd             xchg_ax_si
                                   dcd             xchg_ax_di
                                   dcd             cbw
                                   dcd             cwd
                                   dcd             call_far
                                   dcd             wait
                                   dcd             pushf
                                   dcd             popf
                                   dcd             sahf
                                   dcd             lahf
   
                                   dcd             mov_al_m8                       ; a0
                                   dcd             mov_ax_m16
                                   dcd             mov_m8_al
                                   dcd             mov_m16_ax
                                   dcd             0 ; i286a_rep_movsb
                                   dcd             0 ; i286a_rep_movsw
                                   dcd             0 ; i286a_repe_cmpsb
                                   dcd             0 ; i286a_repe_cmpsw
                                   dcd             test_al_d8
                                   dcd             test_ax_d16
                                   dcd             0 ; i286a_rep_stosb
                                   dcd             0 ; i286a_rep_stosw
                                   dcd             0 ; i286a_rep_lodsb
                                   dcd             0 ; i286a_rep_lodsw
                                   dcd             0 ; i286a_repe_scasb
                                   dcd             0 ; i286a_repe_scasw
   
                                   dcd             mov_al_imm                      ; b0
                                   dcd             mov_cl_imm
                                   dcd             mov_dl_imm
                                   dcd             mov_bl_imm
                                   dcd             mov_ah_imm
                                   dcd             mov_ch_imm
                                   dcd             mov_dh_imm
                                   dcd             mov_bh_imm
                                   dcd             mov_ax_imm
                                   dcd             mov_cx_imm
                                   dcd             mov_dx_imm
                                   dcd             mov_bx_imm
                                   dcd             mov_sp_imm
                                   dcd             mov_bp_imm
                                   dcd             mov_si_imm
                                   dcd             mov_di_imm
   
                                   dcd             i286asft8_d8            ; c0
                                   dcd             i286asft16_d8
                                   dcd             ret_near_d16
                                   dcd             ret_near
                                   dcd             les_r16_ea
                                   dcd             lds_r16_ea
                                   dcd             mov_ea8_d8
                                   dcd             mov_ea16_d16
                                   dcd             enter
                                   dcd             leave
                                   dcd             ret_far_d16
                                   dcd             ret_far
                                   dcd             int_03
                                   dcd             int_d8
                                   dcd             into
                                   dcd             iret
   
                                   dcd             i286asft8_1                     ; d0
                                   dcd             i286asft16_1
                                   dcd             i286asft8_cl
                                   dcd             i286asft16_cl
                                   dcd             aam
                                   dcd             aad
                                   dcd             setalc
                                   dcd             xlat
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
                                   dcd             esc
   
                                   dcd             loopnz                          ; e0
                                   dcd             loopz
                                   dcd             loop
                                   dcd             jcxz
                                   dcd             in_al_d8
                                   dcd             in_ax_d8
                                   dcd             out_d8_al
                                   dcd             out_d8_ax
                                   dcd             call_near
                                   dcd             jmp_near
                                   dcd             jmp_far
                                   dcd             jmp_short
                                   dcd             in_al_dx
                                   dcd             in_ax_dx
                                   dcd             out_dx_al
                                   dcd             out_dx_ax
   
                                   dcd             lock                            ; f0
                                   dcd             lock
                                   dcd             repne
                                   dcd             repe
                                   dcd             hlt
                                   dcd             cmc
                                   dcd             i286aopf6
                                   dcd             i286aopf7
                                   dcd             clc
                                   dcd             stc
                                   dcd             cli
                                   dcd             sti
                                   dcd             cld
                                   dcd             std
                                   dcd             i286aopfe
                                   dcd             i286aopff
   
         END          END
   

Removed from v.1.2  
changed lines
  Added in v.1.8


RetroPC.NET-CVS <cvs@retropc.net>