cb1c81467a
Instead of both driver and TTM allocating memory finalize embedding the ttm_resource object as base into the driver backends. v2: fix typo in vmwgfx grid mgr and double init in amdgpu_vram_mgr.c Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Matthew Auld <matthew.auld@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20210602100914.46246-10-christian.koenig@amd.com
43 lines
967 B
C
43 lines
967 B
C
/* SPDX-License-Identifier: GPL-2.0 OR MIT */
|
|
|
|
#ifndef _TTM_RANGE_MANAGER_H_
|
|
#define _TTM_RANGE_MANAGER_H_
|
|
|
|
#include <drm/ttm/ttm_resource.h>
|
|
#include <drm/drm_mm.h>
|
|
|
|
/**
|
|
* struct ttm_range_mgr_node
|
|
*
|
|
* @base: base clase we extend
|
|
* @mm_nodes: MM nodes, usually 1
|
|
*
|
|
* Extending the ttm_resource object to manage an address space allocation with
|
|
* one or more drm_mm_nodes.
|
|
*/
|
|
struct ttm_range_mgr_node {
|
|
struct ttm_resource base;
|
|
struct drm_mm_node mm_nodes[];
|
|
};
|
|
|
|
/**
|
|
* to_ttm_range_mgr_node
|
|
*
|
|
* @res: the resource to upcast
|
|
*
|
|
* Upcast the ttm_resource object into a ttm_range_mgr_node object.
|
|
*/
|
|
static inline struct ttm_range_mgr_node *
|
|
to_ttm_range_mgr_node(struct ttm_resource *res)
|
|
{
|
|
return container_of(res, struct ttm_range_mgr_node, base);
|
|
}
|
|
|
|
int ttm_range_man_init(struct ttm_device *bdev,
|
|
unsigned type, bool use_tt,
|
|
unsigned long p_size);
|
|
int ttm_range_man_fini(struct ttm_device *bdev,
|
|
unsigned type);
|
|
|
|
#endif
|