From: sonika.jindal@intel.com
To: intel-gfx@lists.freedesktop.org
Subject: [PATCH 02/11] drm: Add support_bits parameter to drm_property_create_bitmask()
Date: Wed, 18 Jun 2014 14:27:18 +0530 [thread overview]
Message-ID: <1403081847-4364-3-git-send-email-sonika.jindal@intel.com> (raw)
In-Reply-To: <1403081847-4364-1-git-send-email-sonika.jindal@intel.com>
From: Ville Syrjälä <ville.syrjala at linux.intel.com>
Make drm_property_create_bitmask() a bit more generic by allowing the
caller to specify which bits are in fact supported. This allows multiple
callers to use the same enum list, but still create different versions
of the same property with different list of supported bits.
v2: Populate values[] array as non-sparse
Make supported_bits 64bit
Fix up omapdrm call site (Rob)
Cc: Tomi Valkeinen <tomi.valkeinen at ti.com>
Cc: Rob Clark <robdclark at gmail.com>
Cc: Sagar Kamble <sagar.a.kamble at intel.com>
Cc: dri-devel at lists.freedesktop.org
Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
---
drivers/gpu/drm/drm_crtc.c | 17 +++++++++++++----
drivers/gpu/drm/omapdrm/omap_plane.c | 5 ++++-
include/drm/drm_crtc.h | 3 ++-
3 files changed, 19 insertions(+), 6 deletions(-)
diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c
index 41c7212..2fbee61 100644
--- a/drivers/gpu/drm/drm_crtc.c
+++ b/drivers/gpu/drm/drm_crtc.c
@@ -3395,19 +3395,28 @@ EXPORT_SYMBOL(drm_property_create_enum);
struct drm_property *drm_property_create_bitmask(struct drm_device *dev,
int flags, const char *name,
const struct drm_prop_enum_list *props,
- int num_values)
+ int num_props,
+ uint64_t supported_bits)
{
struct drm_property *property;
- int i, ret;
+ int i, ret, index = 0;
+ int num_values = hweight64(supported_bits);
flags |= DRM_MODE_PROP_BITMASK;
property = drm_property_create(dev, flags, name, num_values);
if (!property)
return NULL;
+ for (i = 0; i < num_props; i++) {
+ if (!(supported_bits & (1ULL << props[i].type)))
+ continue;
- for (i = 0; i < num_values; i++) {
- ret = drm_property_add_enum(property, i,
+ if (WARN_ON(index >= num_values)) {
+ drm_property_destroy(dev, property);
+ return NULL;
+ }
+
+ ret = drm_property_add_enum(property, index++,
props[i].type,
props[i].name);
if (ret) {
diff --git a/drivers/gpu/drm/omapdrm/omap_plane.c b/drivers/gpu/drm/omapdrm/omap_plane.c
index 3cf31ee..aff06e7 100644
--- a/drivers/gpu/drm/omapdrm/omap_plane.c
+++ b/drivers/gpu/drm/omapdrm/omap_plane.c
@@ -317,7 +317,10 @@ void omap_plane_install_properties(struct drm_plane *plane,
{ DRM_REFLECT_Y, "reflect-y" },
};
prop = drm_property_create_bitmask(dev, 0, "rotation",
- props, ARRAY_SIZE(props));
+ props, ARRAY_SIZE(props),
+ BIT(DRM_ROTATE_0) | BIT(DRM_ROTATE_90) |
+ BIT(DRM_ROTATE_180) | BIT(DRM_ROTATE_270) |
+ BIT(DRM_REFLECT_X) | BIT(DRM_REFLECT_Y));
if (prop == NULL)
return;
priv->rotation_prop = prop;
diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h
index bfc7235..cb4850a 100644
--- a/include/drm/drm_crtc.h
+++ b/include/drm/drm_crtc.h
@@ -1006,7 +1006,8 @@ extern struct drm_property *drm_property_create_enum(struct drm_device *dev, int
struct drm_property *drm_property_create_bitmask(struct drm_device *dev,
int flags, const char *name,
const struct drm_prop_enum_list *props,
- int num_values);
+ int num_props,
+ uint64_t supported_bits);
struct drm_property *drm_property_create_range(struct drm_device *dev, int flags,
const char *name,
uint64_t min, uint64_t max);
--
1.7.10.4
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2014-06-18 9:01 UTC|newest]
Thread overview: 68+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-06-18 8:57 [PATCH 00/11] Support for 180 degree HW rotation sonika.jindal
2014-06-18 8:57 ` [PATCH 01/11] drm: Move DRM_ROTATE bits out of omapdrm into drm_crtc.h sonika.jindal
2014-06-18 8:57 ` sonika.jindal [this message]
2014-06-18 8:57 ` [PATCH 03/11] drm: Add drm_mode_create_rotation_property() sonika.jindal
2014-06-18 8:57 ` [PATCH 04/11] drm/omap: Switch omapdrm over to drm_mode_create_rotation_property() sonika.jindal
2014-06-18 8:57 ` [PATCH 05/11] drm: Add drm_rect rotation functions sonika.jindal
2014-06-18 8:57 ` [PATCH 06/11] drm: Add drm_rotation_simplify() sonika.jindal
2014-06-18 8:57 ` [PATCH 07/11] drm/i915: Add 180 degree sprite rotation support sonika.jindal
2014-06-18 8:57 ` [PATCH 08/11] drm/i915: Make intel_plane_restore() return an error sonika.jindal
2014-06-18 8:57 ` [PATCH 09/11] drm/i915: Add rotation property for sprites sonika.jindal
2014-06-18 11:12 ` Damien Lespiau
2014-06-18 11:54 ` Jindal, Sonika
2014-06-18 13:09 ` Damien Lespiau
2014-06-18 12:01 ` Ville Syrjälä
2014-06-18 8:57 ` [PATCH 10/11] drm/i915: Add 180 degree primary plane rotation support sonika.jindal
2014-06-18 17:02 ` Damien Lespiau
2014-06-19 6:43 ` Jindal, Sonika
2014-06-19 7:07 ` Daniel Vetter
2014-06-19 7:52 ` Jindal, Sonika
2014-06-19 7:55 ` Daniel Vetter
2014-06-19 8:09 ` Jindal, Sonika
2014-06-19 8:21 ` Daniel Vetter
2014-06-19 12:39 ` [PATCH] drm: Resetting rotation property sonika.jindal
2014-06-23 5:35 ` [PATCH 0/3] Moving rotation_property to drm_plane sonika.jindal
2014-06-23 5:35 ` [PATCH 1/3] drm/i915: Add rotation property for sprites sonika.jindal
2014-06-23 5:36 ` [PATCH 2/3] drm/i915: Add 180 degree primary plane rotation support sonika.jindal
2014-06-24 10:14 ` Damien Lespiau
2014-06-24 10:26 ` Jindal, Sonika
2014-06-24 10:29 ` Damien Lespiau
2014-06-24 10:34 ` Jindal, Sonika
2014-06-23 5:36 ` [PATCH 3/3] drm: Resetting rotation property sonika.jindal
2014-06-24 10:27 ` Damien Lespiau
2014-06-24 12:08 ` [PATCH 0/3] Moving rotation_property to drm_plane sonika.jindal
2014-06-24 12:08 ` [PATCH 1/3] drm/i915: Add rotation property for sprites sonika.jindal
2014-06-24 12:08 ` [PATCH 2/3] drm/i915: Add 180 degree primary plane rotation support sonika.jindal
2014-06-30 6:12 ` [PATCH] " sonika.jindal
2014-06-24 12:08 ` [PATCH 3/3] drm: Resetting rotation property sonika.jindal
2014-07-02 8:51 ` [PATCH 0/3] Moving rotation_property to drm_plane Jindal, Sonika
2014-07-02 13:17 ` Damien Lespiau
2014-07-07 14:34 ` Daniel Vetter
2014-06-19 10:07 ` [PATCH 10/11] drm/i915: Add 180 degree primary plane rotation support Damien Lespiau
2014-06-19 10:38 ` Daniel Vetter
2014-06-27 10:34 ` Tvrtko Ursulin
2014-06-27 10:49 ` Jindal, Sonika
2014-06-27 11:12 ` Tvrtko Ursulin
2014-06-27 11:14 ` Jindal, Sonika
2014-06-27 10:38 ` Tvrtko Ursulin
2014-06-27 11:15 ` Jindal, Sonika
2014-06-18 8:57 ` [PATCH 11/11] tests/kms_rotation_crc: IGT for 180 degree HW rotation sonika.jindal
2014-06-18 11:32 ` Damien Lespiau
2014-06-18 11:39 ` Chris Wilson
2014-06-25 5:54 ` Jindal, Sonika
2014-06-25 5:57 ` Chris Wilson
2014-06-25 6:00 ` Jindal, Sonika
2014-06-18 12:00 ` Jindal, Sonika
2014-06-18 11:00 ` [PATCH 00/11] Support " Damien Lespiau
2014-06-18 11:07 ` Chris Wilson
2014-06-18 11:12 ` Damien Lespiau
2014-06-18 11:21 ` Chris Wilson
2014-06-18 11:37 ` Damien Lespiau
2014-06-18 11:57 ` Ville Syrjälä
2014-06-18 11:51 ` Jindal, Sonika
2014-06-19 6:11 ` [PATCH 1/1] Documentation: drm: describing rotation property for i915 sonika.jindal
2014-06-24 10:05 ` Damien Lespiau
2014-06-25 5:38 ` [PATCH 1/2] Documentation: drm: Removing placeholders for generic drm properties description sonika.jindal
2014-06-25 5:38 ` [PATCH 2/2] Documentation: drm: describing rotation property for i915 sonika.jindal
2014-07-02 11:01 ` Damien Lespiau
2014-07-02 11:00 ` [PATCH 1/2] Documentation: drm: Removing placeholders for generic drm properties description Damien Lespiau
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1403081847-4364-3-git-send-email-sonika.jindal@intel.com \
--to=sonika.jindal@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox