Commit 551a9d73 authored by Daeseok Youn's avatar Daeseok Youn Committed by Greg Kroah-Hartman

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: default avatarDaeseok Youn <daeseok.youn@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e74c2ddc
...@@ -957,10 +957,8 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type) ...@@ -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) ...@@ -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) ...@@ -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) ...@@ -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;
} }
/* /*
......
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