bus/fslmc: cleanup the dpaa2 interrupt support
[dpdk.git] / drivers / bus / fslmc / fslmc_vfio.h
index 53dd0b7..5470a41 100644 (file)
@@ -2,7 +2,7 @@
  *   BSD LICENSE
  *
  *   Copyright (c) 2015-2016 Freescale Semiconductor, Inc. All rights reserved.
- *   Copyright (c) 2016 NXP. All rights reserved.
+ *   Copyright 2016 NXP.
  *
  *   Redistribution and use in source and binary forms, with or without
  *   modification, are permitted provided that the following conditions
 
 #include "eal_vfio.h"
 
-#define DPAA2_VENDOR_ID                0x1957
 #define DPAA2_MC_DPNI_DEVID    7
 #define DPAA2_MC_DPSECI_DEVID  3
-
-#define VFIO_MAX_GRP 1
+#define DPAA2_MC_DPCON_DEVID   5
+#define DPAA2_MC_DPIO_DEVID    9
+#define DPAA2_MC_DPBP_DEVID    10
+#define DPAA2_MC_DPCI_DEVID    11
 
 typedef struct fslmc_vfio_device {
        int fd; /* fslmc root container device ?? */
@@ -60,23 +61,20 @@ typedef struct fslmc_vfio_container {
        int fd; /* /dev/vfio/vfio */
        int used;
        int index; /* index in group list */
-       struct fslmc_vfio_group *group_list[VFIO_MAX_GRP];
+       struct fslmc_vfio_group *group;
 } fslmc_vfio_container;
 
-int vfio_dmamap_mem_region(
-       uint64_t vaddr,
-       uint64_t iova,
-       uint64_t size);
+int rte_dpaa2_intr_enable(struct rte_intr_handle *intr_handle, int index);
+int rte_dpaa2_intr_disable(struct rte_intr_handle *intr_handle, int index);
+
+int rte_dpaa2_vfio_setup_intr(struct rte_intr_handle *intr_handle,
+                             int vfio_dev_fd,
+                             int num_irqs);
 
 int fslmc_vfio_setup_group(void);
 int fslmc_vfio_process_group(void);
+char *fslmc_get_container(void);
+int fslmc_get_container_group(int *gropuid);
 int rte_fslmc_vfio_dmamap(void);
 
-/* create dpio device */
-int dpaa2_create_dpio_device(struct fslmc_vfio_device *vdev,
-                            struct vfio_device_info *obj_info,
-                            int object_id);
-
-int dpaa2_create_dpbp_device(int dpbp_id);
-
 #endif /* _FSLMC_VFIO_H_ */