|
| 1 | +/* |
| 2 | + * Copyright (C) 2016 Netronome Systems, Inc. |
| 3 | + * |
| 4 | + * This software is dual licensed under the GNU General License Version 2, |
| 5 | + * June 1991 as shown in the file COPYING in the top-level directory of this |
| 6 | + * source tree or the BSD 2-Clause License provided below. You have the |
| 7 | + * option to license this software under the complete terms of either license. |
| 8 | + * |
| 9 | + * The BSD 2-Clause License: |
| 10 | + * |
| 11 | + * Redistribution and use in source and binary forms, with or |
| 12 | + * without modification, are permitted provided that the following |
| 13 | + * conditions are met: |
| 14 | + * |
| 15 | + * 1. Redistributions of source code must retain the above |
| 16 | + * copyright notice, this list of conditions and the following |
| 17 | + * disclaimer. |
| 18 | + * |
| 19 | + * 2. Redistributions in binary form must reproduce the above |
| 20 | + * copyright notice, this list of conditions and the following |
| 21 | + * disclaimer in the documentation and/or other materials |
| 22 | + * provided with the distribution. |
| 23 | + * |
| 24 | + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| 25 | + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| 26 | + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| 27 | + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS |
| 28 | + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
| 29 | + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN |
| 30 | + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
| 31 | + * SOFTWARE. |
| 32 | + */ |
| 33 | + |
| 34 | +#ifndef __NFP_ASM_H__ |
| 35 | +#define __NFP_ASM_H__ 1 |
| 36 | + |
| 37 | +#include "nfp_bpf.h" |
| 38 | + |
| 39 | +#define REG_NONE 0 |
| 40 | + |
| 41 | +#define RE_REG_NO_DST 0x020 |
| 42 | +#define RE_REG_IMM 0x020 |
| 43 | +#define RE_REG_IMM_encode(x) \ |
| 44 | + (RE_REG_IMM | ((x) & 0x1f) | (((x) & 0x60) << 1)) |
| 45 | +#define RE_REG_IMM_MAX 0x07fULL |
| 46 | +#define RE_REG_XFR 0x080 |
| 47 | + |
| 48 | +#define UR_REG_XFR 0x180 |
| 49 | +#define UR_REG_NN 0x280 |
| 50 | +#define UR_REG_NO_DST 0x300 |
| 51 | +#define UR_REG_IMM UR_REG_NO_DST |
| 52 | +#define UR_REG_IMM_encode(x) (UR_REG_IMM | (x)) |
| 53 | +#define UR_REG_IMM_MAX 0x0ffULL |
| 54 | + |
| 55 | +#define OP_BR_BASE 0x0d800000020ULL |
| 56 | +#define OP_BR_BASE_MASK 0x0f8000c3ce0ULL |
| 57 | +#define OP_BR_MASK 0x0000000001fULL |
| 58 | +#define OP_BR_EV_PIP 0x00000000300ULL |
| 59 | +#define OP_BR_CSS 0x0000003c000ULL |
| 60 | +#define OP_BR_DEFBR 0x00000300000ULL |
| 61 | +#define OP_BR_ADDR_LO 0x007ffc00000ULL |
| 62 | +#define OP_BR_ADDR_HI 0x10000000000ULL |
| 63 | + |
| 64 | +#define nfp_is_br(_insn) \ |
| 65 | + (((_insn) & OP_BR_BASE_MASK) == OP_BR_BASE) |
| 66 | + |
| 67 | +enum br_mask { |
| 68 | + BR_BEQ = 0x00, |
| 69 | + BR_BNE = 0x01, |
| 70 | + BR_BHS = 0x04, |
| 71 | + BR_BLO = 0x05, |
| 72 | + BR_BGE = 0x08, |
| 73 | + BR_UNC = 0x18, |
| 74 | +}; |
| 75 | + |
| 76 | +enum br_ev_pip { |
| 77 | + BR_EV_PIP_UNCOND = 0, |
| 78 | + BR_EV_PIP_COND = 1, |
| 79 | +}; |
| 80 | + |
| 81 | +enum br_ctx_signal_state { |
| 82 | + BR_CSS_NONE = 2, |
| 83 | +}; |
| 84 | + |
| 85 | +#define OP_BBYTE_BASE 0x0c800000000ULL |
| 86 | +#define OP_BB_A_SRC 0x000000000ffULL |
| 87 | +#define OP_BB_BYTE 0x00000000300ULL |
| 88 | +#define OP_BB_B_SRC 0x0000003fc00ULL |
| 89 | +#define OP_BB_I8 0x00000040000ULL |
| 90 | +#define OP_BB_EQ 0x00000080000ULL |
| 91 | +#define OP_BB_DEFBR 0x00000300000ULL |
| 92 | +#define OP_BB_ADDR_LO 0x007ffc00000ULL |
| 93 | +#define OP_BB_ADDR_HI 0x10000000000ULL |
| 94 | + |
| 95 | +#define OP_BALU_BASE 0x0e800000000ULL |
| 96 | +#define OP_BA_A_SRC 0x000000003ffULL |
| 97 | +#define OP_BA_B_SRC 0x000000ffc00ULL |
| 98 | +#define OP_BA_DEFBR 0x00000300000ULL |
| 99 | +#define OP_BA_ADDR_HI 0x0007fc00000ULL |
| 100 | + |
| 101 | +#define OP_IMMED_A_SRC 0x000000003ffULL |
| 102 | +#define OP_IMMED_B_SRC 0x000000ffc00ULL |
| 103 | +#define OP_IMMED_IMM 0x0000ff00000ULL |
| 104 | +#define OP_IMMED_WIDTH 0x00060000000ULL |
| 105 | +#define OP_IMMED_INV 0x00080000000ULL |
| 106 | +#define OP_IMMED_SHIFT 0x00600000000ULL |
| 107 | +#define OP_IMMED_BASE 0x0f000000000ULL |
| 108 | +#define OP_IMMED_WR_AB 0x20000000000ULL |
| 109 | + |
| 110 | +enum immed_width { |
| 111 | + IMMED_WIDTH_ALL = 0, |
| 112 | + IMMED_WIDTH_BYTE = 1, |
| 113 | + IMMED_WIDTH_WORD = 2, |
| 114 | +}; |
| 115 | + |
| 116 | +enum immed_shift { |
| 117 | + IMMED_SHIFT_0B = 0, |
| 118 | + IMMED_SHIFT_1B = 1, |
| 119 | + IMMED_SHIFT_2B = 2, |
| 120 | +}; |
| 121 | + |
| 122 | +#define OP_SHF_BASE 0x08000000000ULL |
| 123 | +#define OP_SHF_A_SRC 0x000000000ffULL |
| 124 | +#define OP_SHF_SC 0x00000000300ULL |
| 125 | +#define OP_SHF_B_SRC 0x0000003fc00ULL |
| 126 | +#define OP_SHF_I8 0x00000040000ULL |
| 127 | +#define OP_SHF_SW 0x00000080000ULL |
| 128 | +#define OP_SHF_DST 0x0000ff00000ULL |
| 129 | +#define OP_SHF_SHIFT 0x001f0000000ULL |
| 130 | +#define OP_SHF_OP 0x00e00000000ULL |
| 131 | +#define OP_SHF_DST_AB 0x01000000000ULL |
| 132 | +#define OP_SHF_WR_AB 0x20000000000ULL |
| 133 | + |
| 134 | +enum shf_op { |
| 135 | + SHF_OP_NONE = 0, |
| 136 | + SHF_OP_AND = 2, |
| 137 | + SHF_OP_OR = 5, |
| 138 | +}; |
| 139 | + |
| 140 | +enum shf_sc { |
| 141 | + SHF_SC_R_ROT = 0, |
| 142 | + SHF_SC_R_SHF = 1, |
| 143 | + SHF_SC_L_SHF = 2, |
| 144 | + SHF_SC_R_DSHF = 3, |
| 145 | +}; |
| 146 | + |
| 147 | +#define OP_ALU_A_SRC 0x000000003ffULL |
| 148 | +#define OP_ALU_B_SRC 0x000000ffc00ULL |
| 149 | +#define OP_ALU_DST 0x0003ff00000ULL |
| 150 | +#define OP_ALU_SW 0x00040000000ULL |
| 151 | +#define OP_ALU_OP 0x00f80000000ULL |
| 152 | +#define OP_ALU_DST_AB 0x01000000000ULL |
| 153 | +#define OP_ALU_BASE 0x0a000000000ULL |
| 154 | +#define OP_ALU_WR_AB 0x20000000000ULL |
| 155 | + |
| 156 | +enum alu_op { |
| 157 | + ALU_OP_NONE = 0x00, |
| 158 | + ALU_OP_ADD = 0x01, |
| 159 | + ALU_OP_NEG = 0x04, |
| 160 | + ALU_OP_AND = 0x08, |
| 161 | + ALU_OP_SUB_C = 0x0d, |
| 162 | + ALU_OP_ADD_C = 0x11, |
| 163 | + ALU_OP_OR = 0x14, |
| 164 | + ALU_OP_SUB = 0x15, |
| 165 | + ALU_OP_XOR = 0x18, |
| 166 | +}; |
| 167 | + |
| 168 | +enum alu_dst_ab { |
| 169 | + ALU_DST_A = 0, |
| 170 | + ALU_DST_B = 1, |
| 171 | +}; |
| 172 | + |
| 173 | +#define OP_LDF_BASE 0x0c000000000ULL |
| 174 | +#define OP_LDF_A_SRC 0x000000000ffULL |
| 175 | +#define OP_LDF_SC 0x00000000300ULL |
| 176 | +#define OP_LDF_B_SRC 0x0000003fc00ULL |
| 177 | +#define OP_LDF_I8 0x00000040000ULL |
| 178 | +#define OP_LDF_SW 0x00000080000ULL |
| 179 | +#define OP_LDF_ZF 0x00000100000ULL |
| 180 | +#define OP_LDF_BMASK 0x0000f000000ULL |
| 181 | +#define OP_LDF_SHF 0x001f0000000ULL |
| 182 | +#define OP_LDF_WR_AB 0x20000000000ULL |
| 183 | + |
| 184 | +#define OP_CMD_A_SRC 0x000000000ffULL |
| 185 | +#define OP_CMD_CTX 0x00000000300ULL |
| 186 | +#define OP_CMD_B_SRC 0x0000003fc00ULL |
| 187 | +#define OP_CMD_TOKEN 0x000000c0000ULL |
| 188 | +#define OP_CMD_XFER 0x00001f00000ULL |
| 189 | +#define OP_CMD_CNT 0x0000e000000ULL |
| 190 | +#define OP_CMD_SIG 0x000f0000000ULL |
| 191 | +#define OP_CMD_TGT_CMD 0x07f00000000ULL |
| 192 | +#define OP_CMD_MODE 0x1c0000000000ULL |
| 193 | + |
| 194 | +struct cmd_tgt_act { |
| 195 | + u8 token; |
| 196 | + u8 tgt_cmd; |
| 197 | +}; |
| 198 | + |
| 199 | +enum cmd_tgt_map { |
| 200 | + CMD_TGT_READ8, |
| 201 | + CMD_TGT_WRITE8, |
| 202 | + CMD_TGT_READ_LE, |
| 203 | + CMD_TGT_READ_SWAP_LE, |
| 204 | + __CMD_TGT_MAP_SIZE, |
| 205 | +}; |
| 206 | + |
| 207 | +enum cmd_mode { |
| 208 | + CMD_MODE_40b_AB = 0, |
| 209 | + CMD_MODE_40b_BA = 1, |
| 210 | + CMD_MODE_32b = 4, |
| 211 | +}; |
| 212 | + |
| 213 | +enum cmd_ctx_swap { |
| 214 | + CMD_CTX_SWAP = 0, |
| 215 | + CMD_CTX_NO_SWAP = 3, |
| 216 | +}; |
| 217 | + |
| 218 | +#define OP_LCSR_BASE 0x0fc00000000ULL |
| 219 | +#define OP_LCSR_A_SRC 0x000000003ffULL |
| 220 | +#define OP_LCSR_B_SRC 0x000000ffc00ULL |
| 221 | +#define OP_LCSR_WRITE 0x00000200000ULL |
| 222 | +#define OP_LCSR_ADDR 0x001ffc00000ULL |
| 223 | + |
| 224 | +enum lcsr_wr_src { |
| 225 | + LCSR_WR_AREG, |
| 226 | + LCSR_WR_BREG, |
| 227 | + LCSR_WR_IMM, |
| 228 | +}; |
| 229 | + |
| 230 | +#define OP_CARB_BASE 0x0e000000000ULL |
| 231 | +#define OP_CARB_OR 0x00000010000ULL |
| 232 | + |
| 233 | +#endif |
0 commit comments