mirror of
https://github.com/lkl/linux.git
synced 2025-12-19 16:13:19 +09:00
treewide: Replace zero-length arrays with flexible-array members
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>
This commit is contained in:
@@ -132,7 +132,7 @@ struct i3c_ccc_dev_desc {
|
||||
struct i3c_ccc_defslvs {
|
||||
u8 count;
|
||||
struct i3c_ccc_dev_desc master;
|
||||
struct i3c_ccc_dev_desc slaves[0];
|
||||
struct i3c_ccc_dev_desc slaves[];
|
||||
} __packed;
|
||||
|
||||
/**
|
||||
@@ -240,7 +240,7 @@ struct i3c_ccc_bridged_slave_desc {
|
||||
*/
|
||||
struct i3c_ccc_setbrgtgt {
|
||||
u8 count;
|
||||
struct i3c_ccc_bridged_slave_desc bslaves[0];
|
||||
struct i3c_ccc_bridged_slave_desc bslaves[];
|
||||
} __packed;
|
||||
|
||||
/**
|
||||
@@ -318,7 +318,7 @@ enum i3c_ccc_setxtime_subcmd {
|
||||
*/
|
||||
struct i3c_ccc_setxtime {
|
||||
u8 subcmd;
|
||||
u8 data[0];
|
||||
u8 data[];
|
||||
} __packed;
|
||||
|
||||
#define I3C_CCC_GETXTIME_SYNC_MODE BIT(0)
|
||||
|
||||
Reference in New Issue
Block a user