Ok no problem. I think Keith just queued up the i915 bits, but I don't think they've made their way to Dave yet. Jesse On Wed, 4 Jan 2012 22:55:31 -0600 Rob Clark <rob@xxxxxx> wrote: > note: looks like I need to rebase this patch after exynos drm driver > was pulled to drm-next.. if there are some other consumers that are > waiting to be pulled, let me know and I'll just rebase on top of that. > (Either way, it would be a trivial merge conflict.. just add FALSE as > additional arg to drm_plane_init()) > > BR, > -R > > On Tue, Dec 13, 2011 at 8:19 PM, Rob Clark <rob.clark@xxxxxxxxxx> wrote: > > From: Rob Clark <rob@xxxxxx> > > > > In cases where the scanout hw is sufficiently similar between "overlay" > > and traditional crtc layers, it might be convenient to allow the driver > > to create internal drm_plane helper objects used by the drm_crtc > > implementation, rather than duplicate code between the plane and crtc. > > A private plane is not exposed to userspace. > > > > Signed-off-by: Rob Clark <rob@xxxxxx> > > --- > > drivers/gpu/drm/drm_crtc.c | 22 +++++++++++++++++----- > > include/drm/drm_crtc.h | 3 ++- > > 2 files changed, 19 insertions(+), 6 deletions(-) > > > > diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c > > index 6dad421..d73746e 100644 > > --- a/drivers/gpu/drm/drm_crtc.c > > +++ b/drivers/gpu/drm/drm_crtc.c > > @@ -557,7 +557,8 @@ EXPORT_SYMBOL(drm_encoder_cleanup); > > int drm_plane_init(struct drm_device *dev, struct drm_plane *plane, > > unsigned long possible_crtcs, > > const struct drm_plane_funcs *funcs, > > - uint32_t *formats, uint32_t format_count) > > + const uint32_t *formats, uint32_t format_count, > > + bool priv) > > { > > mutex_lock(&dev->mode_config.mutex); > > > > @@ -576,8 +577,16 @@ int drm_plane_init(struct drm_device *dev, struct drm_plane *plane, > > plane->format_count = format_count; > > plane->possible_crtcs = possible_crtcs; > > > > - list_add_tail(&plane->head, &dev->mode_config.plane_list); > > - dev->mode_config.num_plane++; > > + /* private planes are not exposed to userspace, but depending on > > + * display hardware, might be convenient to allow sharing programming > > + * for the scanout engine with the crtc implementation. > > + */ > > + if (!priv) { > > + list_add_tail(&plane->head, &dev->mode_config.plane_list); > > + dev->mode_config.num_plane++; > > + } else { > > + INIT_LIST_HEAD(&plane->head); > > + } > > > > mutex_unlock(&dev->mode_config.mutex); > > > > @@ -592,8 +601,11 @@ void drm_plane_cleanup(struct drm_plane *plane) > > mutex_lock(&dev->mode_config.mutex); > > kfree(plane->format_types); > > drm_mode_object_put(dev, &plane->base); > > - list_del(&plane->head); > > - dev->mode_config.num_plane--; > > + /* if not added to a list, it must be a private plane */ > > + if (!list_empty(&plane->head)) { > > + list_del(&plane->head); > > + dev->mode_config.num_plane--; > > + } > > mutex_unlock(&dev->mode_config.mutex); > > } > > EXPORT_SYMBOL(drm_plane_cleanup); > > diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h > > index dd55727..1354ef5 100644 > > --- a/include/drm/drm_crtc.h > > +++ b/include/drm/drm_crtc.h > > @@ -828,7 +828,8 @@ extern int drm_plane_init(struct drm_device *dev, > > struct drm_plane *plane, > > unsigned long possible_crtcs, > > const struct drm_plane_funcs *funcs, > > - uint32_t *formats, uint32_t format_count); > > + const uint32_t *formats, uint32_t format_count, > > + bool private); > > extern void drm_plane_cleanup(struct drm_plane *plane); > > > > extern void drm_encoder_cleanup(struct drm_encoder *encoder); > > -- > > 1.7.5.4 > > >
Attachment:
signature.asc
Description: PGP signature
_______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel