INSTR_MII_UPI,
        INSTR_RIE_R0IU, INSTR_RIE_R0UU, INSTR_RIE_RRP, INSTR_RIE_RRPU,
        INSTR_RIE_RRUUU, INSTR_RIE_RUPI, INSTR_RIE_RUPU, INSTR_RIE_RRI0,
-       INSTR_RIL_RI, INSTR_RIL_RP, INSTR_RIL_RU, INSTR_RIL_UP,
+       INSTR_RIE_RUI0, INSTR_RIL_RI, INSTR_RIL_RP, INSTR_RIL_RU, INSTR_RIL_UP,
        INSTR_RIS_R0RDU, INSTR_RIS_R0UU, INSTR_RIS_RURDI, INSTR_RIS_RURDU,
        INSTR_RI_RI, INSTR_RI_RP, INSTR_RI_RU, INSTR_RI_UP,
        INSTR_RRE_00, INSTR_RRE_0R, INSTR_RRE_AA, INSTR_RRE_AR, INSTR_RRE_F0,
        INSTR_RSI_RRP,
        INSTR_RSL_LRDFU, INSTR_RSL_R0RD,
        INSTR_RSY_AARD, INSTR_RSY_CCRD, INSTR_RSY_RRRD, INSTR_RSY_RURD,
-       INSTR_RSY_RDRM, INSTR_RSY_RMRD,
+       INSTR_RSY_RURD2, INSTR_RSY_RDRM, INSTR_RSY_RMRD,
        INSTR_RS_AARD, INSTR_RS_CCRD, INSTR_RS_R0RD, INSTR_RS_RRRD,
        INSTR_RS_RURD,
        INSTR_RXE_FRRD, INSTR_RXE_RRRD, INSTR_RXE_RRRDM,
        [INSTR_RIE_RRPU]  = { 0xff, R_8,R_12,U4_32,J16_16,0,0 },
        [INSTR_RIE_RRP]   = { 0xff, R_8,R_12,J16_16,0,0,0 },
        [INSTR_RIE_RRUUU] = { 0xff, R_8,R_12,U8_16,U8_24,U8_32,0 },
+       [INSTR_RIE_RUI0]  = { 0xff, R_8,I16_16,U4_12,0,0,0 },
        [INSTR_RIE_RUPI]  = { 0xff, R_8,I8_32,U4_12,J16_16,0,0 },
        [INSTR_RIE_RUPU]  = { 0xff, R_8,U8_32,U4_12,J16_16,0,0 },
        [INSTR_RIL_RI]    = { 0x0f, R_8,I32_16,0,0,0,0 },
        [INSTR_RSY_RMRD]  = { 0xff, R_8,U4_12,D20_20,B_16,0,0 },
        [INSTR_RSY_RRRD]  = { 0xff, R_8,R_12,D20_20,B_16,0,0 },
        [INSTR_RSY_RURD]  = { 0xff, R_8,U4_12,D20_20,B_16,0,0 },
+       [INSTR_RSY_RURD2] = { 0xff, R_8,D20_20,B_16,U4_12,0,0 },
        [INSTR_RS_AARD]   = { 0xff, A_8,A_12,D_20,B_16,0,0 },
        [INSTR_RS_CCRD]   = { 0xff, C_8,C_12,D_20,B_16,0,0 },
        [INSTR_RS_R0RD]   = { 0xff, R_8,D_20,B_16,0,0,0 },
        LONG_INSN_LLGFRL,
        LONG_INSN_LLGHRL,
        LONG_INSN_LLGTAT,
+       LONG_INSN_LLZRGF,
+       LONG_INSN_LOCFHR,
+       LONG_INSN_LOCGHI,
+       LONG_INSN_LOCHHI,
        LONG_INSN_POPCNT,
        LONG_INSN_RIEMIT,
        LONG_INSN_RINEXT,
        LONG_INSN_RISBLG,
        LONG_INSN_SLHHHR,
        LONG_INSN_SLHHLR,
+       LONG_INSN_STOCFH,
        LONG_INSN_TABORT,
        LONG_INSN_TBEGIN,
        LONG_INSN_TBEGINC,
        [LONG_INSN_LLGFRL] = "llgfrl",
        [LONG_INSN_LLGHRL] = "llghrl",
        [LONG_INSN_LLGTAT] = "llgtat",
+       [LONG_INSN_LLZRGF] = "llzrgf",
        [LONG_INSN_POPCNT] = "popcnt",
        [LONG_INSN_RIEMIT] = "riemit",
        [LONG_INSN_RINEXT] = "rinext",
        [LONG_INSN_VESRLV] = "vesrlv",
        [LONG_INSN_VSBCBI] = "vsbcbi",
        [LONG_INSN_STCCTM] = "stcctm",
+       [LONG_INSN_LOCFHR] = "locfhr",
+       [LONG_INSN_LOCGHI] = "locghi",
+       [LONG_INSN_LOCHHI] = "lochhi",
+       [LONG_INSN_STOCFH] = "stocfh",
 };
 
 static struct s390_insn opcode[] = {
        { "lhr", 0x27, INSTR_RRE_RR },
        { "cgfr", 0x30, INSTR_RRE_RR },
        { "clgfr", 0x31, INSTR_RRE_RR },
+       { "ppno", 0x3c, INSTR_RRE_RR },
        { "cfdtr", 0x41, INSTR_RRF_UURF },
        { { 0, LONG_INSN_CLGDTR }, 0x42, INSTR_RRF_UURF },
        { { 0, LONG_INSN_CLFDTR }, 0x43, INSTR_RRF_UURF },
        { { 0, LONG_INSN_SLHHLR }, 0xdb, INSTR_RRF_R0RR2 },
        { "chlr", 0xdd, INSTR_RRE_RR },
        { "clhlr", 0xdf, INSTR_RRE_RR },
+       { { 0, LONG_INSN_LOCFHR }, 0xe0, INSTR_RRF_U0RR },
        { { 0, LONG_INSN_POPCNT }, 0xe1, INSTR_RRE_RR },
        { "locgr", 0xe2, INSTR_RRF_M0RR },
        { "ngrk", 0xe4, INSTR_RRF_R0RR2 },
        { "stg", 0x24, INSTR_RXY_RRRD },
        { "ntstg", 0x25, INSTR_RXY_RRRD },
        { "cvdy", 0x26, INSTR_RXY_RRRD },
+       { "lzrg", 0x2a, INSTR_RXY_RRRD },
        { "cvdg", 0x2e, INSTR_RXY_RRRD },
        { "strvg", 0x2f, INSTR_RXY_RRRD },
        { "cgf", 0x30, INSTR_RXY_RRRD },
        { "ltgf", 0x32, INSTR_RXY_RRRD },
        { "cgh", 0x34, INSTR_RXY_RRRD },
        { "pfd", 0x36, INSTR_RXY_URRD },
+       { { 0, LONG_INSN_LLZRGF }, 0x3a, INSTR_RXY_RRRD },
+       { "lzrf", 0x3b, INSTR_RXY_RRRD },
        { "strvh", 0x3f, INSTR_RXY_RRRD },
        { "bctg", 0x46, INSTR_RXY_RRRD },
        { "sty", 0x50, INSTR_RXY_RRRD },
        { "slak", 0xdd, INSTR_RSY_RRRD },
        { "srlk", 0xde, INSTR_RSY_RRRD },
        { "sllk", 0xdf, INSTR_RSY_RRRD },
+       { "locfh", 0xe0, INSTR_RSY_RURD2 },
+       { { 0, LONG_INSN_STOCFH }, 0xe1, INSTR_RSY_RURD2 },
        { "locg", 0xe2, INSTR_RSY_RDRM },
        { "stocg", 0xe3, INSTR_RSY_RDRM },
        { "lang", 0xe4, INSTR_RSY_RRRD },
 };
 
 static struct s390_insn opcode_ec[] = {
+       { "lochi", 0x42, INSTR_RIE_RUI0 },
        { "brxhg", 0x44, INSTR_RIE_RRP },
        { "brxlg", 0x45, INSTR_RIE_RRP },
+       { { 0, LONG_INSN_LOCGHI }, 0x46, INSTR_RIE_RUI0 },
+       { { 0, LONG_INSN_LOCHHI }, 0x4e, INSTR_RIE_RUI0 },
        { { 0, LONG_INSN_RISBLG }, 0x51, INSTR_RIE_RRUUU },
        { "rnsbg", 0x54, INSTR_RIE_RRUUU },
        { "risbg", 0x55, INSTR_RIE_RRUUU },
        { "mee", 0x37, INSTR_RXE_FRRD },
        { "mad", 0x3e, INSTR_RXF_FRRDF },
        { "msd", 0x3f, INSTR_RXF_FRRDF },
+       { "cdpt", 0xae, INSTR_RSL_LRDFU },
+       { "cxpt", 0xaf, INSTR_RSL_LRDFU },
+       { "cpdt", 0xac, INSTR_RSL_LRDFU },
+       { "cpxt", 0xad, INSTR_RSL_LRDFU },
        { "", 0, INSTR_INVALID }
 };