diff options
author | Wenwen Wang <wenwen@cs.uga.edu> | 2019-08-14 00:14:49 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-08-15 12:37:37 -0700 |
commit | 6f967f8b1be7001b31c46429f2ee7d275af2190f (patch) | |
tree | e573bee34bd1356a135befc746a282216caf7041 | |
parent | 0b24a441765527c797ef3bdb2a539547e0df9a7e (diff) | |
download | lwn-6f967f8b1be7001b31c46429f2ee7d275af2190f.tar.gz lwn-6f967f8b1be7001b31c46429f2ee7d275af2190f.zip |
liquidio: add cleanup in octeon_setup_iq()
If oct->fn_list.enable_io_queues() fails, no cleanup is executed, leading
to memory/resource leaks. To fix this issue, invoke
octeon_delete_instr_queue() before returning from the function.
Signed-off-by: Wenwen Wang <wenwen@cs.uga.edu>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/cavium/liquidio/request_manager.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/net/ethernet/cavium/liquidio/request_manager.c b/drivers/net/ethernet/cavium/liquidio/request_manager.c index 032224178b64..6dd65f9b347c 100644 --- a/drivers/net/ethernet/cavium/liquidio/request_manager.c +++ b/drivers/net/ethernet/cavium/liquidio/request_manager.c @@ -237,8 +237,10 @@ int octeon_setup_iq(struct octeon_device *oct, } oct->num_iqs++; - if (oct->fn_list.enable_io_queues(oct)) + if (oct->fn_list.enable_io_queues(oct)) { + octeon_delete_instr_queue(oct, iq_no); return 1; + } return 0; } |