]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/blame - drivers/scsi/bfa/bfa_hw_ct.c
Merge branch 'timers-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[mirror_ubuntu-jammy-kernel.git] / drivers / scsi / bfa / bfa_hw_ct.c
CommitLineData
52fa7bf9 1// SPDX-License-Identifier: GPL-2.0-only
7725ccfd 2/*
889d0d42
AG
3 * Copyright (c) 2005-2014 Brocade Communications Systems, Inc.
4 * Copyright (c) 2014- QLogic Corporation.
7725ccfd 5 * All rights reserved
889d0d42 6 * www.qlogic.com
7725ccfd 7 *
31e1d569 8 * Linux driver for QLogic BR-series Fibre Channel Host Bus Adapter.
7725ccfd
JH
9 */
10
f16a1750 11#include "bfad_drv.h"
a36c61f9 12#include "bfa_modules.h"
11189208 13#include "bfi_reg.h"
7725ccfd
JH
14
15BFA_TRC_FILE(HAL, IOCFC_CT);
16
5fbe25c7 17/*
7725ccfd
JH
18 * Dummy interrupt handler for handling spurious interrupt during chip-reinit.
19 */
20static void
21bfa_hwct_msix_dummy(struct bfa_s *bfa, int vec)
22{
23}
24
25void
26bfa_hwct_reginit(struct bfa_s *bfa)
27{
28 struct bfa_iocfc_regs_s *bfa_regs = &bfa->iocfc.bfa_regs;
53440260 29 void __iomem *kva = bfa_ioc_bar0(&bfa->ioc);
11189208 30 int fn = bfa_ioc_pcifn(&bfa->ioc);
7725ccfd
JH
31
32 if (fn == 0) {
33 bfa_regs->intr_status = (kva + HOSTFN0_INT_STATUS);
34 bfa_regs->intr_mask = (kva + HOSTFN0_INT_MSK);
35 } else {
36 bfa_regs->intr_status = (kva + HOSTFN1_INT_STATUS);
37 bfa_regs->intr_mask = (kva + HOSTFN1_INT_MSK);
38 }
11189208 39}
7725ccfd 40
11189208
KG
41void
42bfa_hwct2_reginit(struct bfa_s *bfa)
43{
44 struct bfa_iocfc_regs_s *bfa_regs = &bfa->iocfc.bfa_regs;
45 void __iomem *kva = bfa_ioc_bar0(&bfa->ioc);
46
47 bfa_regs->intr_status = (kva + CT2_HOSTFN_INT_STATUS);
48 bfa_regs->intr_mask = (kva + CT2_HOSTFN_INTR_MASK);
7725ccfd
JH
49}
50
f5713c5d
KG
51void
52bfa_hwct_reqq_ack(struct bfa_s *bfa, int reqq)
53{
a36c61f9 54 u32 r32;
f5713c5d 55
53440260
JH
56 r32 = readl(bfa->iocfc.bfa_regs.cpe_q_ctrl[reqq]);
57 writel(r32, bfa->iocfc.bfa_regs.cpe_q_ctrl[reqq]);
f5713c5d
KG
58}
59
ca6e0ea7
KG
60/*
61 * Actions to respond RME Interrupt for Catapult ASIC:
62 * - Write 1 to Interrupt Status register (INTx only - done in bfa_intx())
63 * - Acknowledge by writing to RME Queue Control register
64 * - Update CI
65 */
7725ccfd 66void
ca6e0ea7 67bfa_hwct_rspq_ack(struct bfa_s *bfa, int rspq, u32 ci)
7725ccfd
JH
68{
69 u32 r32;
70
53440260
JH
71 r32 = readl(bfa->iocfc.bfa_regs.rme_q_ctrl[rspq]);
72 writel(r32, bfa->iocfc.bfa_regs.rme_q_ctrl[rspq]);
ca6e0ea7
KG
73
74 bfa_rspq_ci(bfa, rspq) = ci;
75 writel(ci, bfa->iocfc.bfa_regs.rme_q_ci[rspq]);
ca6e0ea7
KG
76}
77
78/*
79 * Actions to respond RME Interrupt for Catapult2 ASIC:
80 * - Write 1 to Interrupt Status register (INTx only - done in bfa_intx())
81 * - Update CI
82 */
83void
84bfa_hwct2_rspq_ack(struct bfa_s *bfa, int rspq, u32 ci)
85{
86 bfa_rspq_ci(bfa, rspq) = ci;
87 writel(ci, bfa->iocfc.bfa_regs.rme_q_ci[rspq]);
7725ccfd
JH
88}
89
90void
91bfa_hwct_msix_getvecs(struct bfa_s *bfa, u32 *msix_vecs_bmap,
92 u32 *num_vecs, u32 *max_vec_bit)
93{
11189208
KG
94 *msix_vecs_bmap = (1 << BFI_MSIX_CT_MAX) - 1;
95 *max_vec_bit = (1 << (BFI_MSIX_CT_MAX - 1));
96 *num_vecs = BFI_MSIX_CT_MAX;
7725ccfd
JH
97}
98
5fbe25c7 99/*
7725ccfd
JH
100 * Setup MSI-X vector for catapult
101 */
102void
103bfa_hwct_msix_init(struct bfa_s *bfa, int nvecs)
104{
11189208 105 WARN_ON((nvecs != 1) && (nvecs != BFI_MSIX_CT_MAX));
7725ccfd
JH
106 bfa_trc(bfa, nvecs);
107
108 bfa->msix.nvecs = nvecs;
109 bfa_hwct_msix_uninstall(bfa);
110}
111
112void
775c7742
KG
113bfa_hwct_msix_ctrl_install(struct bfa_s *bfa)
114{
115 if (bfa->msix.nvecs == 0)
116 return;
117
118 if (bfa->msix.nvecs == 1)
119 bfa->msix.handler[BFI_MSIX_LPU_ERR_CT] = bfa_msix_all;
120 else
121 bfa->msix.handler[BFI_MSIX_LPU_ERR_CT] = bfa_msix_lpu_err;
122}
123
124void
125bfa_hwct_msix_queue_install(struct bfa_s *bfa)
7725ccfd
JH
126{
127 int i;
128
129 if (bfa->msix.nvecs == 0)
130 return;
131
132 if (bfa->msix.nvecs == 1) {
775c7742 133 for (i = BFI_MSIX_CPE_QMIN_CT; i < BFI_MSIX_CT_MAX; i++)
7725ccfd
JH
134 bfa->msix.handler[i] = bfa_msix_all;
135 return;
136 }
137
11189208 138 for (i = BFI_MSIX_CPE_QMIN_CT; i <= BFI_MSIX_CPE_QMAX_CT; i++)
7725ccfd
JH
139 bfa->msix.handler[i] = bfa_msix_reqq;
140
11189208 141 for (i = BFI_MSIX_RME_QMIN_CT; i <= BFI_MSIX_RME_QMAX_CT; i++)
7725ccfd 142 bfa->msix.handler[i] = bfa_msix_rspq;
7725ccfd
JH
143}
144
145void
146bfa_hwct_msix_uninstall(struct bfa_s *bfa)
147{
148 int i;
149
11189208 150 for (i = 0; i < BFI_MSIX_CT_MAX; i++)
7725ccfd
JH
151 bfa->msix.handler[i] = bfa_hwct_msix_dummy;
152}
153
5fbe25c7 154/*
7725ccfd
JH
155 * Enable MSI-X vectors
156 */
157void
158bfa_hwct_isr_mode_set(struct bfa_s *bfa, bfa_boolean_t msix)
159{
160 bfa_trc(bfa, 0);
7725ccfd
JH
161 bfa_ioc_isr_mode_set(&bfa->ioc, msix);
162}
163
36d345a7
JH
164void
165bfa_hwct_msix_get_rme_range(struct bfa_s *bfa, u32 *start, u32 *end)
166{
11189208
KG
167 *start = BFI_MSIX_RME_QMIN_CT;
168 *end = BFI_MSIX_RME_QMAX_CT;
36d345a7 169}