/* $NetBSD: ls.h,v 1.2 2021/12/18 23:45:32 riastradh Exp $ */ /* SPDX-License-Identifier: MIT */ #ifndef __NVFW_LS_H__ #define __NVFW_LS_H__ #include 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