| /* SPDX-License-Identifier: MIT */ |
| #ifndef __NVFW_LS_H__ |
| #define __NVFW_LS_H__ |
| #include <core/os.h> |
| struct nvkm_subdev; |
| |
| struct nvfw_ls_desc_head { |
| u32 descriptor_size; |
| u32 image_size; |
| u32 tools_version; |
| u32 app_version; |
| char date[64]; |
| u32 bootloader_start_offset; |
| u32 bootloader_size; |
| u32 bootloader_imem_offset; |
| u32 bootloader_entry_point; |
| u32 app_start_offset; |
| u32 app_size; |
| u32 app_imem_offset; |
| u32 app_imem_entry; |
| u32 app_dmem_offset; |
| u32 app_resident_code_offset; |
| u32 app_resident_code_size; |
| u32 app_resident_data_offset; |
| u32 app_resident_data_size; |
| }; |
| |
| struct nvfw_ls_desc { |
| struct nvfw_ls_desc_head head; |
| u32 nb_overlays; |
| struct { |
| u32 start; |
| u32 size; |
| } load_ovl[64]; |
| u32 compressed; |
| }; |
| |
| const struct nvfw_ls_desc *nvfw_ls_desc(struct nvkm_subdev *, const void *); |
| |
| struct nvfw_ls_desc_v1 { |
| struct nvfw_ls_desc_head head; |
| u32 nb_imem_overlays; |
| u32 nb_dmem_overlays; |
| struct { |
| u32 start; |
| u32 size; |
| } load_ovl[64]; |
| u32 compressed; |
| }; |
| |
| const struct nvfw_ls_desc_v1 * |
| nvfw_ls_desc_v1(struct nvkm_subdev *, const void *); |
| #endif |