~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/gpu/amdgpu/driver-core.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/gpu/amdgpu/driver-core.rst (Architecture i386) and /Documentation/gpu/amdgpu/driver-core.rst (Architecture mips)


  1 ============================                        1 ============================
  2  Core Driver Infrastructure                         2  Core Driver Infrastructure
  3 ============================                        3 ============================
  4                                                     4 
  5 GPU Hardware Structure                              5 GPU Hardware Structure
  6 ======================                              6 ======================
  7                                                     7 
  8 Each ASIC is a collection of hardware blocks.       8 Each ASIC is a collection of hardware blocks.  We refer to them as
  9 "IPs" (Intellectual Property blocks).  Each IP      9 "IPs" (Intellectual Property blocks).  Each IP encapsulates certain
 10 functionality. IPs are versioned and can also      10 functionality. IPs are versioned and can also be mixed and matched.
 11 E.g., you might have two different ASICs that      11 E.g., you might have two different ASICs that both have System DMA (SDMA) 5.x IPs.
 12 The driver is arranged by IPs.  There are driv     12 The driver is arranged by IPs.  There are driver components to handle
 13 the initialization and operation of each IP.       13 the initialization and operation of each IP.  There are also a bunch
 14 of smaller IPs that don't really need much if      14 of smaller IPs that don't really need much if any driver interaction.
 15 Those end up getting lumped into the common st     15 Those end up getting lumped into the common stuff in the soc files.
 16 The soc files (e.g., vi.c, soc15.c nv.c) conta     16 The soc files (e.g., vi.c, soc15.c nv.c) contain code for aspects of
 17 the SoC itself rather than specific IPs.  E.g.     17 the SoC itself rather than specific IPs.  E.g., things like GPU resets
 18 and register access functions are SoC dependen     18 and register access functions are SoC dependent.
 19                                                    19 
 20 An APU contains more than just CPU and GPU, it     20 An APU contains more than just CPU and GPU, it also contains all of
 21 the platform stuff (audio, usb, gpio, etc.).       21 the platform stuff (audio, usb, gpio, etc.).  Also, a lot of
 22 components are shared between the CPU, platfor     22 components are shared between the CPU, platform, and the GPU (e.g.,
 23 SMU, PSP, etc.).  Specific components (CPU, GP     23 SMU, PSP, etc.).  Specific components (CPU, GPU, etc.) usually have
 24 their interface to interact with those common      24 their interface to interact with those common components.  For things
 25 like S0i3 there is a ton of coordination requi     25 like S0i3 there is a ton of coordination required across all the
 26 components, but that is probably a bit beyond      26 components, but that is probably a bit beyond the scope of this
 27 section.                                           27 section.
 28                                                    28 
 29 With respect to the GPU, we have the following     29 With respect to the GPU, we have the following major IPs:
 30                                                    30 
 31 GMC (Graphics Memory Controller)                   31 GMC (Graphics Memory Controller)
 32     This was a dedicated IP on older pre-vega      32     This was a dedicated IP on older pre-vega chips, but has since
 33     become somewhat decentralized on vega and      33     become somewhat decentralized on vega and newer chips.  They now
 34     have dedicated memory hubs for specific IP     34     have dedicated memory hubs for specific IPs or groups of IPs.  We
 35     still treat it as a single component in th     35     still treat it as a single component in the driver however since
 36     the programming model is still pretty simi     36     the programming model is still pretty similar.  This is how the
 37     different IPs on the GPU get the memory (V     37     different IPs on the GPU get the memory (VRAM or system memory).
 38     It also provides the support for per proce     38     It also provides the support for per process GPU virtual address
 39     spaces.                                        39     spaces.
 40                                                    40 
 41 IH (Interrupt Handler)                             41 IH (Interrupt Handler)
 42     This is the interrupt controller on the GP     42     This is the interrupt controller on the GPU.  All of the IPs feed
 43     their interrupts into this IP and it aggre     43     their interrupts into this IP and it aggregates them into a set of
 44     ring buffers that the driver can parse to      44     ring buffers that the driver can parse to handle interrupts from
 45     different IPs.                                 45     different IPs.
 46                                                    46 
 47 PSP (Platform Security Processor)                  47 PSP (Platform Security Processor)
 48     This handles security policy for the SoC a     48     This handles security policy for the SoC and executes trusted
 49     applications, and validates and loads firm     49     applications, and validates and loads firmwares for other blocks.
 50                                                    50 
 51 SMU (System Management Unit)                       51 SMU (System Management Unit)
 52     This is the power management microcontroll     52     This is the power management microcontroller.  It manages the entire
 53     SoC.  The driver interacts with it to cont     53     SoC.  The driver interacts with it to control power management
 54     features like clocks, voltages, power rail     54     features like clocks, voltages, power rails, etc.
 55                                                    55 
 56 DCN (Display Controller Next)                      56 DCN (Display Controller Next)
 57     This is the display controller.  It handle     57     This is the display controller.  It handles the display hardware.
 58     It is described in more details in :ref:`D     58     It is described in more details in :ref:`Display Core <amdgpu-display-core>`.
 59                                                    59 
 60 SDMA (System DMA)                                  60 SDMA (System DMA)
 61     This is a multi-purpose DMA engine.  The k     61     This is a multi-purpose DMA engine.  The kernel driver uses it for
 62     various things including paging and GPU pa     62     various things including paging and GPU page table updates.  It's also
 63     exposed to userspace for use by user mode      63     exposed to userspace for use by user mode drivers (OpenGL, Vulkan,
 64     etc.)                                          64     etc.)
 65                                                    65 
 66 GC (Graphics and Compute)                          66 GC (Graphics and Compute)
 67     This is the graphics and compute engine, i     67     This is the graphics and compute engine, i.e., the block that
 68     encompasses the 3D pipeline and and shader     68     encompasses the 3D pipeline and and shader blocks.  This is by far the
 69     largest block on the GPU.  The 3D pipeline     69     largest block on the GPU.  The 3D pipeline has tons of sub-blocks.  In
 70     addition to that, it also contains the CP      70     addition to that, it also contains the CP microcontrollers (ME, PFP,
 71     CE, MEC) and the RLC microcontroller.  It'     71     CE, MEC) and the RLC microcontroller.  It's exposed to userspace for
 72     user mode drivers (OpenGL, Vulkan, OpenCL,     72     user mode drivers (OpenGL, Vulkan, OpenCL, etc.)
 73                                                    73 
 74 VCN (Video Core Next)                              74 VCN (Video Core Next)
 75     This is the multi-media engine.  It handle     75     This is the multi-media engine.  It handles video and image encode and
 76     decode.  It's exposed to userspace for use     76     decode.  It's exposed to userspace for user mode drivers (VA-API,
 77     OpenMAX, etc.)                                 77     OpenMAX, etc.)
 78                                                    78 
 79 Graphics and Compute Microcontrollers              79 Graphics and Compute Microcontrollers
 80 -------------------------------------              80 -------------------------------------
 81                                                    81 
 82 CP (Command Processor)                             82 CP (Command Processor)
 83     The name for the hardware block that encom     83     The name for the hardware block that encompasses the front end of the
 84     GFX/Compute pipeline.  Consists mainly of      84     GFX/Compute pipeline.  Consists mainly of a bunch of microcontrollers
 85     (PFP, ME, CE, MEC).  The firmware that run     85     (PFP, ME, CE, MEC).  The firmware that runs on these microcontrollers
 86     provides the driver interface to interact      86     provides the driver interface to interact with the GFX/Compute engine.
 87                                                    87 
 88     MEC (MicroEngine Compute)                      88     MEC (MicroEngine Compute)
 89         This is the microcontroller that contr     89         This is the microcontroller that controls the compute queues on the
 90         GFX/compute engine.                        90         GFX/compute engine.
 91                                                    91 
 92     MES (MicroEngine Scheduler)                    92     MES (MicroEngine Scheduler)
 93         This is a new engine for managing queu     93         This is a new engine for managing queues.  This is currently unused.
 94                                                    94 
 95 RLC (RunList Controller)                           95 RLC (RunList Controller)
 96     This is another microcontroller in the GFX     96     This is another microcontroller in the GFX/Compute engine.  It handles
 97     power management related functionality wit     97     power management related functionality within the GFX/Compute engine.
 98     The name is a vestige of old hardware wher     98     The name is a vestige of old hardware where it was originally added
 99     and doesn't really have much relation to w     99     and doesn't really have much relation to what the engine does now.
100                                                   100 
101 Driver Structure                                  101 Driver Structure
102 ================                                  102 ================
103                                                   103 
104 In general, the driver has a list of all of th    104 In general, the driver has a list of all of the IPs on a particular
105 SoC and for things like init/fini/suspend/resu    105 SoC and for things like init/fini/suspend/resume, more or less just
106 walks the list and handles each IP.               106 walks the list and handles each IP.
107                                                   107 
108 Some useful constructs:                           108 Some useful constructs:
109                                                   109 
110 KIQ (Kernel Interface Queue)                      110 KIQ (Kernel Interface Queue)
111     This is a control queue used by the kernel    111     This is a control queue used by the kernel driver to manage other gfx
112     and compute queues on the GFX/compute engi    112     and compute queues on the GFX/compute engine.  You can use it to
113     map/unmap additional queues, etc.             113     map/unmap additional queues, etc.
114                                                   114 
115 IB (Indirect Buffer)                              115 IB (Indirect Buffer)
116     A command buffer for a particular engine.     116     A command buffer for a particular engine.  Rather than writing
117     commands directly to the queue, you can wr    117     commands directly to the queue, you can write the commands into a
118     piece of memory and then put a pointer to     118     piece of memory and then put a pointer to the memory into the queue.
119     The hardware will then follow the pointer     119     The hardware will then follow the pointer and execute the commands in
120     the memory, then returning to the rest of     120     the memory, then returning to the rest of the commands in the ring.
121                                                   121 
122 .. _amdgpu_memory_domains:                        122 .. _amdgpu_memory_domains:
123                                                   123 
124 Memory Domains                                    124 Memory Domains
125 ==============                                    125 ==============
126                                                   126 
127 .. kernel-doc:: include/uapi/drm/amdgpu_drm.h     127 .. kernel-doc:: include/uapi/drm/amdgpu_drm.h
128    :doc: memory domains                           128    :doc: memory domains
129                                                   129 
130 Buffer Objects                                    130 Buffer Objects
131 ==============                                    131 ==============
132                                                   132 
133 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    133 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
134    :doc: amdgpu_object                            134    :doc: amdgpu_object
135                                                   135 
136 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    136 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
137    :internal:                                     137    :internal:
138                                                   138 
139 PRIME Buffer Sharing                              139 PRIME Buffer Sharing
140 ====================                              140 ====================
141                                                   141 
142 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    142 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_dma_buf.c
143    :doc: PRIME Buffer Sharing                     143    :doc: PRIME Buffer Sharing
144                                                   144 
145 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    145 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_dma_buf.c
146    :internal:                                     146    :internal:
147                                                   147 
148 MMU Notifier                                      148 MMU Notifier
149 ============                                      149 ============
150                                                   150 
151 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    151 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_hmm.c
152    :doc: MMU Notifier                             152    :doc: MMU Notifier
153                                                   153 
154 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    154 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_hmm.c
155    :internal:                                     155    :internal:
156                                                   156 
157 AMDGPU Virtual Memory                             157 AMDGPU Virtual Memory
158 =====================                             158 =====================
159                                                   159 
160 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    160 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
161    :doc: GPUVM                                    161    :doc: GPUVM
162                                                   162 
163 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    163 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
164    :internal:                                     164    :internal:
165                                                   165 
166 Interrupt Handling                                166 Interrupt Handling
167 ==================                                167 ==================
168                                                   168 
169 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    169 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_irq.c
170    :doc: Interrupt Handling                       170    :doc: Interrupt Handling
171                                                   171 
172 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amd    172 .. kernel-doc:: drivers/gpu/drm/amd/amdgpu/amdgpu_irq.c
173    :internal:                                     173    :internal:
174                                                   174 
175 IP Blocks                                         175 IP Blocks
176 =========                                         176 =========
177                                                   177 
178 .. kernel-doc:: drivers/gpu/drm/amd/include/am    178 .. kernel-doc:: drivers/gpu/drm/amd/include/amd_shared.h
179    :doc: IP Blocks                                179    :doc: IP Blocks
180                                                   180 
181 .. kernel-doc:: drivers/gpu/drm/amd/include/am    181 .. kernel-doc:: drivers/gpu/drm/amd/include/amd_shared.h
182    :identifiers: amd_ip_block_type amd_ip_func    182    :identifiers: amd_ip_block_type amd_ip_funcs DC_DEBUG_MASK
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php