Lines Matching +full:firmware +full:- +full:specific

1 /* SPDX-License-Identifier: GPL-2.0-only OR MIT */
27 * struct pvr_fw_object - container for firmware memory allocations
37 * @fw_mm_node: Node representing mapping in FW address space. @pvr_obj->lock must
43 * @fw_addr_offset: Virtual address offset of firmware mapping. Only
58 /** @node: Node for firmware object list. */
63 * struct pvr_fw_defs - FW processor function table and static definitions
69 * FW processor specific initialisation.
72 * This function must call pvr_fw_heap_calculate() to initialise the firmware heap for this
86 * FW processor specific finalisation.
96 * Load and process firmware image.
98 * @fw: Pointer to firmware image.
99 * @fw_code_ptr: Pointer to firmware code section.
100 * @fw_data_ptr: Pointer to firmware data section.
101 * @fw_core_code_ptr: Pointer to firmware core code section. May be %NULL.
102 * @fw_core_data_ptr: Pointer to firmware core data section. May be %NULL.
144 * Called to get address of object in firmware address space, with offset.
151 * * Address in firmware address space.
172 * Called to check if firmware fixed data must be loaded at the address given by the
173 * firmware layout table.
178 * * %true if firmware fixed data must be loaded at the address given by the firmware
214 * struct pvr_fw_mem - FW memory allocations
217 /** @code_obj: Object representing firmware code. */
220 /** @data_obj: Object representing firmware data. */
224 * @core_code_obj: Object representing firmware core code. May be
225 * %NULL if firmware does not contain this section.
230 * @core_data_obj: Object representing firmware core data. May be
231 * %NULL if firmware does not contain this section.
235 /** @code: Driver-side copy of firmware code. */
238 /** @data: Driver-side copy of firmware data. */
242 * @core_code: Driver-side copy of firmware core code. May be %NULL if firmware does not
248 * @core_data: Driver-side copy of firmware core data. May be %NULL if firmware does not
253 /** @code_alloc_size: Allocation size of firmware code section. */
256 /** @data_alloc_size: Allocation size of firmware data section. */
259 /** @core_code_alloc_size: Allocation size of firmware core code section. */
262 /** @core_data_alloc_size: Allocation size of firmware core data section. */
303 /** @firmware: Handle to the firmware loaded into the device. */
304 const struct firmware *firmware; member
306 /** @header: Pointer to firmware header. */
309 /** @layout_entries: Pointer to firmware layout. */
312 /** @mem: Structure containing objects representing firmware memory allocations. */
315 /** @booted: %true if the firmware has been booted, %false otherwise. */
327 /** @processor_data: Pointer to data specific to FW processor. */
329 /** @mips_data: Pointer to MIPS-specific data. */
333 /** @fw_heap_info: Firmware heap information. */
335 /** @gpu_addr: Base address of firmware heap in GPU address space. */
357 /** @fw_mm: Firmware address space allocator. */
390 /** @fw_trace: Device firmware trace buffer state. */
404 pvr_cr_read32((pvr_dev), (pvr_dev)->fw_dev.defs->irq.name ## _reg)
407 pvr_cr_write32((pvr_dev), (pvr_dev)->fw_dev.defs->irq.name ## _reg, value)
410 (pvr_fw_irq_read_reg(pvr_dev, status) & (pvr_dev)->fw_dev.defs->irq.event_mask)
413 pvr_fw_irq_write_reg(pvr_dev, clear, (pvr_dev)->fw_dev.defs->irq.clear_mask)
416 pvr_fw_irq_write_reg(pvr_dev, enable, (pvr_dev)->fw_dev.defs->irq.event_mask)
465 return pvr_gem_object_vmap(fw_obj->gem); in pvr_fw_object_vmap()
471 pvr_gem_object_vunmap(fw_obj->gem); in pvr_fw_object_vunmap()
484 * pvr_fw_object_get_dma_addr() - Get DMA address for given offset in firmware
492 * * -%EINVAL if object is not currently backed, or if @offset is out of valid
498 return pvr_gem_get_dma_addr(fw_obj->gem, offset, dma_addr_out); in pvr_fw_object_get_dma_addr()