#ifndef _SYS_PX_VAR_H
#define _SYS_PX_VAR_H
#include <sys/callb.h>
#ifdef __cplusplus
extern "C" {
#endif
#define PX_CONFIG 0x001000000ull
#define PX_A_IO 0x002000000ull
#define PX_B_IO 0x002010000ull
#define PX_A_MEMORY 0x100000000ull
#define PX_B_MEMORY 0x180000000ull
#define PX_IO_SIZE 0x000010000ull
#define PX_MEM_SIZE 0x080000000ull
typedef struct px_nexus_regspec {
uint64_t phys_addr;
uint64_t size;
} px_nexus_regspec_t;
typedef enum {
PX_ATTACHED = 1,
PX_DETACHED,
PX_SUSPENDED
} px_state_t;
enum { PX_INTR_XBC, PX_INTR_PEC, PX_INTR_HOTPLUG };
#define PX_ATTACH_RETCODE(obj, op, err) \
((err) ? (obj) << 8 | (op) << 4 | (err) & 0xf : DDI_SUCCESS)
struct px {
px_state_t px_state;
uint_t px_soft_state;
kmutex_t px_mutex;
dev_info_t *px_dip;
devhandle_t px_dev_hdl;
px_ib_t *px_ib_p;
px_pec_t *px_pec_p;
px_mmu_t *px_mmu_p;
pcie_req_id_t px_bdf;
pci_bus_range_t px_bus_range;
pci_ranges_t *px_ranges_p;
int px_ranges_length;
devino_t *px_inos;
int px_inos_len;
px_fault_t px_fault;
px_fault_t px_cb_fault;
int px_fm_cap;
kmutex_t px_fm_mutex;
kthread_t *px_fm_mutex_owner;
ddi_iblock_cookie_t px_fm_ibc;
pf_data_t px_pfd_arr[5];
int px_pfd_idx;
uint32_t px_dev_caps;
void *px_plat_p;
int px_supp_intr_types;
kmutex_t px_l23ready_lock;
kcondvar_t px_l23ready_cv;
volatile uint32_t px_lup_pending;
int px_pm_flags;
msiqid_t px_pm_msiq_id;
uint32_t px_pmetoack_ignored;
callb_id_t px_cprcb_id;
uint32_t px_dma_sync_opt;
ddi_softint_handle_t px_dbg_hdl;
};
#define PX_BYPASS_DMA_ALLOWED 1
#define PX_DMA_SYNC_REQUIRED 4
#define PX_PMETOACK_RECVD 0x01
#define PX_PME_TURNOFF_PENDING 0x02
#define PX_LDN_EXPECTED 0x04
#define DIP_TO_INST(dip) ddi_get_instance(dip)
#define INST_TO_STATE(inst) ddi_get_soft_state(px_state_p, inst)
#define DIP_TO_STATE(dip) INST_TO_STATE(DIP_TO_INST(dip))
#define PX_DEV_TO_SOFTSTATE(dev) ((px_t *)ddi_get_soft_state( \
px_state_p, PCI_MINOR_NUM_TO_INSTANCE(getminor(dev))))
extern void *px_state_p;
extern int
px_map(dev_info_t *dip, dev_info_t *rdip, ddi_map_req_t *mp,
off_t offset, off_t len, caddr_t *addrp);
extern int
px_dma_setup(dev_info_t *dip, dev_info_t *rdip,
ddi_dma_req_t *dmareq, ddi_dma_handle_t *handlep);
extern int
px_dma_allochdl(dev_info_t *dip, dev_info_t *rdip, ddi_dma_attr_t *attrp,
int (*waitfp)(caddr_t), caddr_t arg, ddi_dma_handle_t *handlep);
extern int
px_dma_bindhdl(dev_info_t *dip, dev_info_t *rdip,
ddi_dma_handle_t handle, ddi_dma_req_t *dmareq,
ddi_dma_cookie_t *cookiep, uint_t *ccountp);
extern int
px_dma_unbindhdl(dev_info_t *dip, dev_info_t *rdip,
ddi_dma_handle_t handle);
extern int
px_dma_ctlops(dev_info_t *dip, dev_info_t *rdip, ddi_dma_handle_t handle,
enum ddi_dma_ctlops cmd, off_t *offp, size_t *lenp, caddr_t *objp,
uint_t cache_flags);
extern int
px_ctlops(dev_info_t *dip, dev_info_t *rdip,
ddi_ctl_enum_t op, void *arg, void *result);
extern int
px_intr_ops(dev_info_t *dip, dev_info_t *rdip, ddi_intr_op_t intr_op,
ddi_intr_handle_impl_t *handle, void *result);
#ifdef __cplusplus
}
#endif
#endif