105 lines
2.1 KiB
C
105 lines
2.1 KiB
C
|
/* 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
|