OSDN Git Service

s390/disassembler: add missing z13 instructions
authorHeiko Carstens <heiko.carstens@de.ibm.com>
Tue, 26 Sep 2017 14:15:06 +0000 (16:15 +0200)
committerMartin Schwidefsky <schwidefsky@de.ibm.com>
Fri, 29 Sep 2017 13:52:18 +0000 (15:52 +0200)
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
arch/s390/kernel/dis.c

index e08c213..c460e60 100644 (file)
@@ -113,7 +113,7 @@ enum {
        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,
@@ -130,7 +130,7 @@ enum {
        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,
@@ -241,6 +241,7 @@ static const unsigned char formats[][7] = {
        [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 },
@@ -303,6 +304,7 @@ static const unsigned char formats[][7] = {
        [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 },
@@ -425,6 +427,10 @@ enum {
        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,
@@ -433,6 +439,7 @@ enum {
        LONG_INSN_RISBLG,
        LONG_INSN_SLHHHR,
        LONG_INSN_SLHHLR,
+       LONG_INSN_STOCFH,
        LONG_INSN_TABORT,
        LONG_INSN_TBEGIN,
        LONG_INSN_TBEGINC,
@@ -505,6 +512,7 @@ static char *long_insn_name[] = {
        [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",
@@ -526,6 +534,10 @@ static char *long_insn_name[] = {
        [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[] = {
@@ -1101,6 +1113,7 @@ static struct s390_insn opcode_b9[] = {
        { "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 },
@@ -1160,6 +1173,7 @@ static struct s390_insn opcode_b9[] = {
        { { 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 },
@@ -1309,6 +1323,7 @@ static struct s390_insn opcode_e3[] = {
        { "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 },
@@ -1316,6 +1331,8 @@ static struct s390_insn opcode_e3[] = {
        { "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 },
@@ -1595,6 +1612,8 @@ static struct s390_insn opcode_eb[] = {
        { "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 },
@@ -1620,8 +1639,11 @@ static struct s390_insn opcode_eb[] = {
 };
 
 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 },
@@ -1717,6 +1739,10 @@ static struct s390_insn opcode_ed[] = {
        { "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 }
 };