1 1.2 knakahar /* $NetBSD: qat_c2xxx.c,v 1.2 2022/05/24 08:35:47 knakahara Exp $ */ 2 1.1 hikaru 3 1.1 hikaru /* 4 1.1 hikaru * Copyright (c) 2019 Internet Initiative Japan, Inc. 5 1.1 hikaru * All rights reserved. 6 1.1 hikaru * 7 1.1 hikaru * Redistribution and use in source and binary forms, with or without 8 1.1 hikaru * modification, are permitted provided that the following conditions 9 1.1 hikaru * are met: 10 1.1 hikaru * 1. Redistributions of source code must retain the above copyright 11 1.1 hikaru * notice, this list of conditions and the following disclaimer. 12 1.1 hikaru * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 hikaru * notice, this list of conditions and the following disclaimer in the 14 1.1 hikaru * documentation and/or other materials provided with the distribution. 15 1.1 hikaru * 16 1.1 hikaru * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.1 hikaru * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.1 hikaru * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.1 hikaru * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.1 hikaru * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.1 hikaru * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.1 hikaru * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.1 hikaru * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.1 hikaru * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.1 hikaru * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 hikaru * POSSIBILITY OF SUCH DAMAGE. 27 1.1 hikaru */ 28 1.1 hikaru 29 1.1 hikaru /* 30 1.1 hikaru * Copyright(c) 2007-2013 Intel Corporation. All rights reserved. 31 1.1 hikaru * 32 1.1 hikaru * Redistribution and use in source and binary forms, with or without 33 1.1 hikaru * modification, are permitted provided that the following conditions 34 1.1 hikaru * are met: 35 1.1 hikaru * 36 1.1 hikaru * * Redistributions of source code must retain the above copyright 37 1.1 hikaru * notice, this list of conditions and the following disclaimer. 38 1.1 hikaru * * Redistributions in binary form must reproduce the above copyright 39 1.1 hikaru * notice, this list of conditions and the following disclaimer in 40 1.1 hikaru * the documentation and/or other materials provided with the 41 1.1 hikaru * distribution. 42 1.1 hikaru * * Neither the name of Intel Corporation nor the names of its 43 1.1 hikaru * contributors may be used to endorse or promote products derived 44 1.1 hikaru * from this software without specific prior written permission. 45 1.1 hikaru * 46 1.1 hikaru * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 47 1.1 hikaru * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 48 1.1 hikaru * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 49 1.1 hikaru * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 50 1.1 hikaru * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 51 1.1 hikaru * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 52 1.1 hikaru * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 53 1.1 hikaru * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 54 1.1 hikaru * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 55 1.1 hikaru * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 56 1.1 hikaru * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 57 1.1 hikaru */ 58 1.1 hikaru 59 1.1 hikaru #include <sys/cdefs.h> 60 1.2 knakahar __KERNEL_RCSID(0, "$NetBSD: qat_c2xxx.c,v 1.2 2022/05/24 08:35:47 knakahara Exp $"); 61 1.1 hikaru 62 1.1 hikaru #include <sys/param.h> 63 1.1 hikaru #include <sys/systm.h> 64 1.1 hikaru 65 1.1 hikaru #include <dev/pci/pcireg.h> 66 1.1 hikaru #include <dev/pci/pcivar.h> 67 1.1 hikaru 68 1.1 hikaru #include "qatreg.h" 69 1.1 hikaru #include "qat_hw15reg.h" 70 1.1 hikaru #include "qat_c2xxxreg.h" 71 1.1 hikaru #include "qatvar.h" 72 1.1 hikaru #include "qat_hw15var.h" 73 1.1 hikaru 74 1.1 hikaru static uint32_t 75 1.1 hikaru qat_c2xxx_get_accel_mask(struct qat_softc *sc) 76 1.1 hikaru { 77 1.1 hikaru pcireg_t fusectl; 78 1.1 hikaru 79 1.1 hikaru fusectl = pci_conf_read(sc->sc_pc, sc->sc_pcitag, FUSECTL_REG); 80 1.1 hikaru 81 1.1 hikaru return ((~fusectl) & ACCEL_MASK_C2XXX); 82 1.1 hikaru } 83 1.1 hikaru 84 1.1 hikaru static uint32_t 85 1.1 hikaru qat_c2xxx_get_ae_mask(struct qat_softc *sc) 86 1.1 hikaru { 87 1.1 hikaru pcireg_t fusectl; 88 1.1 hikaru 89 1.1 hikaru fusectl = pci_conf_read(sc->sc_pc, sc->sc_pcitag, FUSECTL_REG); 90 1.1 hikaru if (fusectl & ( 91 1.1 hikaru FUSECTL_C2XXX_PKE_DISABLE | 92 1.1 hikaru FUSECTL_C2XXX_ATH_DISABLE | 93 1.1 hikaru FUSECTL_C2XXX_CPH_DISABLE)) { 94 1.1 hikaru return 0; 95 1.1 hikaru } else { 96 1.1 hikaru return ((~fusectl) & AE_MASK_C2XXX); 97 1.1 hikaru } 98 1.1 hikaru } 99 1.1 hikaru 100 1.1 hikaru static enum qat_sku 101 1.1 hikaru qat_c2xxx_get_sku(struct qat_softc *sc) 102 1.1 hikaru { 103 1.1 hikaru pcireg_t fusectl; 104 1.1 hikaru 105 1.1 hikaru fusectl = pci_conf_read(sc->sc_pc, sc->sc_pcitag, FUSECTL_REG); 106 1.1 hikaru 107 1.1 hikaru switch (sc->sc_ae_num) { 108 1.1 hikaru case 1: 109 1.1 hikaru if (fusectl & FUSECTL_C2XXX_LOW_SKU) 110 1.1 hikaru return QAT_SKU_3; 111 1.1 hikaru else if (fusectl & FUSECTL_C2XXX_MID_SKU) 112 1.1 hikaru return QAT_SKU_2; 113 1.1 hikaru break; 114 1.1 hikaru case MAX_AE_C2XXX: 115 1.1 hikaru return QAT_SKU_1; 116 1.1 hikaru } 117 1.1 hikaru 118 1.1 hikaru return QAT_SKU_UNKNOWN; 119 1.1 hikaru } 120 1.1 hikaru 121 1.1 hikaru static uint32_t 122 1.1 hikaru qat_c2xxx_get_accel_cap(struct qat_softc *sc) 123 1.1 hikaru { 124 1.1 hikaru return QAT_ACCEL_CAP_CRYPTO_SYMMETRIC | 125 1.1 hikaru QAT_ACCEL_CAP_CRYPTO_ASYMMETRIC | 126 1.1 hikaru QAT_ACCEL_CAP_CIPHER | 127 1.1 hikaru QAT_ACCEL_CAP_AUTHENTICATION; 128 1.1 hikaru } 129 1.1 hikaru 130 1.1 hikaru static const char * 131 1.1 hikaru qat_c2xxx_get_fw_uof_name(struct qat_softc *sc) 132 1.1 hikaru { 133 1.1 hikaru if (sc->sc_rev < QAT_REVID_C2XXX_B0) 134 1.1 hikaru return AE_FW_UOF_NAME_C2XXX_A0; 135 1.1 hikaru 136 1.1 hikaru /* QAT_REVID_C2XXX_B0 and QAT_REVID_C2XXX_C0 */ 137 1.1 hikaru return AE_FW_UOF_NAME_C2XXX_B0; 138 1.1 hikaru } 139 1.1 hikaru 140 1.1 hikaru static void 141 1.1 hikaru qat_c2xxx_enable_intr(struct qat_softc *sc) 142 1.1 hikaru { 143 1.1 hikaru 144 1.1 hikaru qat_misc_write_4(sc, EP_SMIA_C2XXX, EP_SMIA_MASK_C2XXX); 145 1.1 hikaru } 146 1.1 hikaru 147 1.1 hikaru static void 148 1.1 hikaru qat_c2xxx_init_etr_intr(struct qat_softc *sc, int bank) 149 1.1 hikaru { 150 1.1 hikaru /* 151 1.1 hikaru * For now, all rings within the bank are setup such that the generation 152 1.1 hikaru * of flag interrupts will be triggered when ring leaves the empty 153 1.1 hikaru * state. Note that in order for the ring interrupt to generate an IRQ 154 1.1 hikaru * the interrupt must also be enabled for the ring. 155 1.1 hikaru */ 156 1.1 hikaru qat_etr_bank_write_4(sc, bank, ETR_INT_SRCSEL, 157 1.1 hikaru ETR_INT_SRCSEL_MASK_0_C2XXX); 158 1.1 hikaru qat_etr_bank_write_4(sc, bank, ETR_INT_SRCSEL_2, 159 1.1 hikaru ETR_INT_SRCSEL_MASK_X_C2XXX); 160 1.1 hikaru } 161 1.1 hikaru 162 1.1 hikaru const struct qat_hw qat_hw_c2xxx = { 163 1.1 hikaru .qhw_sram_bar_id = BAR_SRAM_ID_C2XXX, 164 1.1 hikaru .qhw_misc_bar_id = BAR_PMISC_ID_C2XXX, 165 1.1 hikaru .qhw_etr_bar_id = BAR_ETR_ID_C2XXX, 166 1.1 hikaru .qhw_cap_global_offset = CAP_GLOBAL_OFFSET_C2XXX, 167 1.1 hikaru .qhw_ae_offset = AE_OFFSET_C2XXX, 168 1.1 hikaru .qhw_ae_local_offset = AE_LOCAL_OFFSET_C2XXX, 169 1.1 hikaru .qhw_etr_bundle_size = ETR_BUNDLE_SIZE_C2XXX, 170 1.1 hikaru .qhw_num_banks = ETR_MAX_BANKS_C2XXX, 171 1.1 hikaru .qhw_num_ap_banks = ETR_MAX_AP_BANKS_C2XXX, 172 1.1 hikaru .qhw_num_rings_per_bank = ETR_MAX_RINGS_PER_BANK, 173 1.1 hikaru .qhw_num_accel = MAX_ACCEL_C2XXX, 174 1.2 knakahar #if 0 175 1.1 hikaru .qhw_num_engines = MAX_AE_C2XXX, 176 1.2 knakahar #else 177 1.2 knakahar /* 178 1.2 knakahar * Workaround: 179 1.2 knakahar * C2xxx qat has two engines, however it doesn't have arbiter which 180 1.2 knakahar * C3xxx qat has. So, we don't use secondary engine for C2xxx qat. 181 1.2 knakahar */ 182 1.2 knakahar .qhw_num_engines = 1, 183 1.2 knakahar #endif 184 1.1 hikaru .qhw_tx_rx_gap = ETR_TX_RX_GAP_C2XXX, 185 1.1 hikaru .qhw_tx_rings_mask = ETR_TX_RINGS_MASK_C2XXX, 186 1.1 hikaru .qhw_msix_ae_vec_gap = MSIX_AE_VEC_GAP_C2XXX, 187 1.1 hikaru .qhw_fw_auth = false, 188 1.1 hikaru .qhw_fw_req_size = FW_REQ_DEFAULT_SZ_HW15, 189 1.1 hikaru .qhw_fw_resp_size = FW_REQ_DEFAULT_SZ_HW15, 190 1.1 hikaru .qhw_ring_asym_tx = 2, 191 1.1 hikaru .qhw_ring_asym_rx = 3, 192 1.1 hikaru .qhw_ring_sym_tx = 4, 193 1.1 hikaru .qhw_ring_sym_rx = 5, 194 1.1 hikaru .qhw_mof_fwname = AE_FW_MOF_NAME_C2XXX, 195 1.1 hikaru .qhw_mmp_fwname = AE_FW_MMP_NAME_C2XXX, 196 1.1 hikaru .qhw_prod_type = AE_FW_PROD_TYPE_C2XXX, 197 1.1 hikaru .qhw_get_accel_mask = qat_c2xxx_get_accel_mask, 198 1.1 hikaru .qhw_get_ae_mask = qat_c2xxx_get_ae_mask, 199 1.1 hikaru .qhw_get_sku = qat_c2xxx_get_sku, 200 1.1 hikaru .qhw_get_accel_cap = qat_c2xxx_get_accel_cap, 201 1.1 hikaru .qhw_get_fw_uof_name = qat_c2xxx_get_fw_uof_name, 202 1.1 hikaru .qhw_enable_intr = qat_c2xxx_enable_intr, 203 1.1 hikaru .qhw_init_etr_intr = qat_c2xxx_init_etr_intr, 204 1.1 hikaru .qhw_init_admin_comms = qat_adm_ring_init, 205 1.1 hikaru .qhw_send_admin_init = qat_adm_ring_send_init, 206 1.1 hikaru .qhw_crypto_setup_desc = qat_hw15_crypto_setup_desc, 207 1.1 hikaru .qhw_crypto_setup_req_params = qat_hw15_crypto_setup_req_params, 208 1.1 hikaru .qhw_crypto_opaque_offset = 209 1.1 hikaru offsetof(struct fw_la_resp, comn_resp.opaque_data), 210 1.1 hikaru }; 211