blob: 3dd19d323164f49fae712674b6540147b4912131 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
/*
* IOMMU domain allocator for edgetpu
*
* Copyright (C) 2022 Google LLC
*/
#ifndef __EDGETPU_DOMAIN_POOL_H__
#define __EDGETPU_DOMAIN_POOL_H__
#include <linux/idr.h>
#include <linux/iommu.h>
#include "edgetpu-internal.h"
struct edgetpu_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 edgetpu_dev *etdev; /* The edgetpu device used for logging warnings/errors. */
};
/*
* Initializes a domain pool.
*
* @etdev: pointer to edgeptu 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 edgetpu_domain_pool_init(struct edgetpu_dev *etdev, struct edgetpu_domain_pool *pool,
unsigned int size);
/*
* Allocates a domain from the pool
* returns NULL on error.
*/
struct iommu_domain *edgetpu_domain_pool_alloc(struct edgetpu_domain_pool *pool);
/* Releases a domain from the pool. */
void edgetpu_domain_pool_free(struct edgetpu_domain_pool *pool, struct iommu_domain *domain);
/* Cleans up all resources used by the domain pool. */
void edgetpu_domain_pool_destroy(struct edgetpu_domain_pool *pool);
#endif /* __EDGETPU_DOMAIN_POOL_H__ */