116 lines
2.7 KiB
C
116 lines
2.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/* Copyright (c) 2021 HiSilicon Ltd. */
|
|
|
|
#ifndef HISI_ACC_VFIO_PCI_H
|
|
#define HISI_ACC_VFIO_PCI_H
|
|
|
|
#include <linux/hisi_acc_qm.h>
|
|
|
|
#define MB_POLL_PERIOD_US 10
|
|
#define MB_POLL_TIMEOUT_US 1000
|
|
#define QM_CACHE_WB_START 0x204
|
|
#define QM_CACHE_WB_DONE 0x208
|
|
#define QM_MB_CMD_PAUSE_QM 0xe
|
|
#define QM_ABNORMAL_INT_STATUS 0x100008
|
|
#define QM_IFC_INT_STATUS 0x0028
|
|
#define SEC_CORE_INT_STATUS 0x301008
|
|
#define HPRE_HAC_INT_STATUS 0x301800
|
|
#define HZIP_CORE_INT_STATUS 0x3010AC
|
|
|
|
#define QM_VFT_CFG_RDY 0x10006c
|
|
#define QM_VFT_CFG_OP_WR 0x100058
|
|
#define QM_VFT_CFG_TYPE 0x10005c
|
|
#define QM_VFT_CFG 0x100060
|
|
#define QM_VFT_CFG_OP_ENABLE 0x100054
|
|
#define QM_VFT_CFG_DATA_L 0x100064
|
|
#define QM_VFT_CFG_DATA_H 0x100068
|
|
|
|
#define ERROR_CHECK_TIMEOUT 100
|
|
#define CHECK_DELAY_TIME 100
|
|
|
|
#define QM_SQC_VFT_BASE_SHIFT_V2 28
|
|
#define QM_SQC_VFT_BASE_MASK_V2 GENMASK(15, 0)
|
|
#define QM_SQC_VFT_NUM_SHIFT_V2 45
|
|
#define QM_SQC_VFT_NUM_MASK_V2 GENMASK(9, 0)
|
|
|
|
/* RW regs */
|
|
#define QM_REGS_MAX_LEN 7
|
|
#define QM_REG_ADDR_OFFSET 0x0004
|
|
|
|
#define QM_XQC_ADDR_OFFSET 32U
|
|
#define QM_VF_AEQ_INT_MASK 0x0004
|
|
#define QM_VF_EQ_INT_MASK 0x000c
|
|
#define QM_IFC_INT_SOURCE_V 0x0020
|
|
#define QM_IFC_INT_MASK 0x0024
|
|
#define QM_IFC_INT_SET_V 0x002c
|
|
#define QM_QUE_ISO_CFG_V 0x0030
|
|
#define QM_PAGE_SIZE 0x0034
|
|
|
|
#define QM_EQC_DW0 0X8000
|
|
#define QM_AEQC_DW0 0X8020
|
|
|
|
struct acc_vf_data {
|
|
#define QM_MATCH_SIZE offsetofend(struct acc_vf_data, qm_rsv_state)
|
|
/* QM match information */
|
|
#define ACC_DEV_MAGIC 0XCDCDCDCDFEEDAACC
|
|
u64 acc_magic;
|
|
u32 qp_num;
|
|
u32 dev_id;
|
|
u32 que_iso_cfg;
|
|
u32 qp_base;
|
|
u32 vf_qm_state;
|
|
/* QM reserved match information */
|
|
u32 qm_rsv_state[3];
|
|
|
|
/* QM RW regs */
|
|
u32 aeq_int_mask;
|
|
u32 eq_int_mask;
|
|
u32 ifc_int_source;
|
|
u32 ifc_int_mask;
|
|
u32 ifc_int_set;
|
|
u32 page_size;
|
|
|
|
/* QM_EQC_DW has 7 regs */
|
|
u32 qm_eqc_dw[7];
|
|
|
|
/* QM_AEQC_DW has 7 regs */
|
|
u32 qm_aeqc_dw[7];
|
|
|
|
/* QM reserved 5 regs */
|
|
u32 qm_rsv_regs[5];
|
|
u32 padding;
|
|
/* QM memory init information */
|
|
u64 eqe_dma;
|
|
u64 aeqe_dma;
|
|
u64 sqc_dma;
|
|
u64 cqc_dma;
|
|
};
|
|
|
|
struct hisi_acc_vf_migration_file {
|
|
struct file *filp;
|
|
struct mutex lock;
|
|
bool disabled;
|
|
|
|
struct acc_vf_data vf_data;
|
|
size_t total_length;
|
|
};
|
|
|
|
struct hisi_acc_vf_core_device {
|
|
struct vfio_pci_core_device core_device;
|
|
u8 deferred_reset:1;
|
|
/* For migration state */
|
|
struct mutex state_mutex;
|
|
enum vfio_device_mig_state mig_state;
|
|
struct pci_dev *pf_dev;
|
|
struct pci_dev *vf_dev;
|
|
struct hisi_qm *pf_qm;
|
|
struct hisi_qm vf_qm;
|
|
u32 vf_qm_state;
|
|
int vf_id;
|
|
/* For reset handler */
|
|
spinlock_t reset_lock;
|
|
struct hisi_acc_vf_migration_file *resuming_migf;
|
|
struct hisi_acc_vf_migration_file *saving_migf;
|
|
};
|
|
#endif /* HISI_ACC_VFIO_PCI_H */
|