drm/plane: Allocate planes with drm_universal_plane_alloc()
Provide drm_univeral_plane_alloc() to allocate and initialize a plane. Code for non-atomic drivers uses this pattern. Convert them to the new function. The modeset helpers contain a quirk for handling their color formats differently. Set the flag outside plane allocation. The new function is already deprecated to some extend. Drivers should rather use drmm_univeral_plane_alloc() or drm_universal_plane_init(). v2: * kerneldoc fixes (Javier) * grammar fixes in commit message Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Reviewed-by: Javier Martinez Canillas <javierm@redhat.com> Reviewed-by: Lyude Paul <lyude@redhat.com> # nouveau Link: https://patchwork.freedesktop.org/patch/msgid/20220909105947.6487-3-tzimmermann@suse.de
This commit is contained in:
parent
7221941c4f
commit
e71def0572
@ -113,38 +113,6 @@ static const struct drm_plane_funcs primary_plane_funcs = {
|
|||||||
.destroy = drm_plane_helper_destroy,
|
.destroy = drm_plane_helper_destroy,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct drm_plane *create_primary_plane(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_plane *primary;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
primary = kzalloc(sizeof(*primary), GFP_KERNEL);
|
|
||||||
if (primary == NULL) {
|
|
||||||
DRM_DEBUG_KMS("Failed to allocate primary plane\n");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Remove the format_default field from drm_plane when dropping
|
|
||||||
* this helper.
|
|
||||||
*/
|
|
||||||
primary->format_default = true;
|
|
||||||
|
|
||||||
/* possible_crtc's will be filled in later by crtc_init */
|
|
||||||
ret = drm_universal_plane_init(dev, primary, 0,
|
|
||||||
&primary_plane_funcs,
|
|
||||||
safe_modeset_formats,
|
|
||||||
ARRAY_SIZE(safe_modeset_formats),
|
|
||||||
NULL,
|
|
||||||
DRM_PLANE_TYPE_PRIMARY, NULL);
|
|
||||||
if (ret) {
|
|
||||||
kfree(primary);
|
|
||||||
primary = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return primary;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_crtc_init - Legacy CRTC initialization function
|
* drm_crtc_init - Legacy CRTC initialization function
|
||||||
* @dev: DRM device
|
* @dev: DRM device
|
||||||
@ -176,10 +144,33 @@ int drm_crtc_init(struct drm_device *dev, struct drm_crtc *crtc,
|
|||||||
const struct drm_crtc_funcs *funcs)
|
const struct drm_crtc_funcs *funcs)
|
||||||
{
|
{
|
||||||
struct drm_plane *primary;
|
struct drm_plane *primary;
|
||||||
|
int ret;
|
||||||
|
|
||||||
primary = create_primary_plane(dev);
|
/* possible_crtc's will be filled in later by crtc_init */
|
||||||
return drm_crtc_init_with_planes(dev, crtc, primary, NULL, funcs,
|
primary = __drm_universal_plane_alloc(dev, sizeof(*primary), 0, 0,
|
||||||
NULL);
|
&primary_plane_funcs,
|
||||||
|
safe_modeset_formats,
|
||||||
|
ARRAY_SIZE(safe_modeset_formats),
|
||||||
|
NULL, DRM_PLANE_TYPE_PRIMARY, NULL);
|
||||||
|
if (IS_ERR(primary))
|
||||||
|
return PTR_ERR(primary);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove the format_default field from drm_plane when dropping
|
||||||
|
* this helper.
|
||||||
|
*/
|
||||||
|
primary->format_default = true;
|
||||||
|
|
||||||
|
ret = drm_crtc_init_with_planes(dev, crtc, primary, NULL, funcs, NULL);
|
||||||
|
if (ret)
|
||||||
|
goto err_drm_plane_cleanup;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
err_drm_plane_cleanup:
|
||||||
|
drm_plane_cleanup(primary);
|
||||||
|
kfree(primary);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_crtc_init);
|
EXPORT_SYMBOL(drm_crtc_init);
|
||||||
|
|
||||||
|
@ -448,6 +448,44 @@ void *__drmm_universal_plane_alloc(struct drm_device *dev, size_t size,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__drmm_universal_plane_alloc);
|
EXPORT_SYMBOL(__drmm_universal_plane_alloc);
|
||||||
|
|
||||||
|
void *__drm_universal_plane_alloc(struct drm_device *dev, size_t size,
|
||||||
|
size_t offset, uint32_t possible_crtcs,
|
||||||
|
const struct drm_plane_funcs *funcs,
|
||||||
|
const uint32_t *formats, unsigned int format_count,
|
||||||
|
const uint64_t *format_modifiers,
|
||||||
|
enum drm_plane_type type,
|
||||||
|
const char *name, ...)
|
||||||
|
{
|
||||||
|
void *container;
|
||||||
|
struct drm_plane *plane;
|
||||||
|
va_list ap;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (drm_WARN_ON(dev, !funcs))
|
||||||
|
return ERR_PTR(-EINVAL);
|
||||||
|
|
||||||
|
container = kzalloc(size, GFP_KERNEL);
|
||||||
|
if (!container)
|
||||||
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
|
plane = container + offset;
|
||||||
|
|
||||||
|
va_start(ap, name);
|
||||||
|
ret = __drm_universal_plane_init(dev, plane, possible_crtcs, funcs,
|
||||||
|
formats, format_count, format_modifiers,
|
||||||
|
type, name, ap);
|
||||||
|
va_end(ap);
|
||||||
|
if (ret)
|
||||||
|
goto err_kfree;
|
||||||
|
|
||||||
|
return container;
|
||||||
|
|
||||||
|
err_kfree:
|
||||||
|
kfree(container);
|
||||||
|
return ERR_PTR(ret);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(__drm_universal_plane_alloc);
|
||||||
|
|
||||||
int drm_plane_register_all(struct drm_device *dev)
|
int drm_plane_register_all(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
unsigned int num_planes = 0;
|
unsigned int num_planes = 0;
|
||||||
|
@ -1281,32 +1281,6 @@ static const struct drm_plane_funcs nv04_primary_plane_funcs = {
|
|||||||
.destroy = drm_plane_helper_destroy,
|
.destroy = drm_plane_helper_destroy,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct drm_plane *
|
|
||||||
create_primary_plane(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_plane *primary;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
primary = kzalloc(sizeof(*primary), GFP_KERNEL);
|
|
||||||
if (primary == NULL) {
|
|
||||||
DRM_DEBUG_KMS("Failed to allocate primary plane\n");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* possible_crtc's will be filled in later by crtc_init */
|
|
||||||
ret = drm_universal_plane_init(dev, primary, 0,
|
|
||||||
&nv04_primary_plane_funcs,
|
|
||||||
modeset_formats,
|
|
||||||
ARRAY_SIZE(modeset_formats), NULL,
|
|
||||||
DRM_PLANE_TYPE_PRIMARY, NULL);
|
|
||||||
if (ret) {
|
|
||||||
kfree(primary);
|
|
||||||
primary = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return primary;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int nv04_crtc_vblank_handler(struct nvif_notify *notify)
|
static int nv04_crtc_vblank_handler(struct nvif_notify *notify)
|
||||||
{
|
{
|
||||||
struct nouveau_crtc *nv_crtc =
|
struct nouveau_crtc *nv_crtc =
|
||||||
@ -1321,6 +1295,7 @@ nv04_crtc_create(struct drm_device *dev, int crtc_num)
|
|||||||
{
|
{
|
||||||
struct nouveau_display *disp = nouveau_display(dev);
|
struct nouveau_display *disp = nouveau_display(dev);
|
||||||
struct nouveau_crtc *nv_crtc;
|
struct nouveau_crtc *nv_crtc;
|
||||||
|
struct drm_plane *primary;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
nv_crtc = kzalloc(sizeof(*nv_crtc), GFP_KERNEL);
|
nv_crtc = kzalloc(sizeof(*nv_crtc), GFP_KERNEL);
|
||||||
@ -1335,8 +1310,18 @@ nv04_crtc_create(struct drm_device *dev, int crtc_num)
|
|||||||
nv_crtc->save = nv_crtc_save;
|
nv_crtc->save = nv_crtc_save;
|
||||||
nv_crtc->restore = nv_crtc_restore;
|
nv_crtc->restore = nv_crtc_restore;
|
||||||
|
|
||||||
drm_crtc_init_with_planes(dev, &nv_crtc->base,
|
primary = __drm_universal_plane_alloc(dev, sizeof(*primary), 0, 0,
|
||||||
create_primary_plane(dev), NULL,
|
&nv04_primary_plane_funcs,
|
||||||
|
modeset_formats,
|
||||||
|
ARRAY_SIZE(modeset_formats), NULL,
|
||||||
|
DRM_PLANE_TYPE_PRIMARY, NULL);
|
||||||
|
if (IS_ERR(primary)) {
|
||||||
|
ret = PTR_ERR(primary);
|
||||||
|
kfree(nv_crtc);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
drm_crtc_init_with_planes(dev, &nv_crtc->base, primary, NULL,
|
||||||
&nv04_crtc_funcs, NULL);
|
&nv04_crtc_funcs, NULL);
|
||||||
drm_crtc_helper_add(&nv_crtc->base, &nv04_crtc_helper_funcs);
|
drm_crtc_helper_add(&nv_crtc->base, &nv04_crtc_helper_funcs);
|
||||||
drm_mode_crtc_set_gamma_size(&nv_crtc->base, 256);
|
drm_mode_crtc_set_gamma_size(&nv_crtc->base, 256);
|
||||||
|
@ -809,6 +809,50 @@ void *__drmm_universal_plane_alloc(struct drm_device *dev,
|
|||||||
format_count, format_modifiers, \
|
format_count, format_modifiers, \
|
||||||
plane_type, name, ##__VA_ARGS__))
|
plane_type, name, ##__VA_ARGS__))
|
||||||
|
|
||||||
|
__printf(10, 11)
|
||||||
|
void *__drm_universal_plane_alloc(struct drm_device *dev,
|
||||||
|
size_t size, size_t offset,
|
||||||
|
uint32_t possible_crtcs,
|
||||||
|
const struct drm_plane_funcs *funcs,
|
||||||
|
const uint32_t *formats,
|
||||||
|
unsigned int format_count,
|
||||||
|
const uint64_t *format_modifiers,
|
||||||
|
enum drm_plane_type plane_type,
|
||||||
|
const char *name, ...);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* drm_universal_plane_alloc() - Allocate and initialize an universal plane object
|
||||||
|
* @dev: DRM device
|
||||||
|
* @type: the type of the struct which contains struct &drm_plane
|
||||||
|
* @member: the name of the &drm_plane within @type
|
||||||
|
* @possible_crtcs: bitmask of possible CRTCs
|
||||||
|
* @funcs: callbacks for the new plane
|
||||||
|
* @formats: array of supported formats (DRM_FORMAT\_\*)
|
||||||
|
* @format_count: number of elements in @formats
|
||||||
|
* @format_modifiers: array of struct drm_format modifiers terminated by
|
||||||
|
* DRM_FORMAT_MOD_INVALID
|
||||||
|
* @plane_type: type of plane (overlay, primary, cursor)
|
||||||
|
* @name: printf style format string for the plane name, or NULL for default name
|
||||||
|
*
|
||||||
|
* Allocates and initializes a plane object of type @type. The caller
|
||||||
|
* is responsible for releasing the allocated memory with kfree().
|
||||||
|
*
|
||||||
|
* Drivers are encouraged to use drmm_universal_plane_alloc() instead.
|
||||||
|
*
|
||||||
|
* Drivers that only support the DRM_FORMAT_MOD_LINEAR modifier support may set
|
||||||
|
* @format_modifiers to NULL. The plane will advertise the linear modifier.
|
||||||
|
*
|
||||||
|
* Returns:
|
||||||
|
* Pointer to new plane, or ERR_PTR on failure.
|
||||||
|
*/
|
||||||
|
#define drm_universal_plane_alloc(dev, type, member, possible_crtcs, funcs, formats, \
|
||||||
|
format_count, format_modifiers, plane_type, name, ...) \
|
||||||
|
((type *)__drm_universal_plane_alloc(dev, sizeof(type), \
|
||||||
|
offsetof(type, member), \
|
||||||
|
possible_crtcs, funcs, formats, \
|
||||||
|
format_count, format_modifiers, \
|
||||||
|
plane_type, name, ##__VA_ARGS__))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_plane_index - find the index of a registered plane
|
* drm_plane_index - find the index of a registered plane
|
||||||
* @plane: plane to find index for
|
* @plane: plane to find index for
|
||||||
|
Loading…
Reference in New Issue
Block a user