Linux Audio

Check our new training course

Yocto distribution development and maintenance

Need a Yocto distribution for your embedded project?
Loading...
  1/* SPDX-License-Identifier: GPL-2.0 */
  2/* Copyright (c) 2021 HiSilicon Ltd. */
  3
  4#ifndef HISI_ACC_VFIO_PCI_H
  5#define HISI_ACC_VFIO_PCI_H
  6
  7#include <linux/hisi_acc_qm.h>
  8
  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
 19
 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
 27
 28#define ERROR_CHECK_TIMEOUT		100
 29#define CHECK_DELAY_TIME		100
 30
 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)
 35#define QM_MB_CMD_NOT_READY	0xffffffff
 36
 37/* RW regs */
 38#define QM_REGS_MAX_LEN		7
 39#define QM_REG_ADDR_OFFSET	0x0004
 40
 41#define QM_XQC_ADDR_OFFSET	32U
 42#define QM_VF_AEQ_INT_MASK	0x0004
 43#define QM_VF_EQ_INT_MASK	0x000c
 44#define QM_IFC_INT_SOURCE_V	0x0020
 45#define QM_IFC_INT_MASK		0x0024
 46#define QM_IFC_INT_SET_V	0x002c
 47#define QM_QUE_ISO_CFG_V	0x0030
 48#define QM_PAGE_SIZE		0x0034
 49
 50#define QM_EQC_DW0		0X8000
 51#define QM_AEQC_DW0		0X8020
 52
 53struct acc_vf_data {
 54#define QM_MATCH_SIZE offsetofend(struct acc_vf_data, qm_rsv_state)
 55	/* QM match information */
 56#define ACC_DEV_MAGIC	0XCDCDCDCDFEEDAACC
 57	u64 acc_magic;
 58	u32 qp_num;
 59	u32 dev_id;
 60	u32 que_iso_cfg;
 61	u32 qp_base;
 62	u32 vf_qm_state;
 63	/* QM reserved match information */
 64	u32 qm_rsv_state[3];
 65
 66	/* QM RW regs */
 67	u32 aeq_int_mask;
 68	u32 eq_int_mask;
 69	u32 ifc_int_source;
 70	u32 ifc_int_mask;
 71	u32 ifc_int_set;
 72	u32 page_size;
 73
 74	/* QM_EQC_DW has 7 regs */
 75	u32 qm_eqc_dw[7];
 76
 77	/* QM_AEQC_DW has 7 regs */
 78	u32 qm_aeqc_dw[7];
 79
 80	/* QM reserved 5 regs */
 81	u32 qm_rsv_regs[5];
 82	u32 padding;
 83	/* QM memory init information */
 84	u64 eqe_dma;
 85	u64 aeqe_dma;
 86	u64 sqc_dma;
 87	u64 cqc_dma;
 88};
 89
 90struct hisi_acc_vf_migration_file {
 91	struct file *filp;
 92	struct mutex lock;
 93	bool disabled;
 94
 95	struct hisi_acc_vf_core_device *hisi_acc_vdev;
 96	struct acc_vf_data vf_data;
 97	size_t total_length;
 98};
 99
100struct hisi_acc_vf_core_device {
101	struct vfio_pci_core_device core_device;
102	u8 match_done;
103	/*
104	 * io_base is only valid when dev_opened is true,
105	 * which is protected by open_mutex.
106	 */
107	bool dev_opened;
108	/* Ensure the accuracy of dev_opened operation */
109	struct mutex open_mutex;
110
111	/* For migration state */
112	struct mutex state_mutex;
113	enum vfio_device_mig_state mig_state;
114	struct pci_dev *pf_dev;
115	struct pci_dev *vf_dev;
116	struct hisi_qm *pf_qm;
117	struct hisi_qm vf_qm;
118	/*
119	 * vf_qm_state represents the QM_VF_STATE register value.
120	 * It is set by Guest driver for the ACC VF dev indicating
121	 * the driver has loaded and configured the dev correctly.
122	 */
123	u32 vf_qm_state;
124	int vf_id;
125	struct hisi_acc_vf_migration_file *resuming_migf;
126	struct hisi_acc_vf_migration_file *saving_migf;
127
128	/*
129	 * It holds migration data corresponding to the last migration
130	 * and is used by the debugfs interface to report it.
131	 */
132	struct hisi_acc_vf_migration_file *debug_migf;
133};
134#endif /* HISI_ACC_VFIO_PCI_H */