Commit a68292eb authored by Erick Archer's avatar Erick Archer Committed by Leon Romanovsky

net: mana: Avoid open coded arithmetic

This is an effort to get rid of all multiplications from allocation
functions in order to prevent integer overflows [1][2].

As the "req" variable is a pointer to "struct mana_cfg_rx_steer_req_v2"
and this structure ends in a flexible array:

struct mana_cfg_rx_steer_req_v2 {
        [...]
        mana_handle_t indir_tab[] __counted_by(num_indir_entries);
};

the preferred way in the kernel is to use the struct_size() helper to
do the arithmetic instead of the calculation "size + size * count" in
the kzalloc() function.

Moreover, use the "offsetof" helper to get the indirect table offset
instead of the "sizeof" operator and avoid the open-coded arithmetic in
pointers using the new flex member. This new structure member also allow
us to remove the "req_indir_tab" variable since it is no longer needed.

Now, it is also possible to use the "flex_array_size" helper to compute
the size of these trailing elements in the "memcpy" function.

This way, the code is more readable and safer.

This code was detected with the help of Coccinelle, and audited and
modified manually.

Link: https://www.kernel.org/doc/html/latest/process/deprecated.html#open-coded-arithmetic-in-allocator-arguments [1]
Link: https://github.com/KSPP/linux/issues/160 [2]
Signed-off-by: default avatarErick Archer <erick.archer@outlook.com>
Link: https://lore.kernel.org/r/AS8PR02MB7237A21355C86EC0DCC0D83B8B022@AS8PR02MB7237.eurprd02.prod.outlook.comReviewed-by: default avatarJustin Stitt <justinstitt@google.com>
Signed-off-by: default avatarLeon Romanovsky <leon@kernel.org>
parent 29b8e13a
...@@ -1058,11 +1058,10 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc, ...@@ -1058,11 +1058,10 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc,
struct mana_cfg_rx_steer_req_v2 *req; struct mana_cfg_rx_steer_req_v2 *req;
struct mana_cfg_rx_steer_resp resp = {}; struct mana_cfg_rx_steer_resp resp = {};
struct net_device *ndev = apc->ndev; struct net_device *ndev = apc->ndev;
mana_handle_t *req_indir_tab;
u32 req_buf_size; u32 req_buf_size;
int err; int err;
req_buf_size = sizeof(*req) + sizeof(mana_handle_t) * num_entries; req_buf_size = struct_size(req, indir_tab, num_entries);
req = kzalloc(req_buf_size, GFP_KERNEL); req = kzalloc(req_buf_size, GFP_KERNEL);
if (!req) if (!req)
return -ENOMEM; return -ENOMEM;
...@@ -1074,7 +1073,8 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc, ...@@ -1074,7 +1073,8 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc,
req->vport = apc->port_handle; req->vport = apc->port_handle;
req->num_indir_entries = num_entries; req->num_indir_entries = num_entries;
req->indir_tab_offset = sizeof(*req); req->indir_tab_offset = offsetof(struct mana_cfg_rx_steer_req_v2,
indir_tab);
req->rx_enable = rx; req->rx_enable = rx;
req->rss_enable = apc->rss_state; req->rss_enable = apc->rss_state;
req->update_default_rxobj = update_default_rxobj; req->update_default_rxobj = update_default_rxobj;
...@@ -1086,11 +1086,9 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc, ...@@ -1086,11 +1086,9 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc,
if (update_key) if (update_key)
memcpy(&req->hashkey, apc->hashkey, MANA_HASH_KEY_SIZE); memcpy(&req->hashkey, apc->hashkey, MANA_HASH_KEY_SIZE);
if (update_tab) { if (update_tab)
req_indir_tab = (mana_handle_t *)(req + 1); memcpy(req->indir_tab, apc->rxobj_table,
memcpy(req_indir_tab, apc->rxobj_table, flex_array_size(req, indir_tab, req->num_indir_entries));
req->num_indir_entries * sizeof(mana_handle_t));
}
err = mana_send_request(apc->ac, req, req_buf_size, &resp, err = mana_send_request(apc->ac, req, req_buf_size, &resp,
sizeof(resp)); sizeof(resp));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment