mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-09 23:34:42 +08:00
da119f387e
FSL uses the internal reflck to implement the open_device() functionality, conversion to the core code is straightforward. The decision on which set to be part of is trivially based on the is_fsl_mc_bus_dprc() and we use a 'struct device *' pointer as the set_id. The dev_set lock is protecting the interrupts setup. The FSL MC devices are using MSIs and only the DPRC device is allocating the MSIs from the MSI domain. The other devices just take interrupts from a pool. The lock is protecting the access to this pool. Signed-off-by: Yishai Hadas <yishaih@nvidia.com> Tested-by: Diana Craciun OSS <diana.craciun@oss.nxp.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com> Link: https://lore.kernel.org/r/6-v4-9ea22c5e6afb+1adf-vfio_reflck_jgg@nvidia.com Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
50 lines
1.2 KiB
C
50 lines
1.2 KiB
C
/* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */
|
|
/*
|
|
* Copyright 2013-2016 Freescale Semiconductor Inc.
|
|
* Copyright 2016,2019-2020 NXP
|
|
*/
|
|
|
|
#ifndef VFIO_FSL_MC_PRIVATE_H
|
|
#define VFIO_FSL_MC_PRIVATE_H
|
|
|
|
#define VFIO_FSL_MC_OFFSET_SHIFT 40
|
|
#define VFIO_FSL_MC_OFFSET_MASK (((u64)(1) << VFIO_FSL_MC_OFFSET_SHIFT) - 1)
|
|
|
|
#define VFIO_FSL_MC_OFFSET_TO_INDEX(off) ((off) >> VFIO_FSL_MC_OFFSET_SHIFT)
|
|
|
|
#define VFIO_FSL_MC_INDEX_TO_OFFSET(index) \
|
|
((u64)(index) << VFIO_FSL_MC_OFFSET_SHIFT)
|
|
|
|
struct vfio_fsl_mc_irq {
|
|
u32 flags;
|
|
u32 count;
|
|
struct eventfd_ctx *trigger;
|
|
char *name;
|
|
};
|
|
|
|
struct vfio_fsl_mc_region {
|
|
u32 flags;
|
|
u32 type;
|
|
u64 addr;
|
|
resource_size_t size;
|
|
void __iomem *ioaddr;
|
|
};
|
|
|
|
struct vfio_fsl_mc_device {
|
|
struct vfio_device vdev;
|
|
struct fsl_mc_device *mc_dev;
|
|
struct notifier_block nb;
|
|
struct vfio_fsl_mc_region *regions;
|
|
struct mutex igate;
|
|
struct vfio_fsl_mc_irq *mc_irqs;
|
|
};
|
|
|
|
extern int vfio_fsl_mc_set_irqs_ioctl(struct vfio_fsl_mc_device *vdev,
|
|
u32 flags, unsigned int index,
|
|
unsigned int start, unsigned int count,
|
|
void *data);
|
|
|
|
void vfio_fsl_mc_irqs_cleanup(struct vfio_fsl_mc_device *vdev);
|
|
|
|
#endif /* VFIO_FSL_MC_PRIVATE_H */
|