diff options
author | Arnd Bergmann <arnd@arndb.de> | 2017-01-18 15:52:52 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-01-20 11:44:42 -0500 |
commit | 0629a330cf55454962168dd3ee46fad53a39323e (patch) | |
tree | c80da96ac3719995382cbef443f7abb02eb6a0c0 /drivers/net/ethernet/broadcom/bcm63xx_enet.c | |
parent | 91e744653cb80554f3fdfd1d31c5ddf7b6169f37 (diff) | |
download | linux-0629a330cf55454962168dd3ee46fad53a39323e.tar.gz linux-0629a330cf55454962168dd3ee46fad53a39323e.tar.bz2 linux-0629a330cf55454962168dd3ee46fad53a39323e.zip |
qed: avoid possible stack overflow in qed_ll2_acquire_connection
struct qed_ll2_info is rather large, so putting it on the stack
can cause an overflow, as this warning tries to tell us:
drivers/net/ethernet/qlogic/qed/qed_ll2.c: In function 'qed_ll2_start':
drivers/net/ethernet/qlogic/qed/qed_ll2.c:2159:1: error: the frame size of 1056 bytes is larger than 1024 bytes [-Werror=frame-larger-than=]
qed_ll2_start_ooo() already uses a dynamic allocation for the structure
to work around that problem, and we could do the same in qed_ll2_start()
as well as qed_roce_ll2_start(), but since the structure is only
used to pass a couple of initialization values here, it seems nicer
to replace it with a different structure.
Lacking any idea for better naming, I'm adding 'struct qed_ll2_conn',
which now contains all the initialization data, and this now simply
gets copied into struct qed_ll2_info rather than assigning all members
one by one.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: Yuval Mintz <Yuval.Mintz@cavium.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/broadcom/bcm63xx_enet.c')
0 files changed, 0 insertions, 0 deletions