diff options
author | Gustavo A. R. Silva <gustavo@embeddedor.com> | 2019-08-30 13:24:45 -0500 |
---|---|---|
committer | Mike Snitzer <snitzer@redhat.com> | 2019-09-04 09:39:22 -0400 |
commit | fb16c799b8dca78b847ab183e8aa70e34cbf21bc (patch) | |
tree | c1e0780ebeece4281e4a003801044f2b3b3ae163 /drivers/md/dm-stats.c | |
parent | b1d1e29639dff5290945e45262e172aaa9e89cbe (diff) | |
download | lwn-fb16c799b8dca78b847ab183e8aa70e34cbf21bc.tar.gz lwn-fb16c799b8dca78b847ab183e8aa70e34cbf21bc.zip |
dm stats: use struct_size() helper
One of the more common cases of allocation size calculations is finding
the size of a structure that has a zero-sized array at the end, along
with memory for some number of elements for that array. For example:
struct dm_stat {
...
struct dm_stat_shared stat_shared[0];
};
Make use of the struct_size() helper instead of an open-coded version
in order to avoid any potential type mistakes.
So, replace the following form:
sizeof(struct dm_stat) + (size_t)n_entries * sizeof(struct dm_stat_shared)
with:
struct_size(s, stat_shared, n_entries)
This code was detected with the help of Coccinelle.
Signed-off-by: Gustavo A. R. Silva <gustavo@embeddedor.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Diffstat (limited to 'drivers/md/dm-stats.c')
-rw-r--r-- | drivers/md/dm-stats.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/md/dm-stats.c b/drivers/md/dm-stats.c index 45b92a3d9d8e..71417048256a 100644 --- a/drivers/md/dm-stats.c +++ b/drivers/md/dm-stats.c @@ -262,7 +262,7 @@ static int dm_stats_create(struct dm_stats *stats, sector_t start, sector_t end, if (n_entries != (size_t)n_entries || !(size_t)(n_entries + 1)) return -EOVERFLOW; - shared_alloc_size = sizeof(struct dm_stat) + (size_t)n_entries * sizeof(struct dm_stat_shared); + shared_alloc_size = struct_size(s, stat_shared, n_entries); if ((shared_alloc_size - sizeof(struct dm_stat)) / sizeof(struct dm_stat_shared) != n_entries) return -EOVERFLOW; |