mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 10:43:43 +00:00
NTB/msi: Use struct_size() helper in devm_kzalloc()
Make use of the struct_size() helper instead of an open-coded version, in order to avoid any potential type mistakes or integer overflows that, in the worst scenario, could lead to heap overflows. Also, address the following sparse warnings: drivers/ntb/msi.c:46:23: warning: using sizeof on a flexible structure Link: https://github.com/KSPP/linux/issues/174 Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org> Reviewed-by: Kees Cook <keescook@chromium.org> Reviewed-by: Logan Gunthorpe <logang@deltatee.com> Signed-off-by: Jon Mason <jdmason@kudzu.us>
This commit is contained in:
parent
e783362eb5
commit
305325688f
@ -33,7 +33,6 @@ int ntb_msi_init(struct ntb_dev *ntb,
|
||||
{
|
||||
phys_addr_t mw_phys_addr;
|
||||
resource_size_t mw_size;
|
||||
size_t struct_size;
|
||||
int peer_widx;
|
||||
int peers;
|
||||
int ret;
|
||||
@ -43,9 +42,8 @@ int ntb_msi_init(struct ntb_dev *ntb,
|
||||
if (peers <= 0)
|
||||
return -EINVAL;
|
||||
|
||||
struct_size = sizeof(*ntb->msi) + sizeof(*ntb->msi->peer_mws) * peers;
|
||||
|
||||
ntb->msi = devm_kzalloc(&ntb->dev, struct_size, GFP_KERNEL);
|
||||
ntb->msi = devm_kzalloc(&ntb->dev, struct_size(ntb->msi, peer_mws, peers),
|
||||
GFP_KERNEL);
|
||||
if (!ntb->msi)
|
||||
return -ENOMEM;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user