mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 14:50:19 +00:00
94dfc73e7c
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: (linux-5.19-rc2$ 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 ]; }; -fstrict-flex-arrays=3 is coming and we need to land these changes to prevent issues like these in the short future: ../fs/minix/dir.c:337:3: warning: 'strcpy' will always overflow; destination buffer has size 0, but the source string has length 2 (including NUL byte) [-Wfortify-source] strcpy(de3->name, "."); ^ Since these are all [0] to [] changes, the risk to UAPI is nearly zero. If this breaks anything, we can use a union with a new member name. [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 Build-tested-by: kernel test robot <lkp@intel.com> Link: https://lore.kernel.org/lkml/62b675ec.wKX6AOZ6cbE71vtF%25lkp@intel.com/ Acked-by: Dan Williams <dan.j.williams@intel.com> # For ndctl.h Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
67 lines
2.1 KiB
C
67 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
#ifndef __MIPS_UAPI_ASM_UCONTEXT_H
|
|
#define __MIPS_UAPI_ASM_UCONTEXT_H
|
|
|
|
/**
|
|
* struct extcontext - extended context header structure
|
|
* @magic: magic value identifying the type of extended context
|
|
* @size: the size in bytes of the enclosing structure
|
|
*
|
|
* Extended context structures provide context which does not fit within struct
|
|
* sigcontext. They are placed sequentially in memory at the end of struct
|
|
* ucontext and struct sigframe, with each extended context structure beginning
|
|
* with a header defined by this struct. The type of context represented is
|
|
* indicated by the magic field. Userland may check each extended context
|
|
* structure against magic values that it recognises. The size field allows any
|
|
* unrecognised context to be skipped, allowing for future expansion. The end
|
|
* of the extended context data is indicated by the magic value
|
|
* END_EXTCONTEXT_MAGIC.
|
|
*/
|
|
struct extcontext {
|
|
unsigned int magic;
|
|
unsigned int size;
|
|
};
|
|
|
|
/**
|
|
* struct msa_extcontext - MSA extended context structure
|
|
* @ext: the extended context header, with magic == MSA_EXTCONTEXT_MAGIC
|
|
* @wr: the most significant 64 bits of each MSA vector register
|
|
* @csr: the value of the MSA control & status register
|
|
*
|
|
* If MSA context is live for a task at the time a signal is delivered to it,
|
|
* this structure will hold the MSA context of the task as it was prior to the
|
|
* signal delivery.
|
|
*/
|
|
struct msa_extcontext {
|
|
struct extcontext ext;
|
|
#define MSA_EXTCONTEXT_MAGIC 0x784d5341 /* xMSA */
|
|
|
|
unsigned long long wr[32];
|
|
unsigned int csr;
|
|
};
|
|
|
|
#define END_EXTCONTEXT_MAGIC 0x78454e44 /* xEND */
|
|
|
|
/**
|
|
* struct ucontext - user context structure
|
|
* @uc_flags:
|
|
* @uc_link:
|
|
* @uc_stack:
|
|
* @uc_mcontext: holds basic processor state
|
|
* @uc_sigmask:
|
|
* @uc_extcontext: holds extended processor state
|
|
*/
|
|
struct ucontext {
|
|
/* Historic fields matching asm-generic */
|
|
unsigned long uc_flags;
|
|
struct ucontext *uc_link;
|
|
stack_t uc_stack;
|
|
struct sigcontext uc_mcontext;
|
|
sigset_t uc_sigmask;
|
|
|
|
/* Extended context structures may follow ucontext */
|
|
unsigned long long uc_extcontext[];
|
|
};
|
|
|
|
#endif /* __MIPS_UAPI_ASM_UCONTEXT_H */
|