+#if WITH_SEM_SWITCH_FAST
+#ifdef __GNUC__
+ void *sem_fast_lab;
+#endif
+#else
+ SEMANTIC_FN *sem_fast;
+#endif
+
+ /* Instruction number (index in IDESC table, profile table).
+ Also used to switch on in non-gcc semantic switches. */
+ int num;
+
+ /* opcode table data */
+ const CGEN_INSN *opcode;
+
+ /* profiling/modelling support */
+ const INSN_TIMING *timing;
+};
+
+extern const IDESC *m32rxf_decode (SIM_CPU *, IADDR,
+ CGEN_INSN_INT, CGEN_INSN_INT,
+ ARGBUF *);
+
+/* Enum declaration for instructions in cpu family m32rxf. */
+typedef enum m32rxf_insn_type {
+ M32RXF_INSN_X_INVALID, M32RXF_INSN_X_AFTER, M32RXF_INSN_X_BEFORE, M32RXF_INSN_X_CTI_CHAIN
+ , M32RXF_INSN_X_CHAIN, M32RXF_INSN_X_BEGIN, M32RXF_INSN_ADD, M32RXF_INSN_ADD3
+ , M32RXF_INSN_AND, M32RXF_INSN_AND3, M32RXF_INSN_OR, M32RXF_INSN_OR3
+ , M32RXF_INSN_XOR, M32RXF_INSN_XOR3, M32RXF_INSN_ADDI, M32RXF_INSN_ADDV
+ , M32RXF_INSN_ADDV3, M32RXF_INSN_ADDX, M32RXF_INSN_BC8, M32RXF_INSN_BC24
+ , M32RXF_INSN_BEQ, M32RXF_INSN_BEQZ, M32RXF_INSN_BGEZ, M32RXF_INSN_BGTZ
+ , M32RXF_INSN_BLEZ, M32RXF_INSN_BLTZ, M32RXF_INSN_BNEZ, M32RXF_INSN_BL8
+ , M32RXF_INSN_BL24
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_BCL8
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_BCL24
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_BNC8, M32RXF_INSN_BNC24, M32RXF_INSN_BNE, M32RXF_INSN_BRA8
+ , M32RXF_INSN_BRA24
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_BNCL8
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_BNCL24
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_CMP, M32RXF_INSN_CMPI, M32RXF_INSN_CMPU, M32RXF_INSN_CMPUI
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_CMPEQ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_CMPZ
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_DIV, M32RXF_INSN_DIVU, M32RXF_INSN_REM, M32RXF_INSN_REMU
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_DIVH
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_JC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_JNC
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_JL, M32RXF_INSN_JMP, M32RXF_INSN_LD, M32RXF_INSN_LD_D
+ , M32RXF_INSN_LDB, M32RXF_INSN_LDB_D, M32RXF_INSN_LDH, M32RXF_INSN_LDH_D
+ , M32RXF_INSN_LDUB, M32RXF_INSN_LDUB_D, M32RXF_INSN_LDUH, M32RXF_INSN_LDUH_D
+ , M32RXF_INSN_LD_PLUS, M32RXF_INSN_LD24, M32RXF_INSN_LDI8, M32RXF_INSN_LDI16
+ , M32RXF_INSN_LOCK
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACWLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_MUL
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MULHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MULLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MULWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MULWLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_MV
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MVFACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MVFACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MVFACMI_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_MVFC
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MVTACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MVTACLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_MVTC, M32RXF_INSN_NEG, M32RXF_INSN_NOP, M32RXF_INSN_NOT
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_RAC_DSI
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_RACH_DSI
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_RTE, M32RXF_INSN_SETH, M32RXF_INSN_SLL, M32RXF_INSN_SLL3
+ , M32RXF_INSN_SLLI, M32RXF_INSN_SRA, M32RXF_INSN_SRA3, M32RXF_INSN_SRAI
+ , M32RXF_INSN_SRL, M32RXF_INSN_SRL3, M32RXF_INSN_SRLI, M32RXF_INSN_ST
+ , M32RXF_INSN_ST_D, M32RXF_INSN_STB, M32RXF_INSN_STB_D, M32RXF_INSN_STH
+ , M32RXF_INSN_STH_D, M32RXF_INSN_ST_PLUS, M32RXF_INSN_ST_MINUS, M32RXF_INSN_SUB
+ , M32RXF_INSN_SUBV, M32RXF_INSN_SUBX, M32RXF_INSN_TRAP, M32RXF_INSN_UNLOCK
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SATB
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SATH
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SAT
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PCMPBZ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SADD
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MSBLO
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MULWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_MACLH1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_SNC
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_ADD, M32RXF_INSN_WRITE_ADD, M32RXF_INSN_PAR_AND, M32RXF_INSN_WRITE_AND
+ , M32RXF_INSN_PAR_OR, M32RXF_INSN_WRITE_OR, M32RXF_INSN_PAR_XOR, M32RXF_INSN_WRITE_XOR
+ , M32RXF_INSN_PAR_ADDI, M32RXF_INSN_WRITE_ADDI, M32RXF_INSN_PAR_ADDV, M32RXF_INSN_WRITE_ADDV
+ , M32RXF_INSN_PAR_ADDX, M32RXF_INSN_WRITE_ADDX, M32RXF_INSN_PAR_BC8, M32RXF_INSN_WRITE_BC8
+ , M32RXF_INSN_PAR_BL8, M32RXF_INSN_WRITE_BL8
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_BCL8
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_BCL8
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_BNC8, M32RXF_INSN_WRITE_BNC8, M32RXF_INSN_PAR_BRA8, M32RXF_INSN_WRITE_BRA8
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_BNCL8
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_BNCL8
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_CMP, M32RXF_INSN_WRITE_CMP, M32RXF_INSN_PAR_CMPU, M32RXF_INSN_WRITE_CMPU
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_CMPEQ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_CMPEQ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_CMPZ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_CMPZ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_JC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_JC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_JNC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_JNC
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_JL, M32RXF_INSN_WRITE_JL, M32RXF_INSN_PAR_JMP, M32RXF_INSN_WRITE_JMP
+ , M32RXF_INSN_PAR_LD, M32RXF_INSN_WRITE_LD, M32RXF_INSN_PAR_LDB, M32RXF_INSN_WRITE_LDB
+ , M32RXF_INSN_PAR_LDH, M32RXF_INSN_WRITE_LDH, M32RXF_INSN_PAR_LDUB, M32RXF_INSN_WRITE_LDUB
+ , M32RXF_INSN_PAR_LDUH, M32RXF_INSN_WRITE_LDUH, M32RXF_INSN_PAR_LD_PLUS, M32RXF_INSN_WRITE_LD_PLUS
+ , M32RXF_INSN_PAR_LDI8, M32RXF_INSN_WRITE_LDI8, M32RXF_INSN_PAR_LOCK, M32RXF_INSN_WRITE_LOCK
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACWLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACWLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MUL, M32RXF_INSN_WRITE_MUL
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MULHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MULHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MULLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MULLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MULWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MULWHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MULWLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MULWLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MV, M32RXF_INSN_WRITE_MV
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVFACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MVFACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVFACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MVFACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVFACMI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MVFACMI_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVFC, M32RXF_INSN_WRITE_MVFC
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVTACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MVTACHI_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVTACLO_A
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MVTACLO_A
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MVTC, M32RXF_INSN_WRITE_MVTC, M32RXF_INSN_PAR_NEG, M32RXF_INSN_WRITE_NEG
+ , M32RXF_INSN_PAR_NOP, M32RXF_INSN_WRITE_NOP, M32RXF_INSN_PAR_NOT, M32RXF_INSN_WRITE_NOT
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_RAC_DSI
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_RAC_DSI
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_RACH_DSI
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_RACH_DSI
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_PAR_RTE, M32RXF_INSN_WRITE_RTE, M32RXF_INSN_PAR_SLL, M32RXF_INSN_WRITE_SLL
+ , M32RXF_INSN_PAR_SLLI, M32RXF_INSN_WRITE_SLLI, M32RXF_INSN_PAR_SRA, M32RXF_INSN_WRITE_SRA
+ , M32RXF_INSN_PAR_SRAI, M32RXF_INSN_WRITE_SRAI, M32RXF_INSN_PAR_SRL, M32RXF_INSN_WRITE_SRL
+ , M32RXF_INSN_PAR_SRLI, M32RXF_INSN_WRITE_SRLI, M32RXF_INSN_PAR_ST, M32RXF_INSN_WRITE_ST
+ , M32RXF_INSN_PAR_STB, M32RXF_INSN_WRITE_STB, M32RXF_INSN_PAR_STH, M32RXF_INSN_WRITE_STH
+ , M32RXF_INSN_PAR_ST_PLUS, M32RXF_INSN_WRITE_ST_PLUS, M32RXF_INSN_PAR_ST_MINUS, M32RXF_INSN_WRITE_ST_MINUS
+ , M32RXF_INSN_PAR_SUB, M32RXF_INSN_WRITE_SUB, M32RXF_INSN_PAR_SUBV, M32RXF_INSN_WRITE_SUBV
+ , M32RXF_INSN_PAR_SUBX, M32RXF_INSN_WRITE_SUBX, M32RXF_INSN_PAR_TRAP, M32RXF_INSN_WRITE_TRAP
+ , M32RXF_INSN_PAR_UNLOCK, M32RXF_INSN_WRITE_UNLOCK
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_PCMPBZ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_PCMPBZ
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_SADD
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_SADD
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MSBLO
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MSBLO
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MULWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MULWU1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_MACLH1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_MACLH1
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_SC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_SC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_PAR_SNC
+/* end-sanitize-m32rx */
+/* start-sanitize-m32rx */
+ , M32RXF_INSN_WRITE_SNC
+/* end-sanitize-m32rx */
+ , M32RXF_INSN_MAX
+} M32RXF_INSN_TYPE;
+
+#if ! WITH_SEM_SWITCH_FULL
+#define SEMFULL(fn) extern SEMANTIC_FN CONCAT3 (m32rxf,_sem_,fn);
+#else
+#define SEMFULL(fn)
+#endif
+
+#if ! WITH_SEM_SWITCH_FAST
+#define SEMFAST(fn) extern SEMANTIC_FN CONCAT3 (m32rxf,_semf_,fn);
+#else
+#define SEMFAST(fn)
+#endif
+
+#define SEM(fn) SEMFULL (fn) SEMFAST (fn)
+
+/* The function version of the before/after handlers is always needed,
+ so we always want the SEMFULL declaration of them. */
+extern SEMANTIC_FN CONCAT3 (m32rxf,_sem_,x_before);
+extern SEMANTIC_FN CONCAT3 (m32rxf,_sem_,x_after);
+
+SEM (x_invalid)
+SEM (x_after)
+SEM (x_before)
+SEM (x_cti_chain)
+SEM (x_chain)
+SEM (x_begin)
+SEM (add)
+SEM (add3)
+SEM (and)
+SEM (and3)
+SEM (or)
+SEM (or3)
+SEM (xor)
+SEM (xor3)
+SEM (addi)
+SEM (addv)
+SEM (addv3)
+SEM (addx)
+SEM (bc8)
+SEM (bc24)
+SEM (beq)
+SEM (beqz)
+SEM (bgez)
+SEM (bgtz)
+SEM (blez)
+SEM (bltz)
+SEM (bnez)
+SEM (bl8)
+SEM (bl24)
+SEM (bcl8)
+SEM (bcl24)
+SEM (bnc8)
+SEM (bnc24)
+SEM (bne)
+SEM (bra8)
+SEM (bra24)
+SEM (bncl8)
+SEM (bncl24)
+SEM (cmp)
+SEM (cmpi)
+SEM (cmpu)
+SEM (cmpui)
+SEM (cmpeq)
+SEM (cmpz)
+SEM (div)
+SEM (divu)
+SEM (rem)
+SEM (remu)
+SEM (divh)
+SEM (jc)
+SEM (jnc)
+SEM (jl)
+SEM (jmp)
+SEM (ld)
+SEM (ld_d)
+SEM (ldb)
+SEM (ldb_d)
+SEM (ldh)
+SEM (ldh_d)
+SEM (ldub)
+SEM (ldub_d)
+SEM (lduh)
+SEM (lduh_d)
+SEM (ld_plus)
+SEM (ld24)
+SEM (ldi8)
+SEM (ldi16)
+SEM (lock)
+SEM (machi_a)
+SEM (maclo_a)
+SEM (macwhi_a)
+SEM (macwlo_a)
+SEM (mul)
+SEM (mulhi_a)
+SEM (mullo_a)
+SEM (mulwhi_a)
+SEM (mulwlo_a)
+SEM (mv)
+SEM (mvfachi_a)
+SEM (mvfaclo_a)
+SEM (mvfacmi_a)
+SEM (mvfc)
+SEM (mvtachi_a)
+SEM (mvtaclo_a)
+SEM (mvtc)
+SEM (neg)
+SEM (nop)
+SEM (not)
+SEM (rac_dsi)
+SEM (rach_dsi)
+SEM (rte)
+SEM (seth)
+SEM (sll)
+SEM (sll3)
+SEM (slli)
+SEM (sra)
+SEM (sra3)
+SEM (srai)
+SEM (srl)
+SEM (srl3)
+SEM (srli)
+SEM (st)
+SEM (st_d)
+SEM (stb)
+SEM (stb_d)
+SEM (sth)
+SEM (sth_d)
+SEM (st_plus)
+SEM (st_minus)
+SEM (sub)
+SEM (subv)
+SEM (subx)
+SEM (trap)
+SEM (unlock)
+SEM (satb)
+SEM (sath)
+SEM (sat)
+SEM (pcmpbz)
+SEM (sadd)
+SEM (macwu1)
+SEM (msblo)
+SEM (mulwu1)
+SEM (maclh1)
+SEM (sc)
+SEM (snc)
+
+#undef SEMFULL
+#undef SEMFAST