| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- .. _vkms:
- ==========================================
- drm/vkms Virtual Kernel Modesetting
- ==========================================
- .. kernel-doc:: drivers/gpu/drm/vkms/vkms_drv.c
- :doc: vkms (Virtual Kernel Modesetting)
- Setup
- =====
- The VKMS driver can be setup with the following steps:
- To check if VKMS is loaded, run::
- lsmod | grep vkms
- This should list the VKMS driver. If no output is obtained, then
- you need to enable and/or load the VKMS driver.
- Ensure that the VKMS driver has been set as a loadable module in your
- kernel config file. Do::
- make nconfig
- Go to `Device Drivers> Graphics support`
- Enable `Virtual KMS (EXPERIMENTAL)`
- Compile and build the kernel for the changes to get reflected.
- Now, to load the driver, use::
- sudo modprobe vkms
- On running the lsmod command now, the VKMS driver will appear listed.
- You can also observe the driver being loaded in the dmesg logs.
- The VKMS driver has optional features to simulate different kinds of hardware,
- which are exposed as module options. You can use the `modinfo` command
- to see the module options for vkms::
- modinfo vkms
- Module options are helpful when testing, and enabling modules
- can be done while loading vkms. For example, to load vkms with cursor enabled,
- use::
- sudo modprobe vkms enable_cursor=1
- To disable the driver, use ::
- sudo modprobe -r vkms
- Configuring With Configfs
- =========================
- It is possible to create and configure multiple VKMS instances via configfs.
- Start by mounting configfs and loading VKMS::
- sudo mount -t configfs none /config
- sudo modprobe vkms
- Once VKMS is loaded, ``/config/vkms`` is created automatically. Each directory
- under ``/config/vkms`` represents a VKMS instance, create a new one::
- sudo mkdir /config/vkms/my-vkms
- By default, the instance is disabled::
- cat /config/vkms/my-vkms/enabled
- 0
- And directories are created for each configurable item of the display pipeline::
- tree /config/vkms/my-vkms
- ├── connectors
- ├── crtcs
- ├── enabled
- ├── encoders
- └── planes
- To add items to the display pipeline, create one or more directories under the
- available paths.
- Start by creating one or more planes::
- sudo mkdir /config/vkms/my-vkms/planes/plane0
- Planes have 1 configurable attribute:
- - type: Plane type: 0 overlay, 1 primary, 2 cursor (same values as those
- exposed by the "type" property of a plane)
- Continue by creating one or more CRTCs::
- sudo mkdir /config/vkms/my-vkms/crtcs/crtc0
- CRTCs have 1 configurable attribute:
- - writeback: Enable or disable writeback connector support by writing 1 or 0
- Next, create one or more encoders::
- sudo mkdir /config/vkms/my-vkms/encoders/encoder0
- Last but not least, create one or more connectors::
- sudo mkdir /config/vkms/my-vkms/connectors/connector0
- Connectors have 1 configurable attribute:
- - status: Connection status: 1 connected, 2 disconnected, 3 unknown (same values
- as those exposed by the "status" property of a connector)
- To finish the configuration, link the different pipeline items::
- sudo ln -s /config/vkms/my-vkms/crtcs/crtc0 /config/vkms/my-vkms/planes/plane0/possible_crtcs
- sudo ln -s /config/vkms/my-vkms/crtcs/crtc0 /config/vkms/my-vkms/encoders/encoder0/possible_crtcs
- sudo ln -s /config/vkms/my-vkms/encoders/encoder0 /config/vkms/my-vkms/connectors/connector0/possible_encoders
- Since at least one primary plane is required, make sure to set the right type::
- echo "1" | sudo tee /config/vkms/my-vkms/planes/plane0/type
- Once you are done configuring the VKMS instance, enable it::
- echo "1" | sudo tee /config/vkms/my-vkms/enabled
- Finally, you can remove the VKMS instance disabling it::
- echo "0" | sudo tee /config/vkms/my-vkms/enabled
- And removing the top level directory and its subdirectories::
- sudo rm /config/vkms/my-vkms/planes/*/possible_crtcs/*
- sudo rm /config/vkms/my-vkms/encoders/*/possible_crtcs/*
- sudo rm /config/vkms/my-vkms/connectors/*/possible_encoders/*
- sudo rmdir /config/vkms/my-vkms/planes/*
- sudo rmdir /config/vkms/my-vkms/crtcs/*
- sudo rmdir /config/vkms/my-vkms/encoders/*
- sudo rmdir /config/vkms/my-vkms/connectors/*
- sudo rmdir /config/vkms/my-vkms
- Testing With IGT
- ================
- The IGT GPU Tools is a test suite used specifically for debugging and
- development of the DRM drivers.
- The IGT Tools can be installed from
- `here <https://gitlab.freedesktop.org/drm/igt-gpu-tools>`_ .
- The tests need to be run without a compositor, so you need to switch to text
- only mode. You can do this by::
- sudo systemctl isolate multi-user.target
- To return to graphical mode, do::
- sudo systemctl isolate graphical.target
- Once you are in text only mode, you can run tests using the IGT_FORCE_DRIVER
- variable to specify the device filter for the driver we want to test.
- IGT_FORCE_DRIVER can also be used with the run-tests.sh script to run the
- tests for a specific driver::
- sudo IGT_FORCE_DRIVER="vkms" ./build/tests/<name of test>
- sudo IGT_FORCE_DRIVER="vkms" ./scripts/run-tests.sh -t <name of test>
- For example, to test the functionality of the writeback library,
- we can run the kms_writeback test::
- sudo IGT_FORCE_DRIVER="vkms" ./build/tests/kms_writeback
- sudo IGT_FORCE_DRIVER="vkms" ./scripts/run-tests.sh -t kms_writeback
- You can also run subtests if you do not want to run the entire test::
- sudo IGT_FORCE_DRIVER="vkms" ./build/tests/kms_flip --run-subtest basic-plain-flip
- Testing With KUnit
- ==================
- KUnit (Kernel unit testing framework) provides a common framework for unit tests
- within the Linux kernel.
- More information in ../dev-tools/kunit/index.rst .
- To run the VKMS KUnit tests::
- tools/testing/kunit/kunit.py run --kunitconfig=drivers/gpu/drm/vkms/tests
- TODO
- ====
- If you want to do any of the items listed below, please share your interest
- with VKMS maintainers.
- IGT better support
- ------------------
- Debugging:
- - kms_plane: some test cases are failing due to timeout on capturing CRC;
- Virtual hardware (vblank-less) mode:
- - VKMS already has support for vblanks simulated via hrtimers, which can be
- tested with kms_flip test; in some way, we can say that VKMS already mimics
- the real hardware vblank. However, we also have virtual hardware that does
- not support vblank interrupt and completes page_flip events right away; in
- this case, compositor developers may end up creating a busy loop on virtual
- hardware. It would be useful to support Virtual Hardware behavior in VKMS
- because this can help compositor developers to test their features in
- multiple scenarios.
- Add Plane Features
- ------------------
- There's lots of plane features we could add support for:
- - Add background color KMS property[Good to get started].
- - Scaling.
- - Additional buffer formats. Low/high bpp RGB formats would be interesting
- [Good to get started].
- - Async updates (currently only possible on cursor plane using the legacy
- cursor api).
- For all of these, we also want to review the igt test coverage and make sure
- all relevant igt testcases work on vkms. They are good options for internship
- project.
- Runtime Configuration
- ---------------------
- We want to be able to reconfigure vkms instance without having to reload the
- module through configfs. Use/Test-cases:
- - Hotplug/hotremove connectors on the fly (to be able to test DP MST handling
- of compositors).
- - Change output configuration: Plug/unplug screens, change EDID, allow changing
- the refresh rate.
- Writeback support
- -----------------
- - The writeback and CRC capture operations share the use of composer_enabled
- boolean to ensure vblanks. Probably, when these operations work together,
- composer_enabled needs to refcounting the composer state to proper work.
- [Good to get started]
- - Add support for cloned writeback outputs and related test cases using a
- cloned output in the IGT kms_writeback.
- - As a v4l device. This is useful for debugging compositors on special vkms
- configurations, so that developers see what's really going on.
- Output Features
- ---------------
- - Variable refresh rate/freesync support. This probably needs prime buffer
- sharing support, so that we can use vgem fences to simulate rendering in
- testing. Also needs support to specify the EDID.
- - Add support for link status, so that compositors can validate their runtime
- fallbacks when e.g. a Display Port link goes bad.
- CRC API Improvements
- --------------------
- - Optimize CRC computation ``compute_crc()`` and plane blending ``blend()``
- Atomic Check using eBPF
- -----------------------
- Atomic drivers have lots of restrictions which are not exposed to userspace in
- any explicit form through e.g. possible property values. Userspace can only
- inquiry about these limits through the atomic IOCTL, possibly using the
- TEST_ONLY flag. Trying to add configurable code for all these limits, to allow
- compositors to be tested against them, would be rather futile exercise. Instead
- we could add support for eBPF to validate any kind of atomic state, and
- implement a library of different restrictions.
- This needs a bunch of features (plane compositing, multiple outputs, ...)
- enabled already to make sense.
|