]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
drm: Switch drm_plane_state to inline kerneldoc style
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Mon, 9 Jul 2018 08:40:09 +0000 (10:40 +0200)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Fri, 13 Jul 2018 16:40:28 +0000 (18:40 +0200)
For consistency and to encourage more detailed documentation. While
doing this also beefed up a few of the comments, linking at least to
the setup function. Plus fixed all the hyperlinks.

Reviewed-by: Sean Paul <seanpaul@chromium.org>
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180709084016.23750-9-daniel.vetter@ffwll.ch
include/drm/drm_plane.h

index cee9dfaaa740e4ce83de8f680d88442255ce969f..1a647f8f5661b93f3689491f002407aaa845150a 100644 (file)
@@ -34,31 +34,15 @@ struct drm_modeset_acquire_ctx;
 
 /**
  * struct drm_plane_state - mutable plane state
- * @plane: backpointer to the plane
- * @crtc_w: width of visible portion of plane on crtc
- * @crtc_h: height of visible portion of plane on crtc
- * @src_x: left position of visible portion of plane within
- *     plane (in 16.16)
- * @src_y: upper position of visible portion of plane within
- *     plane (in 16.16)
- * @src_w: width of visible portion of plane (in 16.16)
- * @src_h: height of visible portion of plane (in 16.16)
- * @alpha: opacity of the plane
- * @rotation: rotation of the plane
- * @zpos: priority of the given plane on crtc (optional)
- *     Note that multiple active planes on the same crtc can have an identical
- *     zpos value. The rule to solving the conflict is to compare the plane
- *     object IDs; the plane with a higher ID must be stacked on top of a
- *     plane with a lower ID.
- * @normalized_zpos: normalized value of zpos: unique, range from 0 to N-1
- *     where N is the number of active planes for given crtc. Note that
- *     the driver must set drm_mode_config.normalize_zpos or call
- *     drm_atomic_normalize_zpos() to update this before it can be trusted.
- * @src: clipped source coordinates of the plane (in 16.16)
- * @dst: clipped destination coordinates of the plane
- * @state: backpointer to global drm_atomic_state
+ *
+ * Please not that the destination coordinates @crtc_x, @crtc_y, @crtc_h and
+ * @crtc_w and the source coordinates @src_x, @src_y, @src_h and @src_w are the
+ * raw coordinates provided by userspace. Drivers should use
+ * drm_atomic_helper_check_plane_state() and only use the derived rectangles in
+ * @src and @dst to program the hardware.
  */
 struct drm_plane_state {
+       /** @plane: backpointer to the plane */
        struct drm_plane *plane;
 
        /**
@@ -87,7 +71,7 @@ struct drm_plane_state {
         * preserved.
         *
         * Drivers should store any implicit fence in this from their
-        * &drm_plane_helper.prepare_fb callback. See drm_gem_fb_prepare_fb()
+        * &drm_plane_helper_funcs.prepare_fb callback. See drm_gem_fb_prepare_fb()
         * and drm_gem_fb_simple_display_pipe_prepare_fb() for suitable helpers.
         */
        struct dma_fence *fence;
@@ -108,20 +92,60 @@ struct drm_plane_state {
         */
        int32_t crtc_y;
 
+       /** @crtc_w: width of visible portion of plane on crtc */
+       /** @crtc_h: height of visible portion of plane on crtc */
        uint32_t crtc_w, crtc_h;
 
-       /* Source values are 16.16 fixed point */
-       uint32_t src_x, src_y;
+       /**
+        * @src_x: left position of visible portion of plane within plane (in
+        * 16.16 fixed point).
+        */
+       uint32_t src_x;
+       /**
+        * @src_y: upper position of visible portion of plane within plane (in
+        * 16.16 fixed point).
+        */
+       uint32_t src_y;
+       /** @src_w: width of visible portion of plane (in 16.16) */
+       /** @src_h: height of visible portion of plane (in 16.16) */
        uint32_t src_h, src_w;
 
-       /* Plane opacity */
+       /**
+        * @alpha:
+        * Opacity of the plane with 0 as completely transparent and 0xffff as
+        * completely opaque. See drm_plane_create_alpha_property() for more
+        * details.
+        */
        u16 alpha;
 
-       /* Plane rotation */
+       /**
+        * @rotation:
+        * Rotation of the plane. See drm_plane_create_rotation_property() for
+        * more details.
+        */
        unsigned int rotation;
 
-       /* Plane zpos */
+       /**
+        * @zpos:
+        * Priority of the given plane on crtc (optional).
+        *
+        * Note that multiple active planes on the same crtc can have an
+        * identical zpos value. The rule to solving the conflict is to compare
+        * the plane object IDs; the plane with a higher ID must be stacked on
+        * top of a plane with a lower ID.
+        *
+        * See drm_plane_create_zpos_property() and
+        * drm_plane_create_zpos_immutable_property() for more details.
+        */
        unsigned int zpos;
+
+       /**
+        * @normalized_zpos:
+        * Normalized value of zpos: unique, range from 0 to N-1 where N is the
+        * number of active planes for given crtc. Note that the driver must set
+        * &drm_mode_config.normalize_zpos or call drm_atomic_normalize_zpos() to
+        * update this before it can be trusted.
+        */
        unsigned int normalized_zpos;
 
        /**
@@ -138,7 +162,8 @@ struct drm_plane_state {
         */
        enum drm_color_range color_range;
 
-       /* Clipped coordinates */
+       /** @src: clipped source coordinates of the plane (in 16.16) */
+       /** @dst: clipped destination coordinates of the plane */
        struct drm_rect src, dst;
 
        /**
@@ -157,6 +182,7 @@ struct drm_plane_state {
         */
        struct drm_crtc_commit *commit;
 
+       /** @state: backpointer to global drm_atomic_state */
        struct drm_atomic_state *state;
 };