Lines Matching defs:ib_device_ops
2334 struct ib_device_ops { struct
2335 struct module *owner;
2336 enum rdma_driver_id driver_id;
2337 u32 uverbs_abi_ver;
2338 unsigned int uverbs_no_driver_id_binding:1;
2345 const struct attribute_group *device_group;
2346 const struct attribute_group **port_groups;
2348 int (*post_send)(struct ib_qp *qp, const struct ib_send_wr *send_wr,
2350 int (*post_recv)(struct ib_qp *qp, const struct ib_recv_wr *recv_wr,
2352 void (*drain_rq)(struct ib_qp *qp);
2353 void (*drain_sq)(struct ib_qp *qp);
2354 int (*poll_cq)(struct ib_cq *cq, int num_entries, struct ib_wc *wc);
2355 int (*peek_cq)(struct ib_cq *cq, int wc_cnt);
2356 int (*req_notify_cq)(struct ib_cq *cq, enum ib_cq_notify_flags flags);
2357 int (*post_srq_recv)(struct ib_srq *srq,
2360 int (*process_mad)(struct ib_device *device, int process_mad_flags,
2365 int (*query_device)(struct ib_device *device,
2368 int (*modify_device)(struct ib_device *device, int device_modify_mask,
2370 void (*get_dev_fw_str)(struct ib_device *device, char *str);
2371 const struct cpumask *(*get_vector_affinity)(struct ib_device *ibdev,
2373 int (*query_port)(struct ib_device *device, u32 port_num,
2375 int (*modify_port)(struct ib_device *device, u32 port_num,
2384 int (*get_port_immutable)(struct ib_device *device, u32 port_num,
2386 enum rdma_link_layer (*get_link_layer)(struct ib_device *device,
2396 struct net_device *(*get_netdev)(struct ib_device *device,
2404 struct net_device *(*alloc_rdma_netdev)(
2409 int (*rdma_netdev_get_params)(struct ib_device *device, u32 port_num,
2417 int (*query_gid)(struct ib_device *device, u32 port_num, int index,
2432 int (*add_gid)(const struct ib_gid_attr *attr, void **context);
2441 int (*del_gid)(const struct ib_gid_attr *attr, void **context);
2442 int (*query_pkey)(struct ib_device *device, u32 port_num, u16 index,
2444 int (*alloc_ucontext)(struct ib_ucontext *context,
2446 void (*dealloc_ucontext)(struct ib_ucontext *context);
2447 int (*mmap)(struct ib_ucontext *context, struct vm_area_struct *vma);
2454 void (*mmap_free)(struct rdma_user_mmap_entry *entry);
2455 void (*disassociate_ucontext)(struct ib_ucontext *ibcontext);
2456 int (*alloc_pd)(struct ib_pd *pd, struct ib_udata *udata);
2457 int (*dealloc_pd)(struct ib_pd *pd, struct ib_udata *udata);
2458 int (*create_ah)(struct ib_ah *ah, struct rdma_ah_init_attr *attr,
2460 int (*create_user_ah)(struct ib_ah *ah, struct rdma_ah_init_attr *attr,
2462 int (*modify_ah)(struct ib_ah *ah, struct rdma_ah_attr *ah_attr);
2463 int (*query_ah)(struct ib_ah *ah, struct rdma_ah_attr *ah_attr);
2464 int (*destroy_ah)(struct ib_ah *ah, u32 flags);
2465 int (*create_srq)(struct ib_srq *srq,
2468 int (*modify_srq)(struct ib_srq *srq, struct ib_srq_attr *srq_attr,
2471 int (*query_srq)(struct ib_srq *srq, struct ib_srq_attr *srq_attr);
2472 int (*destroy_srq)(struct ib_srq *srq, struct ib_udata *udata);
2473 int (*create_qp)(struct ib_qp *qp, struct ib_qp_init_attr *qp_init_attr,
2475 int (*modify_qp)(struct ib_qp *qp, struct ib_qp_attr *qp_attr,
2477 int (*query_qp)(struct ib_qp *qp, struct ib_qp_attr *qp_attr,
2479 int (*destroy_qp)(struct ib_qp *qp, struct ib_udata *udata);
2480 int (*create_cq)(struct ib_cq *cq, const struct ib_cq_init_attr *attr,
2482 int (*modify_cq)(struct ib_cq *cq, u16 cq_count, u16 cq_period);
2483 int (*destroy_cq)(struct ib_cq *cq, struct ib_udata *udata);
2484 int (*resize_cq)(struct ib_cq *cq, int cqe, struct ib_udata *udata);
2485 struct ib_mr *(*get_dma_mr)(struct ib_pd *pd, int mr_access_flags);
2486 struct ib_mr *(*reg_user_mr)(struct ib_pd *pd, u64 start, u64 length,
2489 struct ib_mr *(*reg_user_mr_dmabuf)(struct ib_pd *pd, u64 offset,
2493 struct ib_mr *(*rereg_user_mr)(struct ib_mr *mr, int flags, u64 start,
2497 int (*dereg_mr)(struct ib_mr *mr, struct ib_udata *udata);
2498 struct ib_mr *(*alloc_mr)(struct ib_pd *pd, enum ib_mr_type mr_type,
2500 struct ib_mr *(*alloc_mr_integrity)(struct ib_pd *pd,
2503 int (*advise_mr)(struct ib_pd *pd,
2515 int (*map_mr_sg)(struct ib_mr *mr, struct scatterlist *sg, int sg_nents,
2517 int (*check_mr_status)(struct ib_mr *mr, u32 check_mask,
2519 int (*alloc_mw)(struct ib_mw *mw, struct ib_udata *udata);
2520 int (*dealloc_mw)(struct ib_mw *mw);
2521 int (*attach_mcast)(struct ib_qp *qp, union ib_gid *gid, u16 lid);
2522 int (*detach_mcast)(struct ib_qp *qp, union ib_gid *gid, u16 lid);
2523 int (*alloc_xrcd)(struct ib_xrcd *xrcd, struct ib_udata *udata);
2524 int (*dealloc_xrcd)(struct ib_xrcd *xrcd, struct ib_udata *udata);
2525 struct ib_flow *(*create_flow)(struct ib_qp *qp,
2528 int (*destroy_flow)(struct ib_flow *flow_id);
2529 int (*destroy_flow_action)(struct ib_flow_action *action);
2530 int (*set_vf_link_state)(struct ib_device *device, int vf, u32 port,
2532 int (*get_vf_config)(struct ib_device *device, int vf, u32 port,
2534 int (*get_vf_stats)(struct ib_device *device, int vf, u32 port,
2536 int (*get_vf_guid)(struct ib_device *device, int vf, u32 port,
2539 int (*set_vf_guid)(struct ib_device *device, int vf, u32 port, u64 guid,
2541 struct ib_wq *(*create_wq)(struct ib_pd *pd,
2544 int (*destroy_wq)(struct ib_wq *wq, struct ib_udata *udata);
2545 int (*modify_wq)(struct ib_wq *wq, struct ib_wq_attr *attr,
2547 int (*create_rwq_ind_table)(struct ib_rwq_ind_table *ib_rwq_ind_table,
2550 int (*destroy_rwq_ind_table)(struct ib_rwq_ind_table *wq_ind_table);
2551 struct ib_dm *(*alloc_dm)(struct ib_device *device,
2555 int (*dealloc_dm)(struct ib_dm *dm, struct uverbs_attr_bundle *attrs);
2556 struct ib_mr *(*reg_dm_mr)(struct ib_pd *pd, struct ib_dm *dm,
2559 int (*create_counters)(struct ib_counters *counters,
2561 int (*destroy_counters)(struct ib_counters *counters);
2562 int (*read_counters)(struct ib_counters *counters,
2565 int (*map_mr_sg_pi)(struct ib_mr *mr, struct scatterlist *data_sg,
2576 struct rdma_hw_stats *(*alloc_hw_device_stats)(struct ib_device *device);
2577 struct rdma_hw_stats *(*alloc_hw_port_stats)(struct ib_device *device,
2591 int (*get_hw_stats)(struct ib_device *device,
2599 int (*modify_hw_stat)(struct ib_device *device, u32 port,
2604 int (*fill_res_mr_entry)(struct sk_buff *msg, struct ib_mr *ibmr);
2605 int (*fill_res_mr_entry_raw)(struct sk_buff *msg, struct ib_mr *ibmr);
2606 int (*fill_res_cq_entry)(struct sk_buff *msg, struct ib_cq *ibcq);
2607 int (*fill_res_cq_entry_raw)(struct sk_buff *msg, struct ib_cq *ibcq);
2608 int (*fill_res_qp_entry)(struct sk_buff *msg, struct ib_qp *ibqp);
2609 int (*fill_res_qp_entry_raw)(struct sk_buff *msg, struct ib_qp *ibqp);
2610 int (*fill_res_cm_id_entry)(struct sk_buff *msg, struct rdma_cm_id *id);
2617 int (*enable_driver)(struct ib_device *dev);
2621 void (*dealloc_driver)(struct ib_device *dev);
2624 void (*iw_add_ref)(struct ib_qp *qp);
2625 void (*iw_rem_ref)(struct ib_qp *qp);
2626 struct ib_qp *(*iw_get_qp)(struct ib_device *device, int qpn);
2627 int (*iw_connect)(struct iw_cm_id *cm_id,
2629 int (*iw_accept)(struct iw_cm_id *cm_id,
2631 int (*iw_reject)(struct iw_cm_id *cm_id, const void *pdata,
2633 int (*iw_create_listen)(struct iw_cm_id *cm_id, int backlog);
2634 int (*iw_destroy_listen)(struct iw_cm_id *cm_id);
2640 int (*counter_bind_qp)(struct rdma_counter *counter, struct ib_qp *qp);
2645 int (*counter_unbind_qp)(struct ib_qp *qp);
2649 int (*counter_dealloc)(struct rdma_counter *counter);
2654 struct rdma_hw_stats *(*counter_alloc_stats)(
2659 int (*counter_update_stats)(struct rdma_counter *counter);
2665 int (*fill_stat_mr_entry)(struct sk_buff *msg, struct ib_mr *ibmr);
2668 int (*query_ucontext)(struct ib_ucontext *context,
2675 int (*get_numa_node)(struct ib_device *dev);