dcn-overview.rst 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. =======================
  2. Display Core Next (DCN)
  3. =======================
  4. To equip our readers with the basic knowledge of how AMD Display Core Next
  5. (DCN) works, we need to start with an overview of the hardware pipeline. Below
  6. you can see a picture that provides a DCN overview, keep in mind that this is a
  7. generic diagram, and we have variations per ASIC.
  8. .. kernel-figure:: dc_pipeline_overview.svg
  9. Based on this diagram, we can pass through each block and briefly describe
  10. them:
  11. * **Display Controller Hub (DCHUB)**: This is the gateway between the Scalable
  12. Data Port (SDP) and DCN. This component has multiple features, such as memory
  13. arbitration, rotation, and cursor manipulation.
  14. * **Display Pipe and Plane (DPP)**: This block provides pre-blend pixel
  15. processing such as color space conversion, linearization of pixel data, tone
  16. mapping, and gamut mapping.
  17. * **Multiple Pipe/Plane Combined (MPC)**: This component performs blending of
  18. multiple planes, using global or per-pixel alpha.
  19. * **Output Pixel Processing (OPP)**: Process and format pixels to be sent to
  20. the display.
  21. * **Output Pipe Timing Combiner (OPTC)**: It generates time output to combine
  22. streams or divide capabilities. CRC values are generated in this block.
  23. * **Display Output (DIO)**: Codify the output to the display connected to our
  24. GPU.
  25. * **Display Writeback (DWB)**: It provides the ability to write the output of
  26. the display pipe back to memory as video frames.
  27. * **Multi-Media HUB (MMHUBBUB)**: Memory controller interface for DMCUB and DWB
  28. (Note that DWB is not hooked yet).
  29. * **DCN Management Unit (DMU)**: It provides registers with access control and
  30. interrupts the controller to the SOC host interrupt unit. This block includes
  31. the Display Micro-Controller Unit - version B (DMCUB), which is handled via
  32. firmware.
  33. * **DCN Clock Generator Block (DCCG)**: It provides the clocks and resets
  34. for all of the display controller clock domains.
  35. * **Azalia (AZ)**: Audio engine.
  36. The above diagram is an architecture generalization of DCN, which means that
  37. every ASIC has variations around this base model. Notice that the display
  38. pipeline is connected to the Scalable Data Port (SDP) via DCHUB; you can see
  39. the SDP as the element from our Data Fabric that feeds the display pipe.
  40. Always approach the DCN architecture as something flexible that can be
  41. configured and reconfigured in multiple ways; in other words, each block can be
  42. setup or ignored accordingly with userspace demands. For example, if we
  43. want to drive an 8k@60Hz with a DSC enabled, our DCN may require 4 DPP and 2
  44. OPP. It is DC's responsibility to drive the best configuration for each
  45. specific scenario. Orchestrate all of these components together requires a
  46. sophisticated communication interface which is highlighted in the diagram by
  47. the edges that connect each block; from the chart, each connection between
  48. these blocks represents:
  49. 1. Pixel data interface (red): Represents the pixel data flow;
  50. 2. Global sync signals (green): It is a set of synchronization signals composed
  51. by VStartup, VUpdate, and VReady;
  52. 3. Config interface: Responsible to configure blocks;
  53. 4. Sideband signals: All other signals that do not fit the previous one.
  54. These signals are essential and play an important role in DCN. Nevertheless,
  55. the Global Sync deserves an extra level of detail described in the next
  56. section.
  57. All of these components are represented by a data structure named dc_state.
  58. From DCHUB to MPC, we have a representation called dc_plane; from MPC to OPTC,
  59. we have dc_stream, and the output (DIO) is handled by dc_link. Keep in mind
  60. that HUBP accesses a surface using a specific format read from memory, and our
  61. dc_plane should work to convert all pixels in the plane to something that can
  62. be sent to the display via dc_stream and dc_link.
  63. Front End and Back End
  64. ----------------------
  65. Display pipeline can be broken down into two components that are usually
  66. referred as **Front End (FE)** and **Back End (BE)**, where FE consists of:
  67. * DCHUB (Mainly referring to a subcomponent named HUBP)
  68. * DPP
  69. * MPC
  70. On the other hand, BE consist of
  71. * OPP
  72. * OPTC
  73. * DIO (DP/HDMI stream encoder and link encoder)
  74. OPP and OPTC are two joining blocks between FE and BE. On a side note, this is
  75. a one-to-one mapping of the link encoder to PHY, but we can configure the DCN
  76. to choose which link encoder to connect to which PHY. FE's main responsibility
  77. is to change, blend and compose pixel data, while BE's job is to frame a
  78. generic pixel stream to a specific display's pixel stream.
  79. Data Flow
  80. ---------
  81. Initially, data is passed in from VRAM through Data Fabric (DF) in native pixel
  82. formats. Such data format stays through till HUBP in DCHUB, where HUBP unpacks
  83. different pixel formats and outputs them to DPP in uniform streams through 4
  84. channels (1 for alpha + 3 for colors).
  85. The Converter and Cursor (CNVC) in DPP would then normalize the data
  86. representation and convert them to a DCN specific floating-point format (i.e.,
  87. different from the IEEE floating-point format). In the process, CNVC also
  88. applies a degamma function to transform the data from non-linear to linear
  89. space to relax the floating-point calculations following. Data would stay in
  90. this floating-point format from DPP to OPP.
  91. Starting OPP, because color transformation and blending have been completed
  92. (i.e alpha can be dropped), and the end sinks do not require the precision and
  93. dynamic range that floating points provide (i.e. all displays are in integer
  94. depth format), bit-depth reduction/dithering would kick in. In OPP, we would
  95. also apply a regamma function to introduce the gamma removed earlier back.
  96. Eventually, we output data in integer format at DIO.
  97. AMD Hardware Pipeline
  98. ---------------------
  99. When discussing graphics on Linux, the **pipeline** term can sometimes be
  100. overloaded with multiple meanings, so it is important to define what we mean
  101. when we say **pipeline**. In the DCN driver, we use the term **hardware
  102. pipeline** or **pipeline** or just **pipe** as an abstraction to indicate a
  103. sequence of DCN blocks instantiated to address some specific configuration. DC
  104. core treats DCN blocks as individual resources, meaning we can build a pipeline
  105. by taking resources for all individual hardware blocks to compose one pipeline.
  106. In actuality, we can't connect an arbitrary block from one pipe to a block from
  107. another pipe; they are routed linearly, except for DSC, which can be
  108. arbitrarily assigned as needed. We have this pipeline concept for trying to
  109. optimize bandwidth utilization.
  110. .. kernel-figure:: pipeline_4k_no_split.svg
  111. Additionally, let's take a look at parts of the DTN log (see
  112. 'Documentation/gpu/amdgpu/display/dc-debug.rst' for more information) since
  113. this log can help us to see part of this pipeline behavior in real-time::
  114. HUBP: format addr_hi width height ...
  115. [ 0]: 8h 81h 3840 2160
  116. [ 1]: 0h 0h 0 0
  117. [ 2]: 0h 0h 0 0
  118. [ 3]: 0h 0h 0 0
  119. [ 4]: 0h 0h 0 0
  120. ...
  121. MPCC: OPP DPP ...
  122. [ 0]: 0h 0h ...
  123. The first thing to notice from the diagram and DTN log it is the fact that we
  124. have different clock domains for each part of the DCN blocks. In this example,
  125. we have just a single **pipeline** where the data flows from DCHUB to DIO, as
  126. we intuitively expect. Nonetheless, DCN is flexible, as mentioned before, and
  127. we can split this single pipe differently, as described in the below diagram:
  128. .. kernel-figure:: pipeline_4k_split.svg
  129. Now, if we inspect the DTN log again we can see some interesting changes::
  130. HUBP: format addr_hi width height ...
  131. [ 0]: 8h 81h 1920 2160 ...
  132. ...
  133. [ 4]: 0h 0h 0 0 ...
  134. [ 5]: 8h 81h 1920 2160 ...
  135. ...
  136. MPCC: OPP DPP ...
  137. [ 0]: 0h 0h ...
  138. [ 5]: 0h 5h ...
  139. From the above example, we now split the display pipeline into two vertical
  140. parts of 1920x2160 (i.e., 3440x2160), and as a result, we could reduce the
  141. clock frequency in the DPP part. This is not only useful for saving power but
  142. also to better handle the required throughput. The idea to keep in mind here is
  143. that the pipe configuration can vary a lot according to the display
  144. configuration, and it is the DML's responsibility to set up all required
  145. configuration parameters for multiple scenarios supported by our hardware.
  146. Global Sync
  147. -----------
  148. Many DCN registers are double buffered, most importantly the surface address.
  149. This allows us to update DCN hardware atomically for page flips, as well as
  150. for most other updates that don't require enabling or disabling of new pipes.
  151. (Note: There are many scenarios when DC will decide to reserve extra pipes
  152. in order to support outputs that need a very high pixel clock, or for
  153. power saving purposes.)
  154. These atomic register updates are driven by global sync signals in DCN. In
  155. order to understand how atomic updates interact with DCN hardware, and how DCN
  156. signals page flip and vblank events it is helpful to understand how global sync
  157. is programmed.
  158. Global sync consists of three signals, VSTARTUP, VUPDATE, and VREADY. These are
  159. calculated by the Display Mode Library - DML (drivers/gpu/drm/amd/display/dc/dml)
  160. based on a large number of parameters and ensure our hardware is able to feed
  161. the DCN pipeline without underflows or hangs in any given system configuration.
  162. The global sync signals always happen during VBlank, are independent from the
  163. VSync signal, and do not overlap each other.
  164. VUPDATE is the only signal that is of interest to the rest of the driver stack
  165. or userspace clients as it signals the point at which hardware latches to
  166. atomically programmed (i.e. double buffered) registers. Even though it is
  167. independent of the VSync signal we use VUPDATE to signal the VSync event as it
  168. provides the best indication of how atomic commits and hardware interact.
  169. Since DCN hardware is double-buffered the DC driver is able to program the
  170. hardware at any point during the frame.
  171. The below picture illustrates the global sync signals:
  172. .. kernel-figure:: global_sync_vblank.svg
  173. These signals affect core DCN behavior. Programming them incorrectly will lead
  174. to a number of negative consequences, most of them quite catastrophic.
  175. The following picture shows how global sync allows for a mailbox style of
  176. updates, i.e. it allows for multiple re-configurations between VUpdate
  177. events where only the last configuration programmed before the VUpdate signal
  178. becomes effective.
  179. .. kernel-figure:: config_example.svg