提交 79058100 编写于 作者: T Thierry Reding

drm/doc: mm: Fix indentation

Use spaces consistently for indentation in the memory-management
section.
Acked-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: NThierry Reding <treding@nvidia.com>
上级 8bf8180f
...@@ -492,10 +492,10 @@ char *date;</synopsis> ...@@ -492,10 +492,10 @@ char *date;</synopsis>
<sect2> <sect2>
<title>The Translation Table Manager (TTM)</title> <title>The Translation Table Manager (TTM)</title>
<para> <para>
TTM design background and information belongs here. TTM design background and information belongs here.
</para> </para>
<sect3> <sect3>
<title>TTM initialization</title> <title>TTM initialization</title>
<warning><para>This section is outdated.</para></warning> <warning><para>This section is outdated.</para></warning>
<para> <para>
Drivers wishing to support TTM must fill out a drm_bo_driver Drivers wishing to support TTM must fill out a drm_bo_driver
...@@ -503,42 +503,42 @@ char *date;</synopsis> ...@@ -503,42 +503,42 @@ char *date;</synopsis>
pointers for initializing the TTM, allocating and freeing memory, pointers for initializing the TTM, allocating and freeing memory,
waiting for command completion and fence synchronization, and memory waiting for command completion and fence synchronization, and memory
migration. See the radeon_ttm.c file for an example of usage. migration. See the radeon_ttm.c file for an example of usage.
</para> </para>
<para> <para>
The ttm_global_reference structure is made up of several fields: The ttm_global_reference structure is made up of several fields:
</para> </para>
<programlisting> <programlisting>
struct ttm_global_reference { struct ttm_global_reference {
enum ttm_global_types global_type; enum ttm_global_types global_type;
size_t size; size_t size;
void *object; void *object;
int (*init) (struct ttm_global_reference *); int (*init) (struct ttm_global_reference *);
void (*release) (struct ttm_global_reference *); void (*release) (struct ttm_global_reference *);
}; };
</programlisting> </programlisting>
<para> <para>
There should be one global reference structure for your memory There should be one global reference structure for your memory
manager as a whole, and there will be others for each object manager as a whole, and there will be others for each object
created by the memory manager at runtime. Your global TTM should created by the memory manager at runtime. Your global TTM should
have a type of TTM_GLOBAL_TTM_MEM. The size field for the global have a type of TTM_GLOBAL_TTM_MEM. The size field for the global
object should be sizeof(struct ttm_mem_global), and the init and object should be sizeof(struct ttm_mem_global), and the init and
release hooks should point at your driver-specific init and release hooks should point at your driver-specific init and
release routines, which probably eventually call release routines, which probably eventually call
ttm_mem_global_init and ttm_mem_global_release, respectively. ttm_mem_global_init and ttm_mem_global_release, respectively.
</para> </para>
<para> <para>
Once your global TTM accounting structure is set up and initialized Once your global TTM accounting structure is set up and initialized
by calling ttm_global_item_ref() on it, by calling ttm_global_item_ref() on it,
you need to create a buffer object TTM to you need to create a buffer object TTM to
provide a pool for buffer object allocation by clients and the provide a pool for buffer object allocation by clients and the
kernel itself. The type of this object should be TTM_GLOBAL_TTM_BO, kernel itself. The type of this object should be TTM_GLOBAL_TTM_BO,
and its size should be sizeof(struct ttm_bo_global). Again, and its size should be sizeof(struct ttm_bo_global). Again,
driver-specific init and release functions may be provided, driver-specific init and release functions may be provided,
likely eventually calling ttm_bo_global_init() and likely eventually calling ttm_bo_global_init() and
ttm_bo_global_release(), respectively. Also, like the previous ttm_bo_global_release(), respectively. Also, like the previous
object, ttm_global_item_ref() is used to create an initial reference object, ttm_global_item_ref() is used to create an initial reference
count for the TTM, which will call your initialization function. count for the TTM, which will call your initialization function.
</para> </para>
</sect3> </sect3>
</sect2> </sect2>
<sect2 id="drm-gem"> <sect2 id="drm-gem">
...@@ -566,19 +566,19 @@ char *date;</synopsis> ...@@ -566,19 +566,19 @@ char *date;</synopsis>
using driver-specific ioctls. using driver-specific ioctls.
</para> </para>
<para> <para>
On a fundamental level, GEM involves several operations: On a fundamental level, GEM involves several operations:
<itemizedlist> <itemizedlist>
<listitem>Memory allocation and freeing</listitem> <listitem>Memory allocation and freeing</listitem>
<listitem>Command execution</listitem> <listitem>Command execution</listitem>
<listitem>Aperture management at command execution time</listitem> <listitem>Aperture management at command execution time</listitem>
</itemizedlist> </itemizedlist>
Buffer object allocation is relatively straightforward and largely Buffer object allocation is relatively straightforward and largely
provided by Linux's shmem layer, which provides memory to back each provided by Linux's shmem layer, which provides memory to back each
object. object.
</para> </para>
<para> <para>
Device-specific operations, such as command execution, pinning, buffer Device-specific operations, such as command execution, pinning, buffer
read &amp; write, mapping, and domain ownership transfers are left to read &amp; write, mapping, and domain ownership transfers are left to
driver-specific ioctls. driver-specific ioctls.
</para> </para>
<sect3> <sect3>
...@@ -738,16 +738,16 @@ char *date;</synopsis> ...@@ -738,16 +738,16 @@ char *date;</synopsis>
respectively. The conversion is handled by the DRM core without any respectively. The conversion is handled by the DRM core without any
driver-specific support. driver-specific support.
</para> </para>
<para> <para>
GEM also supports buffer sharing with dma-buf file descriptors through GEM also supports buffer sharing with dma-buf file descriptors through
PRIME. GEM-based drivers must use the provided helpers functions to PRIME. GEM-based drivers must use the provided helpers functions to
implement the exporting and importing correctly. See <xref linkend="drm-prime-support" />. implement the exporting and importing correctly. See <xref linkend="drm-prime-support" />.
Since sharing file descriptors is inherently more secure than the Since sharing file descriptors is inherently more secure than the
easily guessable and global GEM names it is the preferred buffer easily guessable and global GEM names it is the preferred buffer
sharing mechanism. Sharing buffers through GEM names is only supported sharing mechanism. Sharing buffers through GEM names is only supported
for legacy userspace. Furthermore PRIME also allows cross-device for legacy userspace. Furthermore PRIME also allows cross-device
buffer sharing since it is based on dma-bufs. buffer sharing since it is based on dma-bufs.
</para> </para>
</sect3> </sect3>
<sect3 id="drm-gem-objects-mapping"> <sect3 id="drm-gem-objects-mapping">
<title>GEM Objects Mapping</title> <title>GEM Objects Mapping</title>
...@@ -852,7 +852,7 @@ char *date;</synopsis> ...@@ -852,7 +852,7 @@ char *date;</synopsis>
<sect3> <sect3>
<title>Command Execution</title> <title>Command Execution</title>
<para> <para>
Perhaps the most important GEM function for GPU devices is providing a Perhaps the most important GEM function for GPU devices is providing a
command execution interface to clients. Client programs construct command execution interface to clients. Client programs construct
command buffers containing references to previously allocated memory command buffers containing references to previously allocated memory
objects, and then submit them to GEM. At that point, GEM takes care to objects, and then submit them to GEM. At that point, GEM takes care to
...@@ -874,95 +874,95 @@ char *date;</synopsis> ...@@ -874,95 +874,95 @@ char *date;</synopsis>
<title>GEM Function Reference</title> <title>GEM Function Reference</title>
!Edrivers/gpu/drm/drm_gem.c !Edrivers/gpu/drm/drm_gem.c
</sect3> </sect3>
</sect2> </sect2>
<sect2> <sect2>
<title>VMA Offset Manager</title> <title>VMA Offset Manager</title>
!Pdrivers/gpu/drm/drm_vma_manager.c vma offset manager !Pdrivers/gpu/drm/drm_vma_manager.c vma offset manager
!Edrivers/gpu/drm/drm_vma_manager.c !Edrivers/gpu/drm/drm_vma_manager.c
!Iinclude/drm/drm_vma_manager.h !Iinclude/drm/drm_vma_manager.h
</sect2> </sect2>
<sect2 id="drm-prime-support"> <sect2 id="drm-prime-support">
<title>PRIME Buffer Sharing</title> <title>PRIME Buffer Sharing</title>
<para> <para>
PRIME is the cross device buffer sharing framework in drm, originally PRIME is the cross device buffer sharing framework in drm, originally
created for the OPTIMUS range of multi-gpu platforms. To userspace created for the OPTIMUS range of multi-gpu platforms. To userspace
PRIME buffers are dma-buf based file descriptors. PRIME buffers are dma-buf based file descriptors.
</para> </para>
<sect3> <sect3>
<title>Overview and Driver Interface</title> <title>Overview and Driver Interface</title>
<para> <para>
Similar to GEM global names, PRIME file descriptors are Similar to GEM global names, PRIME file descriptors are
also used to share buffer objects across processes. They offer also used to share buffer objects across processes. They offer
additional security: as file descriptors must be explicitly sent over additional security: as file descriptors must be explicitly sent over
UNIX domain sockets to be shared between applications, they can't be UNIX domain sockets to be shared between applications, they can't be
guessed like the globally unique GEM names. guessed like the globally unique GEM names.
</para> </para>
<para> <para>
Drivers that support the PRIME Drivers that support the PRIME
API must set the DRIVER_PRIME bit in the struct API must set the DRIVER_PRIME bit in the struct
<structname>drm_driver</structname> <structname>drm_driver</structname>
<structfield>driver_features</structfield> field, and implement the <structfield>driver_features</structfield> field, and implement the
<methodname>prime_handle_to_fd</methodname> and <methodname>prime_handle_to_fd</methodname> and
<methodname>prime_fd_to_handle</methodname> operations. <methodname>prime_fd_to_handle</methodname> operations.
</para> </para>
<para> <para>
<synopsis>int (*prime_handle_to_fd)(struct drm_device *dev, <synopsis>int (*prime_handle_to_fd)(struct drm_device *dev,
struct drm_file *file_priv, uint32_t handle, struct drm_file *file_priv, uint32_t handle,
uint32_t flags, int *prime_fd); uint32_t flags, int *prime_fd);
int (*prime_fd_to_handle)(struct drm_device *dev, int (*prime_fd_to_handle)(struct drm_device *dev,
struct drm_file *file_priv, int prime_fd, struct drm_file *file_priv, int prime_fd,
uint32_t *handle);</synopsis> uint32_t *handle);</synopsis>
Those two operations convert a handle to a PRIME file descriptor and Those two operations convert a handle to a PRIME file descriptor and
vice versa. Drivers must use the kernel dma-buf buffer sharing framework vice versa. Drivers must use the kernel dma-buf buffer sharing framework
to manage the PRIME file descriptors. Similar to the mode setting to manage the PRIME file descriptors. Similar to the mode setting
API PRIME is agnostic to the underlying buffer object manager, as API PRIME is agnostic to the underlying buffer object manager, as
long as handles are 32bit unsigned integers. long as handles are 32bit unsigned integers.
</para> </para>
<para> <para>
While non-GEM drivers must implement the operations themselves, GEM While non-GEM drivers must implement the operations themselves, GEM
drivers must use the <function>drm_gem_prime_handle_to_fd</function> drivers must use the <function>drm_gem_prime_handle_to_fd</function>
and <function>drm_gem_prime_fd_to_handle</function> helper functions. and <function>drm_gem_prime_fd_to_handle</function> helper functions.
Those helpers rely on the driver Those helpers rely on the driver
<methodname>gem_prime_export</methodname> and <methodname>gem_prime_export</methodname> and
<methodname>gem_prime_import</methodname> operations to create a dma-buf <methodname>gem_prime_import</methodname> operations to create a dma-buf
instance from a GEM object (dma-buf exporter role) and to create a GEM instance from a GEM object (dma-buf exporter role) and to create a GEM
object from a dma-buf instance (dma-buf importer role). object from a dma-buf instance (dma-buf importer role).
</para> </para>
<para> <para>
<synopsis>struct dma_buf * (*gem_prime_export)(struct drm_device *dev, <synopsis>struct dma_buf * (*gem_prime_export)(struct drm_device *dev,
struct drm_gem_object *obj, struct drm_gem_object *obj,
int flags); int flags);
struct drm_gem_object * (*gem_prime_import)(struct drm_device *dev, struct drm_gem_object * (*gem_prime_import)(struct drm_device *dev,
struct dma_buf *dma_buf);</synopsis> struct dma_buf *dma_buf);</synopsis>
These two operations are mandatory for GEM drivers that support These two operations are mandatory for GEM drivers that support
PRIME. PRIME.
</para> </para>
</sect3>
<sect3>
<title>PRIME Helper Functions</title>
!Pdrivers/gpu/drm/drm_prime.c PRIME Helpers
</sect3> </sect3>
</sect2> <sect3>
<sect2> <title>PRIME Helper Functions</title>
<title>PRIME Function References</title> !Pdrivers/gpu/drm/drm_prime.c PRIME Helpers
</sect3>
</sect2>
<sect2>
<title>PRIME Function References</title>
!Edrivers/gpu/drm/drm_prime.c !Edrivers/gpu/drm/drm_prime.c
</sect2> </sect2>
<sect2> <sect2>
<title>DRM MM Range Allocator</title> <title>DRM MM Range Allocator</title>
<sect3> <sect3>
<title>Overview</title> <title>Overview</title>
!Pdrivers/gpu/drm/drm_mm.c Overview !Pdrivers/gpu/drm/drm_mm.c Overview
</sect3> </sect3>
<sect3> <sect3>
<title>LRU Scan/Eviction Support</title> <title>LRU Scan/Eviction Support</title>
!Pdrivers/gpu/drm/drm_mm.c lru scan roaster !Pdrivers/gpu/drm/drm_mm.c lru scan roaster
</sect3> </sect3>
</sect2> </sect2>
<sect2> <sect2>
<title>DRM MM Range Allocator Function References</title> <title>DRM MM Range Allocator Function References</title>
!Edrivers/gpu/drm/drm_mm.c !Edrivers/gpu/drm/drm_mm.c
!Iinclude/drm/drm_mm.h !Iinclude/drm/drm_mm.h
</sect2> </sect2>
</sect1> </sect1>
<!-- Internals: mode setting --> <!-- Internals: mode setting -->
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册