xref: /dpdk/drivers/common/mlx5/windows/mlx5_win_ext.h (revision 165e5d07ce8880f47d2d4428c9537cf04d4ae87b)
17525ebd8STal Shnaiderman /*
27525ebd8STal Shnaiderman  * Copyright (C) Mellanox Technologies, Ltd. 2001-2020.
37525ebd8STal Shnaiderman  *
47525ebd8STal Shnaiderman  */
57525ebd8STal Shnaiderman #ifndef __MLX5_WIN_ETX_H__
67525ebd8STal Shnaiderman #define __MLX5_WIN_ETX_H__
77525ebd8STal Shnaiderman 
87525ebd8STal Shnaiderman #ifdef __cplusplus
97525ebd8STal Shnaiderman extern "C" {
107525ebd8STal Shnaiderman #endif
117525ebd8STal Shnaiderman 
127525ebd8STal Shnaiderman #include "mlx5devx.h"
137525ebd8STal Shnaiderman 
147525ebd8STal Shnaiderman typedef struct mlx5_context {
157525ebd8STal Shnaiderman 	devx_device_ctx        *devx_ctx;
167525ebd8STal Shnaiderman 	struct devx_device mlx5_dev;
17*165e5d07STal Shnaiderman 	struct devx_shutdown_event shutdown_event_obj;
187525ebd8STal Shnaiderman } mlx5_context_st;
197525ebd8STal Shnaiderman 
207525ebd8STal Shnaiderman typedef struct {
217525ebd8STal Shnaiderman 	devx_device_ctx *devx_ctx;
227525ebd8STal Shnaiderman 	struct devx_obj_handle *obj;
237525ebd8STal Shnaiderman } mlx5_devx_obj_st;
247525ebd8STal Shnaiderman 
257525ebd8STal Shnaiderman struct mlx5_devx_umem {
267525ebd8STal Shnaiderman 	void                   *addr;
277525ebd8STal Shnaiderman 	struct devx_obj_handle *umem_hdl;
287525ebd8STal Shnaiderman 	uint32_t                umem_id;
297525ebd8STal Shnaiderman };
307525ebd8STal Shnaiderman 
311552fb28STal Shnaiderman struct mlx5_pd {
321552fb28STal Shnaiderman 	void                   *obj;
331552fb28STal Shnaiderman 	uint32_t                pdn;
341552fb28STal Shnaiderman 	devx_device_ctx        *devx_ctx;
351552fb28STal Shnaiderman };
361552fb28STal Shnaiderman 
3799d7c45cSTal Shnaiderman struct mlx5_devx_clock {
3899d7c45cSTal Shnaiderman 	void *p_iseg_internal_timer;
3999d7c45cSTal Shnaiderman 	u64 clock_frequency_hz;
4099d7c45cSTal Shnaiderman 	int is_stable_clock_frequency;
4199d7c45cSTal Shnaiderman };
4299d7c45cSTal Shnaiderman 
437525ebd8STal Shnaiderman #define GET_DEVX_CTX(ctx) (((mlx5_context_st *)ctx)->devx_ctx)
447525ebd8STal Shnaiderman #define GET_OBJ_CTX(obj)  (((mlx5_devx_obj_st *)obj)->devx_ctx)
457525ebd8STal Shnaiderman 
467525ebd8STal Shnaiderman #endif /* __MLX5_WIN_ETX_H__ */
47