blob: ee95155575d978423469c64da051d177b9a5c099 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
/*
* IOMMU domain allocator for gxp
*
* Copyright (C) 2022 Google LLC
*/
#ifndef __GXP_DOMAIN_POOL_H__
#define __GXP_DOMAIN_POOL_H__
#include <linux/idr.h>
#include <linux/iommu.h>
#include "gxp-internal.h"
struct gxp_domain_pool {
struct ida idp; /* ID allocator to keep track of used domains. */
/*
* Size of the pool. Can be set to 0, in which case the implementation will fall back to
* dynamic domain allocation using the IOMMU API directly.
*/
unsigned int size;
struct iommu_domain **array; /* Array holding the pointers to pre-allocated domains. */
struct gxp_dev *gxp; /* The gxp device used for logging warnings/errors. */
};
/*
* Initializes a domain pool.
*
* @gxp: pointer to gxp device.
* @pool: caller-allocated pool structure.
* @size: size of the pre-allocated domains pool.
* Set to zero to fall back to dynamically allocated domains.
*
* returns 0 on success or negative error value.
*/
int gxp_domain_pool_init(struct gxp_dev *gxp, struct gxp_domain_pool *pool,
unsigned int size);
/*
* Allocates a domain from the pool
* returns NULL on error.
*/
struct iommu_domain *gxp_domain_pool_alloc(struct gxp_domain_pool *pool);
/* Releases a domain from the pool. */
void gxp_domain_pool_free(struct gxp_domain_pool *pool, struct iommu_domain *domain);
/* Cleans up all resources used by the domain pool. */
void gxp_domain_pool_destroy(struct gxp_domain_pool *pool);
#endif /* __GXP_DOMAIN_POOL_H__ */