1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Copyright (c) 2021 HiSilicon Ltd. */
4 #ifndef HISI_ACC_VFIO_PCI_H
5 #define HISI_ACC_VFIO_PCI_H
7 #include <linux/hisi_acc_qm.h>
9 #define MB_POLL_PERIOD_US 10
10 #define MB_POLL_TIMEOUT_US 1000
11 #define QM_CACHE_WB_START 0x204
12 #define QM_CACHE_WB_DONE 0x208
13 #define QM_MB_CMD_PAUSE_QM 0xe
14 #define QM_ABNORMAL_INT_STATUS 0x100008
15 #define QM_IFC_INT_STATUS 0x0028
16 #define SEC_CORE_INT_STATUS 0x301008
17 #define HPRE_HAC_INT_STATUS 0x301800
18 #define HZIP_CORE_INT_STATUS 0x3010AC
20 #define QM_VFT_CFG_RDY 0x10006c
21 #define QM_VFT_CFG_OP_WR 0x100058
22 #define QM_VFT_CFG_TYPE 0x10005c
23 #define QM_VFT_CFG 0x100060
24 #define QM_VFT_CFG_OP_ENABLE 0x100054
25 #define QM_VFT_CFG_DATA_L 0x100064
26 #define QM_VFT_CFG_DATA_H 0x100068
28 #define ERROR_CHECK_TIMEOUT 100
29 #define CHECK_DELAY_TIME 100
31 #define QM_SQC_VFT_BASE_SHIFT_V2 28
32 #define QM_SQC_VFT_BASE_MASK_V2 GENMASK(15, 0)
33 #define QM_SQC_VFT_NUM_SHIFT_V2 45
34 #define QM_SQC_VFT_NUM_MASK_V2 GENMASK(9, 0)
37 #define QM_REGS_MAX_LEN 7
38 #define QM_REG_ADDR_OFFSET 0x0004
40 #define QM_XQC_ADDR_OFFSET 32U
41 #define QM_VF_AEQ_INT_MASK 0x0004
42 #define QM_VF_EQ_INT_MASK 0x000c
43 #define QM_IFC_INT_SOURCE_V 0x0020
44 #define QM_IFC_INT_MASK 0x0024
45 #define QM_IFC_INT_SET_V 0x002c
46 #define QM_QUE_ISO_CFG_V 0x0030
47 #define QM_PAGE_SIZE 0x0034
49 #define QM_EQC_DW0 0X8000
50 #define QM_AEQC_DW0 0X8020
53 #define QM_MATCH_SIZE offsetofend(struct acc_vf_data, qm_rsv_state)
54 /* QM match information */
55 #define ACC_DEV_MAGIC 0XCDCDCDCDFEEDAACC
62 /* QM reserved match information */
73 /* QM_EQC_DW has 7 regs */
76 /* QM_AEQC_DW has 7 regs */
79 /* QM reserved 5 regs */
82 /* QM memory init information */
89 struct hisi_acc_vf_migration_file
{
94 struct hisi_acc_vf_core_device
*hisi_acc_vdev
;
95 struct acc_vf_data vf_data
;
99 struct hisi_acc_vf_core_device
{
100 struct vfio_pci_core_device core_device
;
103 /* For migration state */
104 struct mutex state_mutex
;
105 enum vfio_device_mig_state mig_state
;
106 struct pci_dev
*pf_dev
;
107 struct pci_dev
*vf_dev
;
108 struct hisi_qm
*pf_qm
;
109 struct hisi_qm vf_qm
;
112 struct hisi_acc_vf_migration_file
*resuming_migf
;
113 struct hisi_acc_vf_migration_file
*saving_migf
;
115 #endif /* HISI_ACC_VFIO_PCI_H */