There is a regular need in the kernel to provide a way to declare having a dynamically sized set of trailing elements in a structure. Kernel code should always use “flexible array members”[1] for these cases. The older style of one-element or zero-length arrays should no longer be used[2]. This code was transformed with the help of Coccinelle: (next-20220214$ spatch --jobs $(getconf _NPROCESSORS_ONLN) --sp-file script.cocci --include-headers --dir . > output.patch) @@ identifier S, member, array; type T1, T2; @@ struct S { ... T1 member; T2 array[ - 0 ]; }; UAPI and wireless changes were intentionally excluded from this patch and will be sent out separately. [1] https://en.wikipedia.org/wiki/Flexible_array_member [2] https://www.kernel.org/doc/html/v5.16/process/deprecated.html#zero-length-and-one-element-arrays Link: https://github.com/KSPP/linux/issues/78 Reviewed-by: Kees Cook <keescook@chromium.org> Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
31 lines
620 B
C
31 lines
620 B
C
/* SPDX-License-Identifier: MIT */
|
|
#ifndef __NVFW_HS_H__
|
|
#define __NVFW_HS_H__
|
|
#include <core/os.h>
|
|
struct nvkm_subdev;
|
|
|
|
struct nvfw_hs_header {
|
|
u32 sig_dbg_offset;
|
|
u32 sig_dbg_size;
|
|
u32 sig_prod_offset;
|
|
u32 sig_prod_size;
|
|
u32 patch_loc;
|
|
u32 patch_sig;
|
|
u32 hdr_offset;
|
|
u32 hdr_size;
|
|
};
|
|
|
|
const struct nvfw_hs_header *nvfw_hs_header(struct nvkm_subdev *, const void *);
|
|
|
|
struct nvfw_hs_load_header {
|
|
u32 non_sec_code_off;
|
|
u32 non_sec_code_size;
|
|
u32 data_dma_base;
|
|
u32 data_size;
|
|
u32 num_apps;
|
|
u32 apps[];
|
|
};
|
|
|
|
const struct nvfw_hs_load_header *
|
|
nvfw_hs_load_header(struct nvkm_subdev *, const void *);
|
|
#endif
|