staging: dgap: unwind on error in dgap_tty_init()
If the kzalloc() fails for channels, it need to handle that error. It should free channels which were already allocated. And also removes the call to dgap_tty_uninit() in dgap_firmware_load(). Signed-off-by: Daeseok Youn <daeseok.youn@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
e74c2ddcbb
commit
551a9d7394
@ -957,10 +957,8 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type)
|
|||||||
* Do tty device initialization.
|
* Do tty device initialization.
|
||||||
*/
|
*/
|
||||||
ret = dgap_tty_init(brd);
|
ret = dgap_tty_init(brd);
|
||||||
if (ret < 0) {
|
if (ret < 0)
|
||||||
dgap_tty_uninit(brd);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
|
||||||
|
|
||||||
ret = dgap_tty_register_ports(brd);
|
ret = dgap_tty_register_ports(brd);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -1330,6 +1328,7 @@ static int dgap_tty_init(struct board_t *brd)
|
|||||||
struct channel_t *ch;
|
struct channel_t *ch;
|
||||||
struct bs_t __iomem *bs;
|
struct bs_t __iomem *bs;
|
||||||
struct cm_t __iomem *cm;
|
struct cm_t __iomem *cm;
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (!brd)
|
if (!brd)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -1381,8 +1380,10 @@ static int dgap_tty_init(struct board_t *brd)
|
|||||||
for (i = 0; i < brd->nasync; i++) {
|
for (i = 0; i < brd->nasync; i++) {
|
||||||
brd->channels[i] =
|
brd->channels[i] =
|
||||||
kzalloc(sizeof(struct channel_t), GFP_KERNEL);
|
kzalloc(sizeof(struct channel_t), GFP_KERNEL);
|
||||||
if (!brd->channels[i])
|
if (!brd->channels[i]) {
|
||||||
return -ENOMEM;
|
ret = -ENOMEM;
|
||||||
|
goto free_chan;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ch = brd->channels[0];
|
ch = brd->channels[0];
|
||||||
@ -1478,6 +1479,13 @@ static int dgap_tty_init(struct board_t *brd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
free_chan:
|
||||||
|
while (--i >= 0) {
|
||||||
|
kfree(brd->channels[i]);
|
||||||
|
brd->channels[i] = NULL;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user