(* INHERENT = nessun operando (H implicito) *)
| MODE_INHH : instr_mode
+ (* INHERENT_ADDRESS = nessun operando (HX implicito) *)
+| MODE_INHX0ADD : instr_mode
+ (* INHERENT_ADDRESS = nessun operando (HX implicito+0x00bb) *)
+| MODE_INHX1ADD : instr_mode
+ (* INHERENT_ADDRESS = nessun operando (HX implicito+0xwwww) *)
+| MODE_INHX2ADD : instr_mode
+
(* IMMEDIATE = operando valore immediato byte = 0xbb *)
| MODE_IMM1 : instr_mode
+ (* IMMEDIATE_EXT = operando valore immediato byte = 0xbb -> esteso a word *)
+| MODE_IMM1EXT : instr_mode
(* IMMEDIATE = operando valore immediato word = 0xwwww *)
| MODE_IMM2 : instr_mode
(* DIRECT = operando offset byte = [0x00bb] *)
| MODE_INHA ⇒ 〈x0,x1〉
| MODE_INHX ⇒ 〈x0,x2〉
| MODE_INHH ⇒ 〈x0,x3〉
-
-| MODE_IMM1 ⇒ 〈x0,x4〉
-| MODE_IMM2 ⇒ 〈x0,x5〉
-| MODE_DIR1 ⇒ 〈x0,x6〉
-| MODE_DIR2 ⇒ 〈x0,x7〉
-| MODE_IX0 ⇒ 〈x0,x8〉
-| MODE_IX1 ⇒ 〈x0,x9〉
-| MODE_IX2 ⇒ 〈x0,xA〉
-| MODE_SP1 ⇒ 〈x0,xB〉
-| MODE_SP2 ⇒ 〈x0,xC〉
-
-| MODE_DIR1_to_DIR1 ⇒ 〈x0,xD〉
-| MODE_IMM1_to_DIR1 ⇒ 〈x0,xE〉
-| MODE_IX0p_to_DIR1 ⇒ 〈x0,xF〉
-| MODE_DIR1_to_IX0p ⇒ 〈x1,x0〉
-
-| MODE_INHA_and_IMM1 ⇒ 〈x1,x1〉
-| MODE_INHX_and_IMM1 ⇒ 〈x1,x2〉
-| MODE_IMM1_and_IMM1 ⇒ 〈x1,x3〉
-| MODE_DIR1_and_IMM1 ⇒ 〈x1,x4〉
-| MODE_IX0_and_IMM1 ⇒ 〈x1,x5〉
-| MODE_IX0p_and_IMM1 ⇒ 〈x1,x6〉
-| MODE_IX1_and_IMM1 ⇒ 〈x1,x7〉
-| MODE_IX1p_and_IMM1 ⇒ 〈x1,x8〉
-| MODE_SP1_and_IMM1 ⇒ 〈x1,x9〉
-
- (* 26-33: bisogna considerare l'operando implicito *)
-| MODE_DIRn o ⇒ plus_b8nc 〈x1,xA〉 〈x0,(exadecim_of_oct o)〉
- (* 34-41: bisogna considerare l'operando implicito *)
-| MODE_DIRn_and_IMM1 o ⇒ plus_b8nc 〈x2,x2〉 〈x0,(exadecim_of_oct o)〉
- (* 42-57: bisogna considerare l'operando implicito *)
-| MODE_TNY e ⇒ plus_b8nc 〈x2,xA〉 〈x0,e〉
- (* 58-99: bisogna considerare gli operandi impliciti *)
-| MODE_SRT t ⇒ plus_b8nc 〈x3,xA〉 (byte8_of_bitrigesim t)
+
+| MODE_INHX0ADD ⇒ 〈x0,x4〉
+| MODE_INHX1ADD ⇒ 〈x0,x5〉
+| MODE_INHX2ADD ⇒ 〈x0,x6〉
+
+| MODE_IMM1 ⇒ 〈x0,x7〉
+| MODE_IMM1EXT ⇒ 〈x0,x8〉
+| MODE_IMM2 ⇒ 〈x0,x9〉
+| MODE_DIR1 ⇒ 〈x0,xA〉
+| MODE_DIR2 ⇒ 〈x0,xB〉
+| MODE_IX0 ⇒ 〈x0,xC〉
+| MODE_IX1 ⇒ 〈x0,xD〉
+| MODE_IX2 ⇒ 〈x0,xE〉
+| MODE_SP1 ⇒ 〈x0,xF〉
+| MODE_SP2 ⇒ 〈x1,x0〉
+
+| MODE_DIR1_to_DIR1 ⇒ 〈x1,x1〉
+| MODE_IMM1_to_DIR1 ⇒ 〈x1,x2〉
+| MODE_IX0p_to_DIR1 ⇒ 〈x1,x3〉
+| MODE_DIR1_to_IX0p ⇒ 〈x1,x4〉
+
+| MODE_INHA_and_IMM1 ⇒ 〈x1,x5〉
+| MODE_INHX_and_IMM1 ⇒ 〈x1,x6〉
+| MODE_IMM1_and_IMM1 ⇒ 〈x1,x7〉
+| MODE_DIR1_and_IMM1 ⇒ 〈x1,x8〉
+| MODE_IX0_and_IMM1 ⇒ 〈x1,x9〉
+| MODE_IX0p_and_IMM1 ⇒ 〈x1,xA〉
+| MODE_IX1_and_IMM1 ⇒ 〈x1,xB〉
+| MODE_IX1p_and_IMM1 ⇒ 〈x1,xC〉
+| MODE_SP1_and_IMM1 ⇒ 〈x1,xD〉
+
+ (* 27-34: bisogna considerare l'operando implicito *)
+| MODE_DIRn o ⇒ plus_b8nc 〈x1,xE〉 〈x0,(exadecim_of_oct o)〉
+ (* 35-42: bisogna considerare l'operando implicito *)
+| MODE_DIRn_and_IMM1 o ⇒ plus_b8nc 〈x2,x6〉 〈x0,(exadecim_of_oct o)〉
+ (* 43-58: bisogna considerare l'operando implicito *)
+| MODE_TNY e ⇒ plus_b8nc 〈x2,xE〉 〈x0,e〉
+ (* 59-100: bisogna considerare gli operandi impliciti *)
+| MODE_SRT t ⇒ plus_b8nc 〈x3,xE〉 (byte8_of_bitrigesim t)
].
(* confronto fra instr_mode *)
(* iteratore sulle modalita' *)
definition forall_instr_mode ≝ λP.
P MODE_INH
-⊗ P MODE_INHA
-⊗ P MODE_INHX
+⊗ P MODE_INHA
+⊗ P MODE_INHX
⊗ P MODE_INHH
-⊗ P MODE_IMM1
-⊗ P MODE_IMM2
-⊗ P MODE_DIR1
+⊗ P MODE_INHX0ADD
+⊗ P MODE_INHX1ADD
+⊗ P MODE_INHX2ADD
+
+⊗ P MODE_IMM1
+⊗ P MODE_IMM1EXT
+⊗ P MODE_IMM2
+⊗ P MODE_DIR1
⊗ P MODE_DIR2
-⊗ P MODE_IX0
-⊗ P MODE_IX1
-⊗ P MODE_IX2
-⊗ P MODE_SP1
+⊗ P MODE_IX0
+⊗ P MODE_IX1
+⊗ P MODE_IX2
+⊗ P MODE_SP1
⊗ P MODE_SP2
-⊗ P MODE_DIR1_to_DIR1
+⊗ P MODE_DIR1_to_DIR1
⊗ P MODE_IMM1_to_DIR1
-⊗ P MODE_IX0p_to_DIR1
+⊗ P MODE_IX0p_to_DIR1
⊗ P MODE_DIR1_to_IX0p
-⊗ P MODE_INHA_and_IMM1
-⊗ P MODE_INHX_and_IMM1
+⊗ P MODE_INHA_and_IMM1
+⊗ P MODE_INHX_and_IMM1
⊗ P MODE_IMM1_and_IMM1
-⊗ P MODE_DIR1_and_IMM1
-⊗ P MODE_IX0_and_IMM1
+⊗ P MODE_DIR1_and_IMM1
+⊗ P MODE_IX0_and_IMM1
⊗ P MODE_IX0p_and_IMM1
-⊗ P MODE_IX1_and_IMM1
-⊗ P MODE_IX1p_and_IMM1
+⊗ P MODE_IX1_and_IMM1
+⊗ P MODE_IX1p_and_IMM1
⊗ P MODE_SP1_and_IMM1
⊗ forall_oct (λo. P (MODE_DIRn o))