1.. _display_todos:
2
3==============================
4AMDGPU - Display Contributions
5==============================
6
7First of all, if you are here, you probably want to give some technical
8contribution to the display code, and for that, we say thank you :)
9
10This page summarizes some of the issues you can help with; keep in mind that
11this is a static page, and it is always a good idea to try to reach developers
12in the amdgfx or some of the maintainers. Finally, this page follows the DRM
13way of creating a TODO list; for more information, check
14'Documentation/gpu/todo.rst'.
15
16Gitlab issues
17=============
18
19Users can report issues associated with AMD GPUs at:
20
21- https://gitlab.freedesktop.org/drm/amd
22
23Usually, we try to add a proper label to all new tickets to make it easy to
24filter issues. If you can reproduce any problem, you could help by adding more
25information or fixing the issue.
26
27Level: diverse
28
29IGT
30===
31
32`IGT`_ provides many integration tests that can be run on your GPU. We always
33want to pass a large set of tests to increase the test coverage in our CI. If
34you wish to contribute to the display code but are unsure where a good place
35is, we recommend you run all IGT tests and try to fix any failure you see in
36your hardware. Keep in mind that this failure can be an IGT problem or a kernel
37issue; it is necessary to analyze case-by-case.
38
39Level: diverse
40
41.. _IGT: https://gitlab.freedesktop.org/drm/igt-gpu-tools
42
43Compilation
44===========
45
46Fix compilation warnings
47------------------------
48
49Enable the W1 or W2 warning level in the kernel compilation and try to fix the
50issues on the display side.
51
52Level: Starter
53
54Fix compilation issues when using um architecture
55-------------------------------------------------
56
57Linux has a User-mode Linux (UML) feature, and the kernel can be compiled to
58the **um** architecture. Compiling for **um** can bring multiple advantages
59from the test perspective. We currently have some compilation issues in this
60area that we need to fix.
61
62Level: Intermediate
63
64Code Refactor
65=============
66
67Add prefix to DC functions to improve the debug with ftrace
68-----------------------------------------------------------
69
70The Ftrace debug feature (check 'Documentation/trace/ftrace.rst') is a
71fantastic way to check the code path when developers try to make sense of a
72bug. Ftrace provides a filter mechanism that can be useful when the developer
73has some hunch of which part of the code can cause the issue; for this reason,
74if a set of functions has a proper prefix, it becomes easy to create a good
75filter. Additionally, prefixes can improve stack trace readability.
76
77The DC code does not follow some prefix rules, which makes the Ftrace filter
78more complicated and reduces the readability of the stack trace. If you want
79something simple to start contributing to the display, you can make patches for
80adding prefixes to DC functions. To create those prefixes, use part of the file
81name as a prefix for all functions in the target file. Check the
82'amdgpu_dm_crtc.c` and `amdgpu_dm_plane.c` for some references. However, we
83strongly advise not to send huge patches changing these prefixes; otherwise, it
84will be hard to review and test, which can generate second thoughts from
85maintainers. Try small steps; in case of double, you can ask before you put in
86effort. We recommend first looking at folders like dceXYZ, dcnXYZ, basics,
87bios, core, clk_mgr, hwss, resource, and irq.
88
89Level: Starter
90
91Reduce code duplication
92-----------------------
93
94AMD has an extensive portfolio with various dGPUs and APUs that amdgpu
95supports. To maintain the new hardware release cadence, DCE/DCN was designed in
96a modular design, making the bring-up for new hardware fast. Over the years,
97amdgpu accumulated some technical debt in the code duplication area. For this
98task, it would be a good idea to find a tool that can discover code duplication
99(including patterns) and use it as guidance to reduce duplications.
100
101Level: Intermediate
102
103Make atomic_commit_[check|tail] more readable
104---------------------------------------------
105
106The functions responsible for atomic commit and tail are intricate and
107extensive. In particular `amdgpu_dm_atomic_commit_tail` is a long function and
108could benefit from being split into smaller helpers. Improvements in this area
109are more than welcome, but keep in mind that changes in this area will affect
110all ASICs, meaning that refactoring requires a comprehensive verification; in
111other words, this effort can take some time for validation.
112
113Level: Advanced
114
115Documentation
116=============
117
118Expand kernel-doc
119-----------------
120
121Many DC functions do not have a proper kernel-doc; understanding a function and
122adding documentation is a great way to learn more about the amdgpu driver and
123also leave an outstanding contribution to the entire community.
124
125Level: Starter
126
127Beyond AMDGPU
128=============
129
130AMDGPU provides features that are not yet enabled in the userspace. This
131section highlights some of the coolest display features, which could be enabled
132with the userspace developer helper.
133
134Enable underlay
135---------------
136
137AMD display has this feature called underlay (which you can read more about at
138'Documentation/gpu/amdgpu/display/mpo-overview.rst') which is intended to
139save power when playing a video. The basic idea is to put a video in the
140underlay plane at the bottom and the desktop in the plane above it with a hole
141in the video area. This feature is enabled in ChromeOS, and from our data
142measurement, it can save power.
143
144Level: Unknown
145
146Adaptive Backlight Modulation (ABM)
147-----------------------------------
148
149ABM is a feature that adjusts the display panel's backlight level and pixel
150values depending on the displayed image. This power-saving feature can be very
151useful when the system starts to run off battery; since this will impact the
152display output fidelity, it would be good if this option was something that
153users could turn on or off.
154
155Level: Unknown
156
157
158HDR & Color management & VRR
159----------------------------
160
161HDR, Color Management, and VRR are huge topics and it's hard to put these into
162concise ToDos. If you are interested in this topic, we recommend checking some
163blog posts from the community developers to better understand some of the
164specific challenges and people working on the subject. If anyone wants to work
165on some particular part, we can try to help with some basic guidance. Finally,
166keep in mind that we already have some kernel-doc in place for those areas.
167
168Level: Unknown
169