cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

parse_asm.h (7180B)


      1/* SPDX-License-Identifier: GPL-2.0-only */
      2/*
      3 * Copyright (C) 2020 SiFive
      4 */
      5
      6#include <linux/bits.h>
      7
      8/* The bit field of immediate value in I-type instruction */
      9#define I_IMM_SIGN_OPOFF	31
     10#define I_IMM_11_0_OPOFF	20
     11#define I_IMM_SIGN_OFF		12
     12#define I_IMM_11_0_OFF		0
     13#define I_IMM_11_0_MASK		GENMASK(11, 0)
     14
     15/* The bit field of immediate value in J-type instruction */
     16#define J_IMM_SIGN_OPOFF	31
     17#define J_IMM_10_1_OPOFF	21
     18#define J_IMM_11_OPOFF		20
     19#define J_IMM_19_12_OPOFF	12
     20#define J_IMM_SIGN_OFF		20
     21#define J_IMM_10_1_OFF		1
     22#define J_IMM_11_OFF		11
     23#define J_IMM_19_12_OFF		12
     24#define J_IMM_10_1_MASK		GENMASK(9, 0)
     25#define J_IMM_11_MASK		GENMASK(0, 0)
     26#define J_IMM_19_12_MASK	GENMASK(7, 0)
     27
     28/* The bit field of immediate value in B-type instruction */
     29#define B_IMM_SIGN_OPOFF	31
     30#define B_IMM_10_5_OPOFF	25
     31#define B_IMM_4_1_OPOFF		8
     32#define B_IMM_11_OPOFF		7
     33#define B_IMM_SIGN_OFF		12
     34#define B_IMM_10_5_OFF		5
     35#define B_IMM_4_1_OFF		1
     36#define B_IMM_11_OFF		11
     37#define B_IMM_10_5_MASK		GENMASK(5, 0)
     38#define B_IMM_4_1_MASK		GENMASK(3, 0)
     39#define B_IMM_11_MASK		GENMASK(0, 0)
     40
     41/* The register offset in RVG instruction */
     42#define RVG_RS1_OPOFF		15
     43#define RVG_RS2_OPOFF		20
     44#define RVG_RD_OPOFF		7
     45
     46/* The bit field of immediate value in RVC J instruction */
     47#define RVC_J_IMM_SIGN_OPOFF	12
     48#define RVC_J_IMM_4_OPOFF	11
     49#define RVC_J_IMM_9_8_OPOFF	9
     50#define RVC_J_IMM_10_OPOFF	8
     51#define RVC_J_IMM_6_OPOFF	7
     52#define RVC_J_IMM_7_OPOFF	6
     53#define RVC_J_IMM_3_1_OPOFF	3
     54#define RVC_J_IMM_5_OPOFF	2
     55#define RVC_J_IMM_SIGN_OFF	11
     56#define RVC_J_IMM_4_OFF		4
     57#define RVC_J_IMM_9_8_OFF	8
     58#define RVC_J_IMM_10_OFF	10
     59#define RVC_J_IMM_6_OFF		6
     60#define RVC_J_IMM_7_OFF		7
     61#define RVC_J_IMM_3_1_OFF	1
     62#define RVC_J_IMM_5_OFF		5
     63#define RVC_J_IMM_4_MASK	GENMASK(0, 0)
     64#define RVC_J_IMM_9_8_MASK	GENMASK(1, 0)
     65#define RVC_J_IMM_10_MASK	GENMASK(0, 0)
     66#define RVC_J_IMM_6_MASK	GENMASK(0, 0)
     67#define RVC_J_IMM_7_MASK	GENMASK(0, 0)
     68#define RVC_J_IMM_3_1_MASK	GENMASK(2, 0)
     69#define RVC_J_IMM_5_MASK	GENMASK(0, 0)
     70
     71/* The bit field of immediate value in RVC B instruction */
     72#define RVC_B_IMM_SIGN_OPOFF	12
     73#define RVC_B_IMM_4_3_OPOFF	10
     74#define RVC_B_IMM_7_6_OPOFF	5
     75#define RVC_B_IMM_2_1_OPOFF	3
     76#define RVC_B_IMM_5_OPOFF	2
     77#define RVC_B_IMM_SIGN_OFF	8
     78#define RVC_B_IMM_4_3_OFF	3
     79#define RVC_B_IMM_7_6_OFF	6
     80#define RVC_B_IMM_2_1_OFF	1
     81#define RVC_B_IMM_5_OFF		5
     82#define RVC_B_IMM_4_3_MASK	GENMASK(1, 0)
     83#define RVC_B_IMM_7_6_MASK	GENMASK(1, 0)
     84#define RVC_B_IMM_2_1_MASK	GENMASK(1, 0)
     85#define RVC_B_IMM_5_MASK	GENMASK(0, 0)
     86
     87/* The register offset in RVC op=C0 instruction */
     88#define RVC_C0_RS1_OPOFF	7
     89#define RVC_C0_RS2_OPOFF	2
     90#define RVC_C0_RD_OPOFF		2
     91
     92/* The register offset in RVC op=C1 instruction */
     93#define RVC_C1_RS1_OPOFF	7
     94#define RVC_C1_RS2_OPOFF	2
     95#define RVC_C1_RD_OPOFF		7
     96
     97/* The register offset in RVC op=C2 instruction */
     98#define RVC_C2_RS1_OPOFF	7
     99#define RVC_C2_RS2_OPOFF	2
    100#define RVC_C2_RD_OPOFF		7
    101
    102/* parts of opcode for RVG*/
    103#define OPCODE_BRANCH		0x63
    104#define OPCODE_JALR		0x67
    105#define OPCODE_JAL		0x6f
    106#define OPCODE_SYSTEM		0x73
    107
    108/* parts of opcode for RVC*/
    109#define OPCODE_C_0		0x0
    110#define OPCODE_C_1		0x1
    111#define OPCODE_C_2		0x2
    112
    113/* parts of funct3 code for I, M, A extension*/
    114#define FUNCT3_JALR		0x0
    115#define FUNCT3_BEQ		0x0
    116#define FUNCT3_BNE		0x1000
    117#define FUNCT3_BLT		0x4000
    118#define FUNCT3_BGE		0x5000
    119#define FUNCT3_BLTU		0x6000
    120#define FUNCT3_BGEU		0x7000
    121
    122/* parts of funct3 code for C extension*/
    123#define FUNCT3_C_BEQZ		0xc000
    124#define FUNCT3_C_BNEZ		0xe000
    125#define FUNCT3_C_J		0xa000
    126#define FUNCT3_C_JAL		0x2000
    127#define FUNCT4_C_JR		0x8000
    128#define FUNCT4_C_JALR		0xf000
    129
    130#define FUNCT12_SRET		0x10200000
    131
    132#define MATCH_JALR		(FUNCT3_JALR | OPCODE_JALR)
    133#define MATCH_JAL		(OPCODE_JAL)
    134#define MATCH_BEQ		(FUNCT3_BEQ | OPCODE_BRANCH)
    135#define MATCH_BNE		(FUNCT3_BNE | OPCODE_BRANCH)
    136#define MATCH_BLT		(FUNCT3_BLT | OPCODE_BRANCH)
    137#define MATCH_BGE		(FUNCT3_BGE | OPCODE_BRANCH)
    138#define MATCH_BLTU		(FUNCT3_BLTU | OPCODE_BRANCH)
    139#define MATCH_BGEU		(FUNCT3_BGEU | OPCODE_BRANCH)
    140#define MATCH_SRET		(FUNCT12_SRET | OPCODE_SYSTEM)
    141#define MATCH_C_BEQZ		(FUNCT3_C_BEQZ | OPCODE_C_1)
    142#define MATCH_C_BNEZ		(FUNCT3_C_BNEZ | OPCODE_C_1)
    143#define MATCH_C_J		(FUNCT3_C_J | OPCODE_C_1)
    144#define MATCH_C_JAL		(FUNCT3_C_JAL | OPCODE_C_1)
    145#define MATCH_C_JR		(FUNCT4_C_JR | OPCODE_C_2)
    146#define MATCH_C_JALR		(FUNCT4_C_JALR | OPCODE_C_2)
    147
    148#define MASK_JALR		0x707f
    149#define MASK_JAL		0x7f
    150#define MASK_C_JALR		0xf07f
    151#define MASK_C_JR		0xf07f
    152#define MASK_C_JAL		0xe003
    153#define MASK_C_J		0xe003
    154#define MASK_BEQ		0x707f
    155#define MASK_BNE		0x707f
    156#define MASK_BLT		0x707f
    157#define MASK_BGE		0x707f
    158#define MASK_BLTU		0x707f
    159#define MASK_BGEU		0x707f
    160#define MASK_C_BEQZ		0xe003
    161#define MASK_C_BNEZ		0xe003
    162#define MASK_SRET		0xffffffff
    163
    164#define __INSN_LENGTH_MASK	_UL(0x3)
    165#define __INSN_LENGTH_GE_32	_UL(0x3)
    166#define __INSN_OPCODE_MASK	_UL(0x7F)
    167#define __INSN_BRANCH_OPCODE	_UL(OPCODE_BRANCH)
    168
    169/* Define a series of is_XXX_insn functions to check if the value INSN
    170 * is an instance of instruction XXX.
    171 */
    172#define DECLARE_INSN(INSN_NAME, INSN_MATCH, INSN_MASK) \
    173static inline bool is_ ## INSN_NAME ## _insn(long insn) \
    174{ \
    175	return (insn & (INSN_MASK)) == (INSN_MATCH); \
    176}
    177
    178#define RV_IMM_SIGN(x) (-(((x) >> 31) & 1))
    179#define RVC_IMM_SIGN(x) (-(((x) >> 12) & 1))
    180#define RV_X(X, s, mask)  (((X) >> (s)) & (mask))
    181#define RVC_X(X, s, mask) RV_X(X, s, mask)
    182
    183#define EXTRACT_JTYPE_IMM(x) \
    184	({typeof(x) x_ = (x); \
    185	(RV_X(x_, J_IMM_10_1_OPOFF, J_IMM_10_1_MASK) << J_IMM_10_1_OFF) | \
    186	(RV_X(x_, J_IMM_11_OPOFF, J_IMM_11_MASK) << J_IMM_11_OFF) | \
    187	(RV_X(x_, J_IMM_19_12_OPOFF, J_IMM_19_12_MASK) << J_IMM_19_12_OFF) | \
    188	(RV_IMM_SIGN(x_) << J_IMM_SIGN_OFF); })
    189
    190#define EXTRACT_ITYPE_IMM(x) \
    191	({typeof(x) x_ = (x); \
    192	(RV_X(x_, I_IMM_11_0_OPOFF, I_IMM_11_0_MASK)) | \
    193	(RV_IMM_SIGN(x_) << I_IMM_SIGN_OFF); })
    194
    195#define EXTRACT_BTYPE_IMM(x) \
    196	({typeof(x) x_ = (x); \
    197	(RV_X(x_, B_IMM_4_1_OPOFF, B_IMM_4_1_MASK) << B_IMM_4_1_OFF) | \
    198	(RV_X(x_, B_IMM_10_5_OPOFF, B_IMM_10_5_MASK) << B_IMM_10_5_OFF) | \
    199	(RV_X(x_, B_IMM_11_OPOFF, B_IMM_11_MASK) << B_IMM_11_OFF) | \
    200	(RV_IMM_SIGN(x_) << B_IMM_SIGN_OFF); })
    201
    202#define EXTRACT_RVC_J_IMM(x) \
    203	({typeof(x) x_ = (x); \
    204	(RVC_X(x_, RVC_J_IMM_3_1_OPOFF, RVC_J_IMM_3_1_MASK) << RVC_J_IMM_3_1_OFF) | \
    205	(RVC_X(x_, RVC_J_IMM_4_OPOFF, RVC_J_IMM_4_MASK) << RVC_J_IMM_4_OFF) | \
    206	(RVC_X(x_, RVC_J_IMM_5_OPOFF, RVC_J_IMM_5_MASK) << RVC_J_IMM_5_OFF) | \
    207	(RVC_X(x_, RVC_J_IMM_6_OPOFF, RVC_J_IMM_6_MASK) << RVC_J_IMM_6_OFF) | \
    208	(RVC_X(x_, RVC_J_IMM_7_OPOFF, RVC_J_IMM_7_MASK) << RVC_J_IMM_7_OFF) | \
    209	(RVC_X(x_, RVC_J_IMM_9_8_OPOFF, RVC_J_IMM_9_8_MASK) << RVC_J_IMM_9_8_OFF) | \
    210	(RVC_X(x_, RVC_J_IMM_10_OPOFF, RVC_J_IMM_10_MASK) << RVC_J_IMM_10_OFF) | \
    211	(RVC_IMM_SIGN(x_) << RVC_J_IMM_SIGN_OFF); })
    212
    213#define EXTRACT_RVC_B_IMM(x) \
    214	({typeof(x) x_ = (x); \
    215	(RVC_X(x_, RVC_B_IMM_2_1_OPOFF, RVC_B_IMM_2_1_MASK) << RVC_B_IMM_2_1_OFF) | \
    216	(RVC_X(x_, RVC_B_IMM_4_3_OPOFF, RVC_B_IMM_4_3_MASK) << RVC_B_IMM_4_3_OFF) | \
    217	(RVC_X(x_, RVC_B_IMM_5_OPOFF, RVC_B_IMM_5_MASK) << RVC_B_IMM_5_OFF) | \
    218	(RVC_X(x_, RVC_B_IMM_7_6_OPOFF, RVC_B_IMM_7_6_MASK) << RVC_B_IMM_7_6_OFF) | \
    219	(RVC_IMM_SIGN(x_) << RVC_B_IMM_SIGN_OFF); })