-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs(linux): Add documentation regaring DSS feature: cropping
This documentation includes examples showing the cropped part of a frame. Signed-off-by: Swamil Jain <[email protected]>
- Loading branch information
Showing
4 changed files
with
54 additions
and
2 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -490,8 +490,8 @@ tidss supports configuration via DRM properties. These are standard DRM properti | |
| GAMMA_LUT_SIZE | crtc | Number of elements in gammma lookup table. | | ||
+--------------------+----------+------------------------------------------------------------------------------------------------------+ | ||
|
||
Testing tidss properties with modetest | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
Testing tidss properties with modetest and kmstest | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
|
||
As the name suggests, ``modetest`` is DRM based mode setting test program available along with libdrm. | ||
It is an easy-to-use tool to test different features provided by display HWs. The DRM driver for, | ||
|
@@ -663,6 +663,58 @@ The following example was run on DSS7-UL and hence the pipe with scaling capabil | |
Note that the ``*2`` at the end of ``-P 41@38:400x400*2`` is the scaling factor. | ||
|
||
- **Cropping** | ||
|
||
``kmstest`` utility can be used to demonstrate cropping in a video frame using a test pattern. | ||
User can specify the video frame size ``w x h`` with an input color format ``cf`` using option ``-f``, then to specify the source rectangle i.e. to create cropped portion of video frame, it can be done using ``-v`` argument which specify ``w1 x h1`` source rectangle starting at coordinates ``x1,y1`` w.r.t the video frame. The destination rectangle i.e. on the screen where this needs to be displayed can be specified using ``-p`` option with the desired dimensions i.e. ``w2 x h2`` to be displayed starting at coordinates ``x2,y2``. | ||
|
||
.. code-block:: console | ||
$ kmstest -p <plane_number>:<x-coordinate>,<ycoordinate>-<plane_width>x<plane_height> -f <frame_width>x<frame_height>-<color-format> -v <view_number>:<x-coordinate>,<ycoordinate>-<view_width>x<view_height> | ||
$ kmstest -p 0:x2,y2-w2xh2 -f wxh-cf -v x1,y1-w1xh1 | ||
.. code-block:: console | ||
$ kmstest -c hdmi -p 0:0,0-1000x1000 -f 1000x1000-XR24 -v 0,0-1000x1000 | ||
Connector 1/@50: HDMI-A-1 | ||
Crtc 1/@48: [email protected] 138.500 1920/48/32/80/+ 1080/3/5/23/- 60 (59.93) 0x9 0x48 | ||
Plane 0/@31: 0,0-1000x1000 | ||
Fb 55 1000x1000-XR24 | ||
The above example displays a ``1000x1000`` video frame on the screen starting at coordinates ``0,0``. | ||
|
||
.. figure:: /images/DSS_cropping_example_1.jpg | ||
:height: 600 | ||
:width: 1020 | ||
|
||
.. code-block:: console | ||
$ kmstest -c hdmi -p 0:0,0-800x800 -f 1000x1000 -v 0,0-800x800 | ||
Connector 1/@50: HDMI-A-1 | ||
Crtc 1/@48: [email protected] 138.500 1920/48/32/80/+ 1080/3/5/23/- 60 (59.93) 0x9 0x48 | ||
Plane 0/@31: 0,0-800x800 | ||
Fb 55 1000x1000-XR24 | ||
The example displays a cropped part i.e. ``800x800`` of the ``1000x1000`` video frame starting at coordinates ``0,0``. | ||
|
||
.. figure:: /images/DSS_cropping_example_2.jpg | ||
:height: 600 | ||
:width: 1020 | ||
|
||
.. code-block:: console | ||
$ kmstest -c hdmi -p 0:500,200-800x800 -f 1000x1000 -v 200,100-800x800 | ||
Connector 1/@50: HDMI-A-1 | ||
Crtc 1/@48: [email protected] 138.500 1920/48/32/80/+ 1080/3/5/23/- 60 (59.93) 0x9 0x48 | ||
Plane 0/@31: 500,200-800x800 | ||
Fb 54 1000x1000-XR24 | ||
This example displays the cropped part of the video frame with the dimensions ``800x800``, starting at coordinates ``200,100`` of the video frame, on the screen starting at coordinates ``500,200``. | ||
|
||
.. figure:: /images/DSS_cropping_example_3.jpg | ||
:height: 600 | ||
:width: 1020 | ||
|
||
Buffers | ||
------- | ||
|