/* 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 *); struct nvfw_ls_desc_v2 { u32 descriptor_size; u32 image_size; u32 tools_version; u32 app_version; char date[64]; u32 secure_bootloader; 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; u32 nb_imem_overlays; u32 nb_dmem_overlays; struct { u32 start; u32 size; } load_ovl[64]; }; const struct nvfw_ls_desc_v2 *nvfw_ls_desc_v2(struct nvkm_subdev *, const void *); struct nvfw_ls_hsbl_bin_hdr { u32 bin_magic; u32 bin_ver; u32 bin_size; u32 header_offset; }; const struct nvfw_ls_hsbl_bin_hdr *nvfw_ls_hsbl_bin_hdr(struct nvkm_subdev *, const void *); struct nvfw_ls_hsbl_hdr { u32 sig_prod_offset; u32 sig_prod_size; u32 patch_loc; u32 patch_sig; u32 meta_data_offset; u32 meta_data_size; u32 num_sig; }; const struct nvfw_ls_hsbl_hdr *nvfw_ls_hsbl_hdr(struct nvkm_subdev *, const void *); #endif