| /* SPDX-License-Identifier: GPL-2.0 OR MIT */ |
| /* |
| * Copyright 2011 Red Hat Inc. |
| * Copyright © 2022 Intel Corporation |
| */ |
| #ifndef _DRM_SUBALLOC_H_ |
| #define _DRM_SUBALLOC_H_ |
| |
| #include <drm/drm_mm.h> |
| |
| #include <linux/dma-fence.h> |
| #include <linux/types.h> |
| |
| #define DRM_SUBALLOC_MAX_QUEUES 32 |
| /** |
| * struct drm_suballoc_manager - fenced range allocations |
| * @wq: Wait queue for sleeping allocations on contention. |
| * @hole: Pointer to first hole node. |
| * @olist: List of allocated ranges. |
| * @flist: Array[fence context hash] of queues of fenced allocated ranges. |
| * @size: Size of the managed range. |
| * @align: Default alignment for the managed range. |
| */ |
| struct drm_suballoc_manager { |
| wait_queue_head_t wq; |
| struct list_head *hole; |
| struct list_head olist; |
| struct list_head flist[DRM_SUBALLOC_MAX_QUEUES]; |
| size_t size; |
| size_t align; |
| }; |
| |
| /** |
| * struct drm_suballoc - Sub-allocated range |
| * @olist: List link for list of allocated ranges. |
| * @flist: List linkk for the manager fenced allocated ranges queues. |
| * @manager: The drm_suballoc_manager. |
| * @soffset: Start offset. |
| * @eoffset: End offset + 1 so that @eoffset - @soffset = size. |
| * @fence: The fence protecting the allocation. |
| */ |
| struct drm_suballoc { |
| struct list_head olist; |
| struct list_head flist; |
| struct drm_suballoc_manager *manager; |
| size_t soffset; |
| size_t eoffset; |
| struct dma_fence *fence; |
| }; |
| |
| void drm_suballoc_manager_init(struct drm_suballoc_manager *sa_manager, |
| size_t size, size_t align); |
| |
| void drm_suballoc_manager_fini(struct drm_suballoc_manager *sa_manager); |
| |
| struct drm_suballoc * |
| drm_suballoc_new(struct drm_suballoc_manager *sa_manager, size_t size, |
| gfp_t gfp, bool intr, size_t align); |
| |
| void drm_suballoc_free(struct drm_suballoc *sa, struct dma_fence *fence); |
| |
| /** |
| * drm_suballoc_soffset - Range start. |
| * @sa: The struct drm_suballoc. |
| * |
| * Return: The start of the allocated range. |
| */ |
| static inline size_t drm_suballoc_soffset(struct drm_suballoc *sa) |
| { |
| return sa->soffset; |
| } |
| |
| /** |
| * drm_suballoc_eoffset - Range end. |
| * @sa: The struct drm_suballoc. |
| * |
| * Return: The end of the allocated range + 1. |
| */ |
| static inline size_t drm_suballoc_eoffset(struct drm_suballoc *sa) |
| { |
| return sa->eoffset; |
| } |
| |
| /** |
| * drm_suballoc_size - Range size. |
| * @sa: The struct drm_suballoc. |
| * |
| * Return: The size of the allocated range. |
| */ |
| static inline size_t drm_suballoc_size(struct drm_suballoc *sa) |
| { |
| return sa->eoffset - sa->soffset; |
| } |
| |
| #ifdef CONFIG_DEBUG_FS |
| void drm_suballoc_dump_debug_info(struct drm_suballoc_manager *sa_manager, |
| struct drm_printer *p, |
| unsigned long long suballoc_base); |
| #else |
| static inline void |
| drm_suballoc_dump_debug_info(struct drm_suballoc_manager *sa_manager, |
| struct drm_printer *p, |
| unsigned long long suballoc_base) |
| { } |
| |
| #endif |
| |
| #endif /* _DRM_SUBALLOC_H_ */ |