mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-06 13:16:22 +00:00
staging: vt6655: fix some erroneous memory clean-up loops
In some initialization functions of this driver, memory is allocated with 'i' acting as an index variable and increasing from 0. The commit in "Fixes" introduces some clean-up codes in case of allocation failure, which free memory in reverse order with 'i' decreasing to 0. However, there are some problems: - The case i=0 is left out. Thus memory is leaked. - In case memory allocation fails right from the start, the memory freeing loops will start with i=-1 and invalid memory locations will be accessed. One of these loops has been fixed in commitc8ff915358
("staging: vt6655: fix potential memory leak"). Fix the remaining erroneous loops. Link: https://lore.kernel.org/linux-staging/Yx9H1zSpxmNqx6Xc@kadam/ Fixes:5341ee0adb
("staging: vt6655: check for memory allocation failures") Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Tested-by: Philipp Hortmann <philipp.g.hortmann@gmail.com> Signed-off-by: Nam Cao <namcaov@gmail.com> Link: https://lore.kernel.org/r/20220912170429.29852-1-namcaov@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
2d3cdad6ea
commit
2a2db520e3
@ -631,7 +631,7 @@ static int device_init_rd0_ring(struct vnt_private *priv)
|
||||
kfree(desc->rd_info);
|
||||
|
||||
err_free_desc:
|
||||
while (--i) {
|
||||
while (i--) {
|
||||
desc = &priv->aRD0Ring[i];
|
||||
device_free_rx_buf(priv, desc);
|
||||
kfree(desc->rd_info);
|
||||
@ -677,7 +677,7 @@ static int device_init_rd1_ring(struct vnt_private *priv)
|
||||
kfree(desc->rd_info);
|
||||
|
||||
err_free_desc:
|
||||
while (--i) {
|
||||
while (i--) {
|
||||
desc = &priv->aRD1Ring[i];
|
||||
device_free_rx_buf(priv, desc);
|
||||
kfree(desc->rd_info);
|
||||
@ -782,7 +782,7 @@ static int device_init_td1_ring(struct vnt_private *priv)
|
||||
return 0;
|
||||
|
||||
err_free_desc:
|
||||
while (--i) {
|
||||
while (i--) {
|
||||
desc = &priv->apTD1Rings[i];
|
||||
kfree(desc->td_info);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user