Commit 6c8b84ef authored by Mark Hounschell's avatar Mark Hounschell Committed by Greg Kroah-Hartman

staging: dgap: fix kernel oops on port open

This patch addresses the follow error message followed
by a kernel oops:

dgap: driver does not set tty->port. This will crash the kernel later. Fix the driver

It also renames the main function this patch addresses because
its name is misleading.
Signed-off-by: default avatarMark Hounschell <markh@compro.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d7a078b8
...@@ -223,7 +223,7 @@ static void dgap_get_vpd(struct board_t *brd); ...@@ -223,7 +223,7 @@ static void dgap_get_vpd(struct board_t *brd);
static void dgap_do_reset_board(struct board_t *brd); static void dgap_do_reset_board(struct board_t *brd);
static void dgap_do_wait_for_bios(struct board_t *brd); static void dgap_do_wait_for_bios(struct board_t *brd);
static void dgap_do_wait_for_fep(struct board_t *brd); static void dgap_do_wait_for_fep(struct board_t *brd);
static void dgap_sysfs_create(struct board_t *brd); static int dgap_tty_register_ports(struct board_t *brd);
static int dgap_firmware_load(struct pci_dev *pdev, int card_type); static int dgap_firmware_load(struct pci_dev *pdev, int card_type);
/* Driver load/unload functions */ /* Driver load/unload functions */
...@@ -1098,7 +1098,9 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type) ...@@ -1098,7 +1098,9 @@ static int dgap_firmware_load(struct pci_dev *pdev, int card_type)
return ret; return ret;
} }
dgap_sysfs_create(brd); ret = dgap_tty_register_ports(brd);
if (ret)
return ret;
brd->state = BOARD_READY; brd->state = BOARD_READY;
brd->dpastatus = BD_RUNNING; brd->dpastatus = BD_RUNNING;
...@@ -1730,6 +1732,7 @@ static void dgap_tty_uninit(struct board_t *brd) ...@@ -1730,6 +1732,7 @@ static void dgap_tty_uninit(struct board_t *brd)
dgap_BoardsByMajor[brd->SerialDriver->major] = NULL; dgap_BoardsByMajor[brd->SerialDriver->major] = NULL;
brd->dgap_Serial_Major = 0; brd->dgap_Serial_Major = 0;
for (i = 0; i < brd->nasync; i++) { for (i = 0; i < brd->nasync; i++) {
tty_port_destroy(&brd->SerialPorts[i]);
dgap_remove_tty_sysfs(brd->channels[i]->ch_tun.un_sysfs); dgap_remove_tty_sysfs(brd->channels[i]->ch_tun.un_sysfs);
tty_unregister_device(brd->SerialDriver, i); tty_unregister_device(brd->SerialDriver, i);
} }
...@@ -1737,6 +1740,7 @@ static void dgap_tty_uninit(struct board_t *brd) ...@@ -1737,6 +1740,7 @@ static void dgap_tty_uninit(struct board_t *brd)
kfree(brd->SerialDriver->ttys); kfree(brd->SerialDriver->ttys);
brd->SerialDriver->ttys = NULL; brd->SerialDriver->ttys = NULL;
put_tty_driver(brd->SerialDriver); put_tty_driver(brd->SerialDriver);
kfree(brd->SerialPorts);
brd->dgap_Major_Serial_Registered = FALSE; brd->dgap_Major_Serial_Registered = FALSE;
} }
...@@ -1744,6 +1748,7 @@ static void dgap_tty_uninit(struct board_t *brd) ...@@ -1744,6 +1748,7 @@ static void dgap_tty_uninit(struct board_t *brd)
dgap_BoardsByMajor[brd->PrintDriver->major] = NULL; dgap_BoardsByMajor[brd->PrintDriver->major] = NULL;
brd->dgap_TransparentPrint_Major = 0; brd->dgap_TransparentPrint_Major = 0;
for (i = 0; i < brd->nasync; i++) { for (i = 0; i < brd->nasync; i++) {
tty_port_destroy(&brd->PrinterPorts[i]);
dgap_remove_tty_sysfs(brd->channels[i]->ch_pun.un_sysfs); dgap_remove_tty_sysfs(brd->channels[i]->ch_pun.un_sysfs);
tty_unregister_device(brd->PrintDriver, i); tty_unregister_device(brd->PrintDriver, i);
} }
...@@ -1751,6 +1756,7 @@ static void dgap_tty_uninit(struct board_t *brd) ...@@ -1751,6 +1756,7 @@ static void dgap_tty_uninit(struct board_t *brd)
kfree(brd->PrintDriver->ttys); kfree(brd->PrintDriver->ttys);
brd->PrintDriver->ttys = NULL; brd->PrintDriver->ttys = NULL;
put_tty_driver(brd->PrintDriver); put_tty_driver(brd->PrintDriver);
kfree(brd->PrinterPorts);
brd->dgap_Major_TransparentPrint_Registered = FALSE; brd->dgap_Major_TransparentPrint_Registered = FALSE;
} }
} }
...@@ -4813,25 +4819,49 @@ static int dgap_after_config_loaded(int board) ...@@ -4813,25 +4819,49 @@ static int dgap_after_config_loaded(int board)
/* /*
* Create pr and tty device entries * Create pr and tty device entries
*/ */
static void dgap_sysfs_create(struct board_t *brd) static int dgap_tty_register_ports(struct board_t *brd)
{ {
struct channel_t *ch; struct channel_t *ch;
int j = 0; int i;
brd->SerialPorts = kcalloc(brd->nasync, sizeof(*brd->SerialPorts),
GFP_KERNEL);
if (brd->SerialPorts == NULL)
return -ENOMEM;
for (i = 0; i < brd->nasync; i++)
tty_port_init(&brd->SerialPorts[i]);
brd->PrinterPorts = kcalloc(brd->nasync, sizeof(*brd->PrinterPorts),
GFP_KERNEL);
if (brd->PrinterPorts == NULL) {
kfree(brd->SerialPorts);
return -ENOMEM;
}
for (i = 0; i < brd->nasync; i++)
tty_port_init(&brd->PrinterPorts[i]);
ch = brd->channels[0]; ch = brd->channels[0];
for (j = 0; j < brd->nasync; j++, ch = brd->channels[j]) { for (i = 0; i < brd->nasync; i++, ch = brd->channels[i]) {
struct device *classp; struct device *classp;
classp = tty_register_device(brd->SerialDriver, j,
&(ch->ch_bd->pdev->dev)); classp = tty_port_register_device(&brd->SerialPorts[i],
ch->ch_tun.un_sysfs = classp; brd->SerialDriver,
brd->firstminor + i, NULL);
dgap_create_tty_sysfs(&ch->ch_tun, classp); dgap_create_tty_sysfs(&ch->ch_tun, classp);
ch->ch_tun.un_sysfs = classp;
classp = tty_port_register_device(&brd->PrinterPorts[i],
brd->PrintDriver,
brd->firstminor + i, NULL);
classp = tty_register_device(brd->PrintDriver, j,
&(ch->ch_bd->pdev->dev));
ch->ch_pun.un_sysfs = classp;
dgap_create_tty_sysfs(&ch->ch_pun, classp); dgap_create_tty_sysfs(&ch->ch_pun, classp);
ch->ch_pun.un_sysfs = classp;
} }
dgap_create_ports_sysfiles(brd); dgap_create_ports_sysfiles(brd);
return 0;
} }
......
...@@ -703,7 +703,6 @@ struct macounter ...@@ -703,7 +703,6 @@ struct macounter
#define BD_FEP5PLUS 0x0001 /* Supports FEP5 Plus commands */ #define BD_FEP5PLUS 0x0001 /* Supports FEP5 Plus commands */
#define BD_HAS_VPD 0x0002 /* Board has VPD info available */ #define BD_HAS_VPD 0x0002 /* Board has VPD info available */
/* /*
* Per-board information * Per-board information
*/ */
...@@ -761,8 +760,10 @@ struct board_t ...@@ -761,8 +760,10 @@ struct board_t
struct channel_t *channels[MAXPORTS]; /* array of pointers to our channels. */ struct channel_t *channels[MAXPORTS]; /* array of pointers to our channels. */
struct tty_driver *SerialDriver; struct tty_driver *SerialDriver;
struct tty_port *SerialPorts;
char SerialName[200]; char SerialName[200];
struct tty_driver *PrintDriver; struct tty_driver *PrintDriver;
struct tty_port *PrinterPorts;
char PrintName[200]; char PrintName[200];
u32 dgap_Major_Serial_Registered; u32 dgap_Major_Serial_Registered;
......
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