[PATCH] memcontrol: use flexible-array member

From: wenhuizhang
Date: Tue May 18 2021 - 01:20:50 EST



Change depracated zero-length-and-one-element-arrays into flexible
array member.
Zero-length and one-element arrays detected by Lukas's CodeChecker.
Zero/one element arrays causes undefined behaviours if sizeof() used.

https://www.kernel.org/doc/html/latest/processd/deprecated.html


Signed-off-by: wenhuizhang<wenhui@xxxxxxxxxxxxxx>
---
include/linux/memcontrol.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h
index 0ce97eff79e2..f879efb1bc6e 100644
--- a/include/linux/memcontrol.h
+++ b/include/linux/memcontrol.h
@@ -190,7 +190,7 @@ enum memcg_kmem_state {

#if defined(CONFIG_SMP)
struct memcg_padding {
- char x[0];
+ char x[];
} ____cacheline_internodealigned_in_smp;
#define MEMCG_PADDING(name) struct memcg_padding name;
#else
@@ -349,7 +349,7 @@ struct mem_cgroup {
struct deferred_split deferred_split_queue;
#endif

- struct mem_cgroup_per_node *nodeinfo[0];
+ struct mem_cgroup_per_node *nodeinfo[];
/* WARNING: nodeinfo must be the last member here */
};

--
2.17.1