/openbmc/linux/drivers/gpu/drm/ |
H A D | drm_gem_ttm_helper.c | 12 * This library provides helper functions for gem objects backed by 20 * @gem: GEM object 26 const struct drm_gem_object *gem) in drm_gem_ttm_print_info() argument 42 const struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem); in drm_gem_ttm_print_info() 56 * @gem: GEM object. 59 * Maps a GEM object with ttm_bo_vmap(). This function can be used as 65 int drm_gem_ttm_vmap(struct drm_gem_object *gem, in drm_gem_ttm_vmap() argument 68 struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem); in drm_gem_ttm_vmap() 76 * @gem: GEM object. 79 * Unmaps a GEM object with ttm_bo_vunmap(). This function can be used as [all …]
|
H A D | drm_gem_vram_helper.c | 29 * This library provides &struct drm_gem_vram_object (GEM VRAM), a GEM 34 * manager for simple framebuffer devices with dedicated video memory. GEM 38 * With the GEM interface userspace applications create, manage and destroy 39 * graphics buffers, such as an on-screen framebuffer. GEM does not provide 46 * left in VRAM, inactive GEM objects can be moved to system memory. 83 * interfaces for GEM buffer management and initializes file operations to 84 * allow for accessing created GEM buffers. With this setup, the DRM driver 85 * manages an area of video RAM with VRAM MM and provides GEM VRAM objects 117 * up; only release the GEM object. in drm_gem_vram_cleanup() 172 * drm_gem_vram_create() - Creates a VRAM-backed GEM object [all …]
|
H A D | drm_exec.c | 11 * multiple GEM objects while preparing hardware operations (e.g. command 14 * If a contention is detected while locking a GEM object the cleanup procedure 15 * unlocks all previously locked GEM objects and locks the contended one first 19 * dma_resv object inside the GEM object. 191 * drm_exec_lock_obj - lock a GEM object for use 193 * @obj: the GEM object to lock 195 * Lock a GEM object for use and grab a reference to it. 246 * drm_exec_unlock_obj - unlock a GEM object in this exec context 248 * @obj: the GEM object to unlock 250 * Unlock the GEM object and remove it from the collection of locked objects. [all …]
|
H A D | drm_gem_dma_helper.c | 3 * drm gem DMA helper functions 29 * The DRM GEM/DMA helpers are a means to provide buffer objects that are 43 * For GEM callback helpers in struct &drm_gem_object functions, see likewise 58 * __drm_gem_dma_create - Create a GEM DMA object without allocating memory 63 * This function creates and initializes a GEM DMA object of the given size, 121 * This function creates a DMA GEM object and allocates memory as backing store. 173 * return a GEM handle to it 177 * @handle: return location for the GEM handle 179 * This function creates a DMA GEM object, allocating a chunk of memory as 180 * backing store. The GEM object is then added to the list of object associated [all …]
|
H A D | drm_prime.c | 48 * Similar to GEM global names, PRIME file descriptors are also used to share 51 * between applications, they can't be guessed like the globally unique GEM 59 * Reference Counting for GEM Drivers 65 * and stores the exporting GEM object in the &dma_buf.priv field. This 68 * GEM-based drivers, the &dma_buf should be exported using 72 * importing GEM object -> dma-buf -> exported GEM bo. A further complication 75 * is required to allow userspace to detect duplicated imports, since some GEM 82 * it will get a fd->handle request for a GEM object that it created. Drivers 84 * dma-buf private. For GEM based drivers this is handled in 231 * drm_gem_dmabuf_export - &dma_buf export implementation for GEM [all …]
|
H A D | drm_gem_shmem_helper.c | 31 * This library provides helpers for GEM objects backed by shmem buffers 34 * Functions that operate on the GEM object receive struct &drm_gem_shmem_object. 35 * For GEM callback helpers in struct &drm_gem_object functions, see likewise 119 * This function creates a shmem GEM object. 132 * drm_gem_shmem_free - Free resources associated with a shmem GEM object 133 * @shmem: shmem GEM object to free 135 * This function cleans up the GEM object state and frees the memory used to 202 * drm_gem_shmem_put_pages - Decrease use count on the backing pages for a shmem GEM object 203 * @shmem: shmem GEM object 250 * drm_gem_shmem_pin - Pin backing pages for a shmem GEM object [all …]
|
H A D | drm_gem.c | 90 * drm_gem_init - Initialize the GEM device fields 117 * drm_gem_object_init - initialize an allocated shmem-backed GEM object 122 * Initialize an already allocated GEM object of the specified size with 143 * drm_gem_private_object_init - initialize an allocated private GEM object 148 * Initialize an already allocated GEM object of the specified size with 149 * no GEM provided backing store. Instead the caller is responsible for 179 * Uninitialize an already allocated GEM object when it initialized failed 191 * @obj: GEM object to clean up. 272 * Removes the GEM handle from the @filp lookup table which has been added with 274 * resources like GEM names. [all …]
|
H A D | drm_fb_dma_helper.c | 38 * drm_fb_dma_get_gem_obj() - Get DMA GEM object for framebuffer 42 * Return the DMA GEM object for given framebuffer. 49 struct drm_gem_object *gem; in drm_fb_dma_get_gem_obj() local 51 gem = drm_gem_fb_get_obj(fb, plane); in drm_fb_dma_get_gem_obj() 52 if (!gem) in drm_fb_dma_get_gem_obj() 55 return to_drm_gem_dma_obj(gem); in drm_fb_dma_get_gem_obj() 66 * Return the DMA GEM address for given framebuffer. 109 * drm_fb_dma_sync_non_coherent - Sync GEM object to non-coherent backing 116 * DMA GEM objects backed by non-coherent memory. Calling this function
|
/openbmc/linux/drivers/gpu/drm/tegra/ |
H A D | gem.c | 3 * NVIDIA Tegra DRM GEM helper functions 8 * Based on the GEM/CMA helpers 23 #include "gem.h" 56 drm_gem_object_put(&obj->gem); in tegra_bo_put() 63 struct drm_gem_object *gem = &obj->gem; in tegra_bo_pin() local 79 if (gem->import_attach) { in tegra_bo_pin() 80 struct dma_buf *buf = gem->import_attach->dmabuf; in tegra_bo_pin() 97 map->size = gem->size; in tegra_bo_pin() 117 err = sg_alloc_table_from_pages(map->sgt, obj->pages, obj->num_pages, 0, gem->size, in tegra_bo_pin() 127 err = dma_get_sgtable(dev, map->sgt, obj->vaddr, obj->iova, gem->size); in tegra_bo_pin() [all …]
|
H A D | gem.h | 3 * Tegra host1x GEM implementation 36 struct drm_gem_object gem; member 52 static inline struct tegra_bo *to_tegra_bo(struct drm_gem_object *gem) in to_tegra_bo() argument 54 return container_of(gem, struct tegra_bo, gem); in to_tegra_bo() 69 void tegra_bo_free_object(struct drm_gem_object *gem); 75 int __tegra_gem_mmap(struct drm_gem_object *gem, struct vm_area_struct *vma); 78 struct dma_buf *tegra_gem_prime_export(struct drm_gem_object *gem,
|
H A D | fb.c | 18 #include "gem.h" 120 fb->obj[i] = &planes[i]->gem; in tegra_fb_alloc() 139 struct drm_gem_object *gem; in tegra_fb_create() local 149 gem = drm_gem_object_lookup(file, cmd->handles[i]); in tegra_fb_create() 150 if (!gem) { in tegra_fb_create() 160 if (gem->size < size) { in tegra_fb_create() 162 drm_gem_object_put(gem); in tegra_fb_create() 166 planes[i] = to_tegra_bo(gem); in tegra_fb_create() 179 drm_gem_object_put(&planes[i]->gem); in tegra_fb_create()
|
/openbmc/linux/Documentation/gpu/ |
H A D | drm-mm.rst | 12 (TTM) and Graphics Execution Manager (GEM). TTM was the first DRM memory 20 GEM started as an Intel-sponsored project in reaction to TTM's 22 providing a solution to every graphics memory-related problems, GEM 24 share it. GEM has simpler initialization and execution requirements than 79 The Graphics Execution Manager (GEM) 82 The GEM design approach has resulted in a memory manager that doesn't 84 userspace or kernel API. GEM exposes a set of standard memory-related 89 The GEM userspace API is described in the `GEM - the Graphics Execution 91 slightly outdated, the document provides a good overview of the GEM API 93 as part of the common GEM API, are currently implemented using [all …]
|
/openbmc/linux/Documentation/devicetree/bindings/net/ |
H A D | cdns,macb.yaml | 7 title: Cadence MACB/GEM Ethernet controller 23 - cdns,zynq-gem # Xilinx Zynq-7xxx SoC 24 - cdns,zynqmp-gem # Xilinx Zynq Ultrascale+ MPSoC 25 - const: cdns,gem # Generic 30 - xlnx,versal-gem # Xilinx Versal 31 - xlnx,zynq-gem # Xilinx Zynq-7xxx SoC 32 - xlnx,zynqmp-gem # Xilinx Zynq Ultrascale+ MPSoC 33 - const: cdns,gem # Generic 50 - atmel,sama5d29-gem # GEM XL IP (10/100) on Atmel sama5d29 SoCs 51 - atmel,sama5d2-gem # GEM IP (10/100) on Atmel sama5d2 SoCs [all …]
|
/openbmc/linux/drivers/gpu/drm/i915/ |
H A D | Makefile | 152 # GEM (Graphics Execution Management) code 153 gem-y += \ 154 gem/i915_gem_busy.o \ 155 gem/i915_gem_clflush.o \ 156 gem/i915_gem_context.o \ 157 gem/i915_gem_create.o \ 158 gem/i915_gem_dmabuf.o \ 159 gem/i915_gem_domain.o \ 160 gem/i915_gem_execbuffer.o \ 161 gem/i915_gem_internal.o \ [all …]
|
/openbmc/linux/include/drm/ |
H A D | drm_gem_shmem_helper.h | 21 * struct drm_gem_shmem_object - GEM object backed by shmem 25 * @base: Base GEM object 131 * GEM object functions 135 * drm_gem_shmem_object_free - GEM object function for drm_gem_shmem_free() 136 * @obj: GEM object to free 152 * @obj: GEM object 166 * drm_gem_shmem_object_pin - GEM object function for drm_gem_shmem_pin() 167 * @obj: GEM object 180 * drm_gem_shmem_object_unpin - GEM object function for drm_gem_shmem_unpin() 181 * @obj: GEM object [all …]
|
H A D | drm_gem_dma_helper.h | 12 * struct drm_gem_dma_object - GEM object backed by DMA memory allocations 13 * @base: base GEM object 19 * @map_noncoherent: if true, the GEM object is backed by non-coherent memory 26 /* For objects with DMA memory allocated by GEM DMA */ 48 * GEM object functions 52 * drm_gem_dma_object_free - GEM object function for drm_gem_dma_free() 53 * @obj: GEM object to free 69 * @obj: GEM object 83 * drm_gem_dma_object_get_sg_table - GEM object function for drm_gem_dma_get_sg_table() 84 * @obj: GEM object [all …]
|
H A D | drm_gem.h | 5 * GEM Graphics Execution Manager Driver Interfaces 58 * become puregeable until it becomes idle. The status gem object func does 67 * struct drm_gem_object_funcs - GEM object functions 82 * Called upon GEM handle creation. 91 * Called upon GEM handle release. 178 * Handle mmap() of the gem object, setup vma accordingly. 191 * Evicts gem object out from memory. Used by the drm_gem_object_evict() 224 * A helper for tracking GEM objects in a given state, to aid in 234 * Lock protecting movement of GEM objects between LRUs. All 243 * The total number of backing pages of the GEM objects in [all …]
|
H A D | drm_exec.h | 44 * @contended: contended GEM object we backed off for 49 * @prelocked: already locked GEM object due to contention 72 * @obj: the current GEM object 74 * Iterate over all the locked GEM objects inside the drm_exec object. 84 * @obj: the current GEM object 86 * Iterate over all the locked GEM objects inside the drm_exec object in 95 * drm_exec_until_all_locked - loop until all GEM objects are locked 98 * Core functionality of the drm_exec object. Loops until all GEM objects are 100 * guaranteed that no GEM object is locked. 118 * clean up and re-start the loop to prepare all GEM objects. [all …]
|
H A D | drm_gem_vram_helper.h | 33 * struct drm_gem_vram_object - GEM object backed by VRAM 40 * The type struct drm_gem_vram_object represents a GEM object that is 45 * GEM VRAM objects perform reference counting for pin and mapping 73 * Returns: The containing GEM VRAM object 83 * &struct drm_gem_vram_object for field gem. 84 * @gem: the GEM object 85 * Returns: The containing GEM VRAM object 88 struct drm_gem_object *gem) in drm_gem_vram_of_gem() argument 90 return container_of(gem, struct drm_gem_vram_object, bo.base); in drm_gem_vram_of_gem() 132 * Drivers may use GEM BOs as VRAM helpers for the framebuffer memory. This [all …]
|
/openbmc/u-boot/drivers/net/pfe_eth/ |
H A D | pfe_eth.c | 86 struct gemac_s *gem = priv->gem; in pfe_eth_write_hwaddr() local 91 gem->gemac_base + EMAC_PHY_ADDR_LOW); in pfe_eth_write_hwaddr() 92 writel((mac[4] << 24) + (mac[5] << 16) + 0x8808, gem->gemac_base + in pfe_eth_write_hwaddr() 107 pfe_gemac_disable(priv->gem->gemac_base); in pfe_eth_stop() 109 gpi_disable(priv->gem->egpi_base); in pfe_eth_stop() 115 struct gemac_s *gem = priv->gem; in pfe_eth_start() local 121 writel(EMAC_TFWR, gem->gemac_base + EMAC_TFWR_STR_FWD); in pfe_eth_start() 122 writel(EMAC_RX_SECTION_FULL_32, gem->gemac_base + EMAC_RX_SECTIOM_FULL); in pfe_eth_start() 123 writel(EMAC_TRUNC_FL_16K, gem->gemac_base + EMAC_TRUNC_FL); in pfe_eth_start() 124 writel(EMAC_TX_SECTION_EMPTY_30, gem->gemac_base in pfe_eth_start() [all …]
|
/openbmc/linux/drivers/gpu/drm/exynos/ |
H A D | exynos_drm_gem.h | 21 * @base: a gem object. 22 * - a new handle to this gem object would be created 49 /* destroy a buffer with gem object */ 52 /* create a new buffer with gem object */ 59 * request gem object creation and buffer allocation as the size 66 /* get fake-offset of gem object that can be used with mmap. */ 71 * get exynos drm object from gem handle, this function could be used for 73 * with this function call, gem object reference count would be increased. 80 * gem object reference count would be decreased. 87 /* get buffer information to memory region allocated by gem. */ [all …]
|
/openbmc/linux/drivers/gpu/drm/nouveau/ |
H A D | nouveau_gem.c | 77 nouveau_gem_object_del(struct drm_gem_object *gem) in nouveau_gem_object_del() argument 79 struct nouveau_bo *nvbo = nouveau_gem_object(gem); in nouveau_gem_object_del() 90 if (gem->import_attach) in nouveau_gem_object_del() 91 drm_prime_gem_destroy(gem, nvbo->bo.sg); in nouveau_gem_object_del() 100 nouveau_gem_object_open(struct drm_gem_object *gem, struct drm_file *file_priv) in nouveau_gem_object_open() argument 103 struct nouveau_bo *nvbo = nouveau_gem_object(gem); in nouveau_gem_object_open() 185 nouveau_gem_object_close(struct drm_gem_object *gem, struct drm_file *file_priv) in nouveau_gem_object_close() argument 188 struct nouveau_bo *nvbo = nouveau_gem_object(gem); in nouveau_gem_object_close() 262 /* Initialize the embedded gem-object. We return a single gem-reference in nouveau_gem_new() 296 nouveau_gem_info(struct drm_file *file_priv, struct drm_gem_object *gem, in nouveau_gem_info() argument [all …]
|
/openbmc/linux/drivers/gpu/drm/mediatek/ |
H A D | mtk_drm_gem.h | 14 * @base: a gem object. 15 * - a new handle to this gem object would be created 18 * @kvaddr: kernel virtual address of gem buffer. 19 * @dma_addr: dma address of gem buffer. 20 * @dma_attrs: dma attributes of gem buffer. 37 void mtk_drm_gem_free_object(struct drm_gem_object *gem);
|
/openbmc/linux/drivers/gpu/drm/gma500/ |
H A D | gem.c | 3 * psb GEM interface 11 * accelerated operations on a GEM object) 21 #include "gem.h" 25 * PSB GEM object 165 /* GEM object */ in psb_gem_create() 216 pobj = psb_gem_create(dev, size, "gem", false, PAGE_SIZE); in psb_gem_dumb_create() 239 * psb_gem_fault - pagefault handler for GEM objects 242 * Invoked when a fault occurs on an mmap of a GEM managed area. GEM 250 * The VMA was set up by GEM. In doing so it also ensured that the 251 * vma->vm_private_data points to the GEM object that is backing this [all …]
|
/openbmc/linux/include/uapi/drm/ |
H A D | tegra_drm.h | 19 * struct drm_tegra_gem_create - parameters for the GEM object creation IOCTL 32 * A bitmask of flags that influence the creation of GEM objects: 45 * The handle of the created GEM object. Set by the kernel upon 52 * struct drm_tegra_gem_mmap - parameters for the GEM mmap IOCTL 58 * Handle of the GEM object to obtain an mmap offset for. 72 * The mmap offset for the given GEM object. Set by the kernel upon 276 * Handle to a GEM object containing the command buffer. 283 * Offset, in bytes, into the GEM object identified by @handle at 304 * struct drm_tegra_reloc - GEM object relocation structure 311 * Handle to the GEM object containing the command buffer for [all …]
|