Linux Audio
Check our new training course
Embedded Linux Audio
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
/* 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