| /* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */ | 
 | /* | 
 |  * Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved | 
 |  */ | 
 |  | 
 | #ifndef _IB_UCAPS_H_ | 
 | #define _IB_UCAPS_H_ | 
 |  | 
 | #define UCAP_ENABLED(ucaps, type) (!!((ucaps) & (1U << (type)))) | 
 |  | 
 | enum rdma_user_cap { | 
 | 	RDMA_UCAP_MLX5_CTRL_LOCAL, | 
 | 	RDMA_UCAP_MLX5_CTRL_OTHER_VHCA, | 
 | 	RDMA_UCAP_MAX | 
 | }; | 
 |  | 
 | void ib_cleanup_ucaps(void); | 
 | int ib_get_ucaps(int *fds, int fd_count, uint64_t *idx_mask); | 
 | #if IS_ENABLED(CONFIG_INFINIBAND_USER_ACCESS) | 
 | int ib_create_ucap(enum rdma_user_cap type); | 
 | void ib_remove_ucap(enum rdma_user_cap type); | 
 | #else | 
 | static inline int ib_create_ucap(enum rdma_user_cap type) | 
 | { | 
 | 	return -EOPNOTSUPP; | 
 | } | 
 | static inline void ib_remove_ucap(enum rdma_user_cap type) {} | 
 | #endif /* CONFIG_INFINIBAND_USER_ACCESS */ | 
 |  | 
 | #endif /* _IB_UCAPS_H_ */ |