1f0129207SStephen Hemminger /* SPDX-License-Identifier: BSD-3-Clause 27525ebd8STal Shnaiderman * Copyright (C) Mellanox Technologies, Ltd. 2001-2020. 37525ebd8STal Shnaiderman */ 4f0129207SStephen Hemminger 57525ebd8STal Shnaiderman #ifndef __MLX5_WIN_ETX_H__ 67525ebd8STal Shnaiderman #define __MLX5_WIN_ETX_H__ 77525ebd8STal Shnaiderman 8*2744cb6eSThomas Monjalon #include <pthread.h> 9*2744cb6eSThomas Monjalon 109dab4d62SMichael Baum #include "mlx5_prm.h" 117525ebd8STal Shnaiderman #include "mlx5devx.h" 127525ebd8STal Shnaiderman 137525ebd8STal Shnaiderman typedef struct mlx5_context { 147525ebd8STal Shnaiderman devx_device_ctx *devx_ctx; 157525ebd8STal Shnaiderman struct devx_device mlx5_dev; 16165e5d07STal Shnaiderman struct devx_shutdown_event shutdown_event_obj; 177525ebd8STal Shnaiderman } mlx5_context_st; 187525ebd8STal Shnaiderman 197525ebd8STal Shnaiderman typedef struct { 207525ebd8STal Shnaiderman devx_device_ctx *devx_ctx; 217525ebd8STal Shnaiderman struct devx_obj_handle *obj; 227525ebd8STal Shnaiderman } mlx5_devx_obj_st; 237525ebd8STal Shnaiderman 247525ebd8STal Shnaiderman struct mlx5_devx_umem { 257525ebd8STal Shnaiderman void *addr; 267525ebd8STal Shnaiderman struct devx_obj_handle *umem_hdl; 277525ebd8STal Shnaiderman uint32_t umem_id; 287525ebd8STal Shnaiderman }; 297525ebd8STal Shnaiderman 301552fb28STal Shnaiderman struct mlx5_pd { 311552fb28STal Shnaiderman void *obj; 321552fb28STal Shnaiderman uint32_t pdn; 331552fb28STal Shnaiderman devx_device_ctx *devx_ctx; 341552fb28STal Shnaiderman }; 351552fb28STal Shnaiderman 3699d7c45cSTal Shnaiderman struct mlx5_devx_clock { 3799d7c45cSTal Shnaiderman void *p_iseg_internal_timer; 3899d7c45cSTal Shnaiderman u64 clock_frequency_hz; 3999d7c45cSTal Shnaiderman int is_stable_clock_frequency; 4099d7c45cSTal Shnaiderman }; 4199d7c45cSTal Shnaiderman 427525ebd8STal Shnaiderman #define GET_DEVX_CTX(ctx) (((mlx5_context_st *)ctx)->devx_ctx) 437525ebd8STal Shnaiderman #define GET_OBJ_CTX(obj) (((mlx5_devx_obj_st *)obj)->devx_ctx) 447525ebd8STal Shnaiderman 457525ebd8STal Shnaiderman #endif /* __MLX5_WIN_ETX_H__ */ 46