提交 39b7b42b 编写于 作者: J Jiri Slaby 提交者: Greg Kroah-Hartman

tty: stop using alloc_tty_driver

alloc_tty_driver was deprecated by tty_alloc_driver in commit
7f0bc6a6 (TTY: pass flags to alloc_tty_driver) in 2012.

I never got into eliminating alloc_tty_driver until now. So we still
have two functions for allocating drivers which might be confusing. So
get rid of alloc_tty_driver uses to eliminate it for good in the next
patch.

Note we need to switch return value checking as tty_alloc_driver uses
ERR_PTR. And flags are now a parameter of tty_alloc_driver.

Cc: Richard Henderson <rth@twiddle.net>(odd fixer:ALPHA PORT)
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Matt Turner <mattst88@gmail.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
Cc: Helge Deller <deller@gmx.de>
Cc: Jeff Dike <jdike@addtoit.com>
Cc: Richard Weinberger <richard@nod.at>
Cc: Anton Ivanov <anton.ivanov@cambridgegreys.com>
Cc: Chris Zankel <chris@zankel.net>
Cc: Max Filippov <jcmvbkbc@gmail.com>
Cc: Samuel Iglesias Gonsalvez <siglesias@igalia.com>
Cc: Jens Taprogge <jens.taprogge@taprogge.org>
Cc: Karsten Keil <isdn@linux-pingi.de>
Cc: Ulf Hansson <ulf.hansson@linaro.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Jakub Kicinski <kuba@kernel.org>
Cc: Heiko Carstens <hca@linux.ibm.com>
Cc: Vasily Gorbik <gor@linux.ibm.com>
Cc: Christian Borntraeger <borntraeger@de.ibm.com>
Cc: Laurentiu Tudor <laurentiu.tudor@nxp.com>
Cc: Jiri Kosina <jikos@kernel.org>
Cc: David Sterba <dsterba@suse.com>
Cc: Shawn Guo <shawnguo@kernel.org>
Cc: Sascha Hauer <s.hauer@pengutronix.de>
Cc: Oliver Neukum <oneukum@suse.com>
Cc: Felipe Balbi <balbi@kernel.org>
Cc: Johan Hovold <johan@kernel.org>
Cc: Marcel Holtmann <marcel@holtmann.org>
Cc: Johan Hedberg <johan.hedberg@gmail.com>
Cc: Luiz Augusto von Dentz <luiz.dentz@gmail.com>
Acked-by: NSamuel Iglesias Gonsálvez <siglesias@igalia.com>
Acked-by: NMax Filippov <jcmvbkbc@gmail.com>
Acked-by: NDavid Sterba <dsterba@suse.com>
Acked-by: NChristian Borntraeger <borntraeger@de.ibm.com>
Signed-off-by: NJiri Slaby <jslaby@suse.cz>
Link: https://lore.kernel.org/r/20210723074317.32690-5-jslaby@suse.czSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 0524513a
...@@ -204,9 +204,9 @@ srmcons_init(void) ...@@ -204,9 +204,9 @@ srmcons_init(void)
struct tty_driver *driver; struct tty_driver *driver;
int err; int err;
driver = alloc_tty_driver(MAX_SRM_CONSOLE_DEVICES); driver = tty_alloc_driver(MAX_SRM_CONSOLE_DEVICES, 0);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
tty_port_init(&srmcons_singleton.port); tty_port_init(&srmcons_singleton.port);
......
...@@ -127,9 +127,9 @@ static int __init nfcon_init(void) ...@@ -127,9 +127,9 @@ static int __init nfcon_init(void)
if (!stderr_id) if (!stderr_id)
return -ENODEV; return -ENODEV;
driver = alloc_tty_driver(1); driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
tty_port_init(&nfcon_tty_port); tty_port_init(&nfcon_tty_port);
...@@ -138,7 +138,6 @@ static int __init nfcon_init(void) ...@@ -138,7 +138,6 @@ static int __init nfcon_init(void)
driver->type = TTY_DRIVER_TYPE_SYSTEM; driver->type = TTY_DRIVER_TYPE_SYSTEM;
driver->subtype = SYSTEM_TYPE_TTY; driver->subtype = SYSTEM_TYPE_TTY;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &nfcon_tty_ops); tty_set_operations(driver, &nfcon_tty_ops);
tty_port_link_device(&nfcon_tty_port, driver, 0); tty_port_link_device(&nfcon_tty_port, driver, 0);
......
...@@ -161,9 +161,10 @@ static int __init pdc_console_tty_driver_init(void) ...@@ -161,9 +161,10 @@ static int __init pdc_console_tty_driver_init(void)
printk(KERN_INFO "The PDC console driver is still registered, removing CON_BOOT flag\n"); printk(KERN_INFO "The PDC console driver is still registered, removing CON_BOOT flag\n");
pdc_cons.flags &= ~CON_BOOT; pdc_cons.flags &= ~CON_BOOT;
driver = alloc_tty_driver(1); driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW |
if (!driver) TTY_DRIVER_RESET_TERMIOS);
return -ENOMEM; if (IS_ERR(driver))
return PTR_ERR(driver);
tty_port_init(&tty_port); tty_port_init(&tty_port);
...@@ -173,8 +174,6 @@ static int __init pdc_console_tty_driver_init(void) ...@@ -173,8 +174,6 @@ static int __init pdc_console_tty_driver_init(void)
driver->minor_start = 0; driver->minor_start = 0;
driver->type = TTY_DRIVER_TYPE_SYSTEM; driver->type = TTY_DRIVER_TYPE_SYSTEM;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->flags = TTY_DRIVER_REAL_RAW |
TTY_DRIVER_RESET_TERMIOS;
tty_set_operations(driver, &pdc_console_tty_ops); tty_set_operations(driver, &pdc_console_tty_ops);
tty_port_link_device(&tty_port, driver, 0); tty_port_link_device(&tty_port, driver, 0);
......
...@@ -538,12 +538,14 @@ int register_lines(struct line_driver *line_driver, ...@@ -538,12 +538,14 @@ int register_lines(struct line_driver *line_driver,
const struct tty_operations *ops, const struct tty_operations *ops,
struct line *lines, int nlines) struct line *lines, int nlines)
{ {
struct tty_driver *driver = alloc_tty_driver(nlines); struct tty_driver *driver;
int err; int err;
int i; int i;
if (!driver) driver = tty_alloc_driver(nlines, TTY_DRIVER_REAL_RAW |
return -ENOMEM; TTY_DRIVER_DYNAMIC_DEV);
if (IS_ERR(driver))
return PTR_ERR(driver);
driver->driver_name = line_driver->name; driver->driver_name = line_driver->name;
driver->name = line_driver->device_name; driver->name = line_driver->device_name;
...@@ -551,9 +553,8 @@ int register_lines(struct line_driver *line_driver, ...@@ -551,9 +553,8 @@ int register_lines(struct line_driver *line_driver,
driver->minor_start = line_driver->minor_start; driver->minor_start = line_driver->minor_start;
driver->type = line_driver->type; driver->type = line_driver->type;
driver->subtype = line_driver->subtype; driver->subtype = line_driver->subtype;
driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
for (i = 0; i < nlines; i++) { for (i = 0; i < nlines; i++) {
tty_port_init(&lines[i].port); tty_port_init(&lines[i].port);
lines[i].port.ops = &line_port_ops; lines[i].port.ops = &line_port_ops;
......
...@@ -139,9 +139,9 @@ static int __init rs_init(void) ...@@ -139,9 +139,9 @@ static int __init rs_init(void)
struct tty_driver *driver; struct tty_driver *driver;
int ret; int ret;
driver = alloc_tty_driver(SERIAL_MAX_NUM_LINES); driver = tty_alloc_driver(SERIAL_MAX_NUM_LINES, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
tty_port_init(&serial_port); tty_port_init(&serial_port);
...@@ -156,7 +156,6 @@ static int __init rs_init(void) ...@@ -156,7 +156,6 @@ static int __init rs_init(void)
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->init_termios.c_cflag = driver->init_termios.c_cflag =
B9600 | CS8 | CREAD | HUPCL | CLOCAL; B9600 | CS8 | CREAD | HUPCL | CLOCAL;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &serial_ops); tty_set_operations(driver, &serial_ops);
tty_port_link_device(&serial_port, driver, 0); tty_port_link_device(&serial_port, driver, 0);
......
...@@ -347,10 +347,10 @@ static int ipoctal_inst_slot(struct ipoctal *ipoctal, unsigned int bus_nr, ...@@ -347,10 +347,10 @@ static int ipoctal_inst_slot(struct ipoctal *ipoctal, unsigned int bus_nr,
/* Register the TTY device */ /* Register the TTY device */
/* Each IP-OCTAL channel is a TTY port */ /* Each IP-OCTAL channel is a TTY port */
tty = alloc_tty_driver(NR_CHANNELS); tty = tty_alloc_driver(NR_CHANNELS, TTY_DRIVER_REAL_RAW |
TTY_DRIVER_DYNAMIC_DEV);
if (!tty) if (IS_ERR(tty))
return -ENOMEM; return PTR_ERR(tty);
/* Fill struct tty_driver with ipoctal data */ /* Fill struct tty_driver with ipoctal data */
tty->owner = THIS_MODULE; tty->owner = THIS_MODULE;
...@@ -362,7 +362,6 @@ static int ipoctal_inst_slot(struct ipoctal *ipoctal, unsigned int bus_nr, ...@@ -362,7 +362,6 @@ static int ipoctal_inst_slot(struct ipoctal *ipoctal, unsigned int bus_nr,
tty->minor_start = 0; tty->minor_start = 0;
tty->type = TTY_DRIVER_TYPE_SERIAL; tty->type = TTY_DRIVER_TYPE_SERIAL;
tty->subtype = SERIAL_TYPE_NORMAL; tty->subtype = SERIAL_TYPE_NORMAL;
tty->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
tty->init_termios = tty_std_termios; tty->init_termios = tty_std_termios;
tty->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL; tty->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL;
tty->init_termios.c_ispeed = 9600; tty->init_termios.c_ispeed = 9600;
......
...@@ -1269,10 +1269,11 @@ static int __init capinc_tty_init(void) ...@@ -1269,10 +1269,11 @@ static int __init capinc_tty_init(void)
if (!capiminors) if (!capiminors)
return -ENOMEM; return -ENOMEM;
drv = alloc_tty_driver(capi_ttyminors); drv = tty_alloc_driver(capi_ttyminors, TTY_DRIVER_REAL_RAW |
if (!drv) { TTY_DRIVER_RESET_TERMIOS | TTY_DRIVER_DYNAMIC_DEV);
if (IS_ERR(drv)) {
kfree(capiminors); kfree(capiminors);
return -ENOMEM; return PTR_ERR(drv);
} }
drv->driver_name = "capi_nc"; drv->driver_name = "capi_nc";
drv->name = "capi!"; drv->name = "capi!";
...@@ -1285,9 +1286,6 @@ static int __init capinc_tty_init(void) ...@@ -1285,9 +1286,6 @@ static int __init capinc_tty_init(void)
drv->init_termios.c_oflag = OPOST | ONLCR; drv->init_termios.c_oflag = OPOST | ONLCR;
drv->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL; drv->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL;
drv->init_termios.c_lflag = 0; drv->init_termios.c_lflag = 0;
drv->flags =
TTY_DRIVER_REAL_RAW | TTY_DRIVER_RESET_TERMIOS |
TTY_DRIVER_DYNAMIC_DEV;
tty_set_operations(drv, &capinc_ops); tty_set_operations(drv, &capinc_ops);
err = tty_register_driver(drv); err = tty_register_driver(drv);
......
...@@ -1135,9 +1135,10 @@ static int __init sdio_uart_init(void) ...@@ -1135,9 +1135,10 @@ static int __init sdio_uart_init(void)
int ret; int ret;
struct tty_driver *tty_drv; struct tty_driver *tty_drv;
sdio_uart_tty_driver = tty_drv = alloc_tty_driver(UART_NR); sdio_uart_tty_driver = tty_drv = tty_alloc_driver(UART_NR,
if (!tty_drv) TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(tty_drv))
return PTR_ERR(tty_drv);
tty_drv->driver_name = "sdio_uart"; tty_drv->driver_name = "sdio_uart";
tty_drv->name = "ttySDIO"; tty_drv->name = "ttySDIO";
...@@ -1145,7 +1146,6 @@ static int __init sdio_uart_init(void) ...@@ -1145,7 +1146,6 @@ static int __init sdio_uart_init(void)
tty_drv->minor_start = 0; tty_drv->minor_start = 0;
tty_drv->type = TTY_DRIVER_TYPE_SERIAL; tty_drv->type = TTY_DRIVER_TYPE_SERIAL;
tty_drv->subtype = SERIAL_TYPE_NORMAL; tty_drv->subtype = SERIAL_TYPE_NORMAL;
tty_drv->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
tty_drv->init_termios = tty_std_termios; tty_drv->init_termios = tty_std_termios;
tty_drv->init_termios.c_cflag = B4800 | CS8 | CREAD | HUPCL | CLOCAL; tty_drv->init_termios.c_cflag = B4800 | CS8 | CREAD | HUPCL | CLOCAL;
tty_drv->init_termios.c_ispeed = 4800; tty_drv->init_termios.c_ispeed = 4800;
......
...@@ -3229,9 +3229,10 @@ static int __init hso_init(void) ...@@ -3229,9 +3229,10 @@ static int __init hso_init(void)
serial_table[i] = NULL; serial_table[i] = NULL;
/* allocate our driver using the proper amount of supported minors */ /* allocate our driver using the proper amount of supported minors */
tty_drv = alloc_tty_driver(HSO_SERIAL_TTY_MINORS); tty_drv = tty_alloc_driver(HSO_SERIAL_TTY_MINORS, TTY_DRIVER_REAL_RAW |
if (!tty_drv) TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(tty_drv))
return PTR_ERR(tty_drv);
/* fill in all needed values */ /* fill in all needed values */
tty_drv->driver_name = driver_name; tty_drv->driver_name = driver_name;
...@@ -3244,7 +3245,6 @@ static int __init hso_init(void) ...@@ -3244,7 +3245,6 @@ static int __init hso_init(void)
tty_drv->minor_start = 0; tty_drv->minor_start = 0;
tty_drv->type = TTY_DRIVER_TYPE_SERIAL; tty_drv->type = TTY_DRIVER_TYPE_SERIAL;
tty_drv->subtype = SERIAL_TYPE_NORMAL; tty_drv->subtype = SERIAL_TYPE_NORMAL;
tty_drv->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
tty_drv->init_termios = tty_std_termios; tty_drv->init_termios = tty_std_termios;
hso_init_termios(&tty_drv->init_termios); hso_init_termios(&tty_drv->init_termios);
tty_set_operations(tty_drv, &hso_serial_ops); tty_set_operations(tty_drv, &hso_serial_ops);
......
...@@ -1076,9 +1076,9 @@ static int __init tty3215_init(void) ...@@ -1076,9 +1076,9 @@ static int __init tty3215_init(void)
if (!CONSOLE_IS_3215) if (!CONSOLE_IS_3215)
return 0; return 0;
driver = alloc_tty_driver(NR_3215); driver = tty_alloc_driver(NR_3215, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
ret = ccw_driver_register(&raw3215_ccw_driver); ret = ccw_driver_register(&raw3215_ccw_driver);
if (ret) { if (ret) {
...@@ -1101,7 +1101,6 @@ static int __init tty3215_init(void) ...@@ -1101,7 +1101,6 @@ static int __init tty3215_init(void)
driver->init_termios.c_iflag = IGNBRK | IGNPAR; driver->init_termios.c_iflag = IGNBRK | IGNPAR;
driver->init_termios.c_oflag = ONLCR; driver->init_termios.c_oflag = ONLCR;
driver->init_termios.c_lflag = ISIG; driver->init_termios.c_lflag = ISIG;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &tty3215_ops); tty_set_operations(driver, &tty3215_ops);
ret = tty_register_driver(driver); ret = tty_register_driver(driver);
if (ret) { if (ret) {
......
...@@ -503,9 +503,9 @@ sclp_tty_init(void) ...@@ -503,9 +503,9 @@ sclp_tty_init(void)
return 0; return 0;
if (!sclp.has_linemode) if (!sclp.has_linemode)
return 0; return 0;
driver = alloc_tty_driver(1); driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
rc = sclp_rw_init(); rc = sclp_rw_init();
if (rc) { if (rc) {
...@@ -548,7 +548,6 @@ sclp_tty_init(void) ...@@ -548,7 +548,6 @@ sclp_tty_init(void)
driver->init_termios.c_iflag = IGNBRK | IGNPAR; driver->init_termios.c_iflag = IGNBRK | IGNPAR;
driver->init_termios.c_oflag = ONLCR; driver->init_termios.c_oflag = ONLCR;
driver->init_termios.c_lflag = ISIG | ECHO; driver->init_termios.c_lflag = ISIG | ECHO;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &sclp_ops); tty_set_operations(driver, &sclp_ops);
tty_port_link_device(&sclp_port, driver, 0); tty_port_link_device(&sclp_port, driver, 0);
rc = tty_register_driver(driver); rc = tty_register_driver(driver);
......
...@@ -732,9 +732,9 @@ static int __init sclp_vt220_tty_init(void) ...@@ -732,9 +732,9 @@ static int __init sclp_vt220_tty_init(void)
/* Note: we're not testing for CONSOLE_IS_SCLP here to preserve /* Note: we're not testing for CONSOLE_IS_SCLP here to preserve
* symmetry between VM and LPAR systems regarding ttyS1. */ * symmetry between VM and LPAR systems regarding ttyS1. */
driver = alloc_tty_driver(1); driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
rc = __sclp_vt220_init(MAX_KMEM_PAGES); rc = __sclp_vt220_init(MAX_KMEM_PAGES);
if (rc) if (rc)
goto out_driver; goto out_driver;
...@@ -746,7 +746,6 @@ static int __init sclp_vt220_tty_init(void) ...@@ -746,7 +746,6 @@ static int __init sclp_vt220_tty_init(void)
driver->type = TTY_DRIVER_TYPE_SYSTEM; driver->type = TTY_DRIVER_TYPE_SYSTEM;
driver->subtype = SYSTEM_TYPE_TTY; driver->subtype = SYSTEM_TYPE_TTY;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &sclp_vt220_ops); tty_set_operations(driver, &sclp_vt220_ops);
tty_port_link_device(&sclp_vt220_port, driver, 0); tty_port_link_device(&sclp_vt220_port, driver, 0);
......
...@@ -281,9 +281,10 @@ int register_lte_tty_driver(void) ...@@ -281,9 +281,10 @@ int register_lte_tty_driver(void)
int ret; int ret;
for (i = 0; i < TTY_MAX_COUNT; i++) { for (i = 0; i < TTY_MAX_COUNT; i++) {
tty_driver = alloc_tty_driver(GDM_TTY_MINOR); tty_driver = tty_alloc_driver(GDM_TTY_MINOR,
if (!tty_driver) TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(tty_driver))
return PTR_ERR(tty_driver);
tty_driver->owner = THIS_MODULE; tty_driver->owner = THIS_MODULE;
tty_driver->driver_name = DRIVER_STRING[i]; tty_driver->driver_name = DRIVER_STRING[i];
...@@ -291,8 +292,6 @@ int register_lte_tty_driver(void) ...@@ -291,8 +292,6 @@ int register_lte_tty_driver(void)
tty_driver->major = GDM_TTY_MAJOR; tty_driver->major = GDM_TTY_MAJOR;
tty_driver->type = TTY_DRIVER_TYPE_SERIAL; tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
tty_driver->subtype = SERIAL_TYPE_NORMAL; tty_driver->subtype = SERIAL_TYPE_NORMAL;
tty_driver->flags = TTY_DRIVER_REAL_RAW |
TTY_DRIVER_DYNAMIC_DEV;
tty_driver->init_termios = tty_std_termios; tty_driver->init_termios = tty_std_termios;
tty_driver->init_termios.c_cflag = B9600 | CS8 | HUPCL | CLOCAL; tty_driver->init_termios.c_cflag = B9600 | CS8 | HUPCL | CLOCAL;
tty_driver->init_termios.c_lflag = ISIG | ICANON | IEXTEN; tty_driver->init_termios.c_lflag = ISIG | ICANON | IEXTEN;
......
...@@ -1494,9 +1494,9 @@ static int __init amiga_serial_probe(struct platform_device *pdev) ...@@ -1494,9 +1494,9 @@ static int __init amiga_serial_probe(struct platform_device *pdev)
unsigned long flags; unsigned long flags;
int error; int error;
driver = alloc_tty_driver(1); driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
/* Initialize the tty_driver structure */ /* Initialize the tty_driver structure */
...@@ -1509,7 +1509,6 @@ static int __init amiga_serial_probe(struct platform_device *pdev) ...@@ -1509,7 +1509,6 @@ static int __init amiga_serial_probe(struct platform_device *pdev)
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->init_termios.c_cflag = driver->init_termios.c_cflag =
B9600 | CS8 | CREAD | HUPCL | CLOCAL; B9600 | CS8 | CREAD | HUPCL | CLOCAL;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &serial_ops); tty_set_operations(driver, &serial_ops);
memset(state, 0, sizeof(*state)); memset(state, 0, sizeof(*state));
......
...@@ -774,9 +774,10 @@ static int __init ehv_bc_init(void) ...@@ -774,9 +774,10 @@ static int __init ehv_bc_init(void)
if (!bcs) if (!bcs)
return -ENOMEM; return -ENOMEM;
driver = alloc_tty_driver(count); driver = tty_alloc_driver(count, TTY_DRIVER_REAL_RAW |
if (!driver) { TTY_DRIVER_DYNAMIC_DEV);
ret = -ENOMEM; if (IS_ERR(driver)) {
ret = PTR_ERR(driver);
goto err_free_bcs; goto err_free_bcs;
} }
...@@ -785,7 +786,6 @@ static int __init ehv_bc_init(void) ...@@ -785,7 +786,6 @@ static int __init ehv_bc_init(void)
driver->type = TTY_DRIVER_TYPE_CONSOLE; driver->type = TTY_DRIVER_TYPE_CONSOLE;
driver->subtype = SYSTEM_TYPE_CONSOLE; driver->subtype = SYSTEM_TYPE_CONSOLE;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
tty_set_operations(driver, &ehv_bc_ops); tty_set_operations(driver, &ehv_bc_ops);
ret = tty_register_driver(driver); ret = tty_register_driver(driver);
......
...@@ -253,18 +253,18 @@ static int goldfish_tty_create_driver(void) ...@@ -253,18 +253,18 @@ static int goldfish_tty_create_driver(void)
ret = -ENOMEM; ret = -ENOMEM;
goto err_alloc_goldfish_ttys_failed; goto err_alloc_goldfish_ttys_failed;
} }
tty = alloc_tty_driver(goldfish_tty_line_count); tty = tty_alloc_driver(goldfish_tty_line_count,
if (tty == NULL) { TTY_DRIVER_RESET_TERMIOS | TTY_DRIVER_REAL_RAW |
ret = -ENOMEM; TTY_DRIVER_DYNAMIC_DEV);
goto err_alloc_tty_driver_failed; if (IS_ERR(tty)) {
ret = PTR_ERR(tty);
goto err_tty_alloc_driver_failed;
} }
tty->driver_name = "goldfish"; tty->driver_name = "goldfish";
tty->name = "ttyGF"; tty->name = "ttyGF";
tty->type = TTY_DRIVER_TYPE_SERIAL; tty->type = TTY_DRIVER_TYPE_SERIAL;
tty->subtype = SERIAL_TYPE_NORMAL; tty->subtype = SERIAL_TYPE_NORMAL;
tty->init_termios = tty_std_termios; tty->init_termios = tty_std_termios;
tty->flags = TTY_DRIVER_RESET_TERMIOS | TTY_DRIVER_REAL_RAW |
TTY_DRIVER_DYNAMIC_DEV;
tty_set_operations(tty, &goldfish_tty_ops); tty_set_operations(tty, &goldfish_tty_ops);
ret = tty_register_driver(tty); ret = tty_register_driver(tty);
if (ret) if (ret)
...@@ -275,7 +275,7 @@ static int goldfish_tty_create_driver(void) ...@@ -275,7 +275,7 @@ static int goldfish_tty_create_driver(void)
err_tty_register_driver_failed: err_tty_register_driver_failed:
put_tty_driver(tty); put_tty_driver(tty);
err_alloc_tty_driver_failed: err_tty_alloc_driver_failed:
kfree(goldfish_ttys); kfree(goldfish_ttys);
goldfish_ttys = NULL; goldfish_ttys = NULL;
err_alloc_goldfish_ttys_failed: err_alloc_goldfish_ttys_failed:
......
...@@ -1021,9 +1021,10 @@ static int hvc_init(void) ...@@ -1021,9 +1021,10 @@ static int hvc_init(void)
int err; int err;
/* We need more than hvc_count adapters due to hotplug additions. */ /* We need more than hvc_count adapters due to hotplug additions. */
drv = alloc_tty_driver(HVC_ALLOC_TTY_ADAPTERS); drv = tty_alloc_driver(HVC_ALLOC_TTY_ADAPTERS, TTY_DRIVER_REAL_RAW |
if (!drv) { TTY_DRIVER_RESET_TERMIOS);
err = -ENOMEM; if (IS_ERR(drv)) {
err = PTR_ERR(drv);
goto out; goto out;
} }
...@@ -1033,7 +1034,6 @@ static int hvc_init(void) ...@@ -1033,7 +1034,6 @@ static int hvc_init(void)
drv->minor_start = HVC_MINOR; drv->minor_start = HVC_MINOR;
drv->type = TTY_DRIVER_TYPE_SYSTEM; drv->type = TTY_DRIVER_TYPE_SYSTEM;
drv->init_termios = tty_std_termios; drv->init_termios = tty_std_termios;
drv->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_RESET_TERMIOS;
tty_set_operations(drv, &hvc_ops); tty_set_operations(drv, &hvc_ops);
/* Always start the kthread because there can be hotplug vty adapters /* Always start the kthread because there can be hotplug vty adapters
......
...@@ -1445,10 +1445,11 @@ static int hvcs_initialize(void) ...@@ -1445,10 +1445,11 @@ static int hvcs_initialize(void)
} else } else
num_ttys_to_alloc = hvcs_parm_num_devs; num_ttys_to_alloc = hvcs_parm_num_devs;
hvcs_tty_driver = alloc_tty_driver(num_ttys_to_alloc); hvcs_tty_driver = tty_alloc_driver(num_ttys_to_alloc,
if (!hvcs_tty_driver) { TTY_DRIVER_REAL_RAW);
if (IS_ERR(hvcs_tty_driver)) {
mutex_unlock(&hvcs_init_mutex); mutex_unlock(&hvcs_init_mutex);
return -ENOMEM; return PTR_ERR(hvcs_tty_driver);
} }
if (hvcs_alloc_index_list(num_ttys_to_alloc)) { if (hvcs_alloc_index_list(num_ttys_to_alloc)) {
...@@ -1473,7 +1474,6 @@ static int hvcs_initialize(void) ...@@ -1473,7 +1474,6 @@ static int hvcs_initialize(void)
* throw us into a horrible recursive echo-echo-echo loop. * throw us into a horrible recursive echo-echo-echo loop.
*/ */
hvcs_tty_driver->init_termios = hvcs_tty_termios; hvcs_tty_driver->init_termios = hvcs_tty_termios;
hvcs_tty_driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(hvcs_tty_driver, &hvcs_ops); tty_set_operations(hvcs_tty_driver, &hvcs_ops);
......
...@@ -1041,9 +1041,9 @@ static int __init hvsi_init(void) ...@@ -1041,9 +1041,9 @@ static int __init hvsi_init(void)
struct tty_driver *driver; struct tty_driver *driver;
int i, ret; int i, ret;
driver = alloc_tty_driver(hvsi_count); driver = tty_alloc_driver(hvsi_count, TTY_DRIVER_REAL_RAW);
if (!driver) if (IS_ERR(driver))
return -ENOMEM; return PTR_ERR(driver);
driver->driver_name = "hvsi"; driver->driver_name = "hvsi";
driver->name = "hvsi"; driver->name = "hvsi";
...@@ -1054,7 +1054,6 @@ static int __init hvsi_init(void) ...@@ -1054,7 +1054,6 @@ static int __init hvsi_init(void)
driver->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL; driver->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL;
driver->init_termios.c_ispeed = 9600; driver->init_termios.c_ispeed = 9600;
driver->init_termios.c_ospeed = 9600; driver->init_termios.c_ospeed = 9600;
driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(driver, &hvsi_ops); tty_set_operations(driver, &hvsi_ops);
for (i=0; i < hvsi_count; i++) { for (i=0; i < hvsi_count; i++) {
......
...@@ -564,9 +564,10 @@ int ipwireless_tty_init(void) ...@@ -564,9 +564,10 @@ int ipwireless_tty_init(void)
{ {
int result; int result;
ipw_tty_driver = alloc_tty_driver(IPWIRELESS_PCMCIA_MINORS); ipw_tty_driver = tty_alloc_driver(IPWIRELESS_PCMCIA_MINORS,
if (!ipw_tty_driver) TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(ipw_tty_driver))
return PTR_ERR(ipw_tty_driver);
ipw_tty_driver->driver_name = IPWIRELESS_PCCARD_NAME; ipw_tty_driver->driver_name = IPWIRELESS_PCCARD_NAME;
ipw_tty_driver->name = "ttyIPWp"; ipw_tty_driver->name = "ttyIPWp";
...@@ -574,7 +575,6 @@ int ipwireless_tty_init(void) ...@@ -574,7 +575,6 @@ int ipwireless_tty_init(void)
ipw_tty_driver->minor_start = IPWIRELESS_PCMCIA_START; ipw_tty_driver->minor_start = IPWIRELESS_PCMCIA_START;
ipw_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; ipw_tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
ipw_tty_driver->subtype = SERIAL_TYPE_NORMAL; ipw_tty_driver->subtype = SERIAL_TYPE_NORMAL;
ipw_tty_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
ipw_tty_driver->init_termios = tty_std_termios; ipw_tty_driver->init_termios = tty_std_termios;
ipw_tty_driver->init_termios.c_cflag = ipw_tty_driver->init_termios.c_cflag =
B9600 | CS8 | CREAD | HUPCL | CLOCAL; B9600 | CS8 | CREAD | HUPCL | CLOCAL;
......
...@@ -1976,9 +1976,10 @@ static int __init mxser_module_init(void) ...@@ -1976,9 +1976,10 @@ static int __init mxser_module_init(void)
{ {
int retval; int retval;
mxvar_sdriver = alloc_tty_driver(MXSER_PORTS); mxvar_sdriver = tty_alloc_driver(MXSER_PORTS, TTY_DRIVER_REAL_RAW |
if (!mxvar_sdriver) TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(mxvar_sdriver))
return PTR_ERR(mxvar_sdriver);
/* Initialize the tty_driver structure */ /* Initialize the tty_driver structure */
mxvar_sdriver->name = "ttyMI"; mxvar_sdriver->name = "ttyMI";
...@@ -1988,7 +1989,6 @@ static int __init mxser_module_init(void) ...@@ -1988,7 +1989,6 @@ static int __init mxser_module_init(void)
mxvar_sdriver->subtype = SERIAL_TYPE_NORMAL; mxvar_sdriver->subtype = SERIAL_TYPE_NORMAL;
mxvar_sdriver->init_termios = tty_std_termios; mxvar_sdriver->init_termios = tty_std_termios;
mxvar_sdriver->init_termios.c_cflag = B9600|CS8|CREAD|HUPCL|CLOCAL; mxvar_sdriver->init_termios.c_cflag = B9600|CS8|CREAD|HUPCL|CLOCAL;
mxvar_sdriver->flags = TTY_DRIVER_REAL_RAW|TTY_DRIVER_DYNAMIC_DEV;
tty_set_operations(mxvar_sdriver, &mxser_ops); tty_set_operations(mxvar_sdriver, &mxser_ops);
retval = tty_register_driver(mxvar_sdriver); retval = tty_register_driver(mxvar_sdriver);
......
...@@ -3252,10 +3252,11 @@ static int __init gsm_init(void) ...@@ -3252,10 +3252,11 @@ static int __init gsm_init(void)
return status; return status;
} }
gsm_tty_driver = alloc_tty_driver(256); gsm_tty_driver = tty_alloc_driver(256, TTY_DRIVER_REAL_RAW |
if (!gsm_tty_driver) { TTY_DRIVER_DYNAMIC_DEV | TTY_DRIVER_HARDWARE_BREAK);
if (IS_ERR(gsm_tty_driver)) {
pr_err("gsm_init: tty allocation failed.\n"); pr_err("gsm_init: tty allocation failed.\n");
status = -ENOMEM; status = PTR_ERR(gsm_tty_driver);
goto err_unreg_ldisc; goto err_unreg_ldisc;
} }
gsm_tty_driver->driver_name = "gsmtty"; gsm_tty_driver->driver_name = "gsmtty";
...@@ -3264,8 +3265,6 @@ static int __init gsm_init(void) ...@@ -3264,8 +3265,6 @@ static int __init gsm_init(void)
gsm_tty_driver->minor_start = 0; gsm_tty_driver->minor_start = 0;
gsm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; gsm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
gsm_tty_driver->subtype = SERIAL_TYPE_NORMAL; gsm_tty_driver->subtype = SERIAL_TYPE_NORMAL;
gsm_tty_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV
| TTY_DRIVER_HARDWARE_BREAK;
gsm_tty_driver->init_termios = tty_std_termios; gsm_tty_driver->init_termios = tty_std_termios;
/* Fixme */ /* Fixme */
gsm_tty_driver->init_termios.c_lflag &= ~ECHO; gsm_tty_driver->init_termios.c_lflag &= ~ECHO;
......
...@@ -1824,16 +1824,16 @@ static __init int nozomi_init(void) ...@@ -1824,16 +1824,16 @@ static __init int nozomi_init(void)
{ {
int ret; int ret;
ntty_driver = alloc_tty_driver(NTTY_TTY_MAXMINORS); ntty_driver = tty_alloc_driver(NTTY_TTY_MAXMINORS, TTY_DRIVER_REAL_RAW |
if (!ntty_driver) TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(ntty_driver))
return PTR_ERR(ntty_driver);
ntty_driver->driver_name = NOZOMI_NAME_TTY; ntty_driver->driver_name = NOZOMI_NAME_TTY;
ntty_driver->name = "noz"; ntty_driver->name = "noz";
ntty_driver->major = 0; ntty_driver->major = 0;
ntty_driver->type = TTY_DRIVER_TYPE_SERIAL; ntty_driver->type = TTY_DRIVER_TYPE_SERIAL;
ntty_driver->subtype = SERIAL_TYPE_NORMAL; ntty_driver->subtype = SERIAL_TYPE_NORMAL;
ntty_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
ntty_driver->init_termios = tty_std_termios; ntty_driver->init_termios = tty_std_termios;
ntty_driver->init_termios.c_cflag = B115200 | CS8 | CREAD | \ ntty_driver->init_termios.c_cflag = B115200 | CS8 | CREAD | \
HUPCL | CLOCAL; HUPCL | CLOCAL;
......
...@@ -330,17 +330,16 @@ int kgdb_register_nmi_console(void) ...@@ -330,17 +330,16 @@ int kgdb_register_nmi_console(void)
if (!arch_kgdb_ops.enable_nmi) if (!arch_kgdb_ops.enable_nmi)
return 0; return 0;
kgdb_nmi_tty_driver = alloc_tty_driver(1); kgdb_nmi_tty_driver = tty_alloc_driver(1, TTY_DRIVER_REAL_RAW);
if (!kgdb_nmi_tty_driver) { if (IS_ERR(kgdb_nmi_tty_driver)) {
pr_err("%s: cannot allocate tty\n", __func__); pr_err("%s: cannot allocate tty\n", __func__);
return -ENOMEM; return PTR_ERR(kgdb_nmi_tty_driver);
} }
kgdb_nmi_tty_driver->driver_name = "ttyNMI"; kgdb_nmi_tty_driver->driver_name = "ttyNMI";
kgdb_nmi_tty_driver->name = "ttyNMI"; kgdb_nmi_tty_driver->name = "ttyNMI";
kgdb_nmi_tty_driver->num = 1; kgdb_nmi_tty_driver->num = 1;
kgdb_nmi_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; kgdb_nmi_tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
kgdb_nmi_tty_driver->subtype = SERIAL_TYPE_NORMAL; kgdb_nmi_tty_driver->subtype = SERIAL_TYPE_NORMAL;
kgdb_nmi_tty_driver->flags = TTY_DRIVER_REAL_RAW;
kgdb_nmi_tty_driver->init_termios = tty_std_termios; kgdb_nmi_tty_driver->init_termios = tty_std_termios;
tty_termios_encode_baud_rate(&kgdb_nmi_tty_driver->init_termios, tty_termios_encode_baud_rate(&kgdb_nmi_tty_driver->init_termios,
KGDB_NMI_BAUD, KGDB_NMI_BAUD); KGDB_NMI_BAUD, KGDB_NMI_BAUD);
......
...@@ -2530,9 +2530,12 @@ int uart_register_driver(struct uart_driver *drv) ...@@ -2530,9 +2530,12 @@ int uart_register_driver(struct uart_driver *drv)
if (!drv->state) if (!drv->state)
goto out; goto out;
normal = alloc_tty_driver(drv->nr); normal = tty_alloc_driver(drv->nr, TTY_DRIVER_REAL_RAW |
if (!normal) TTY_DRIVER_DYNAMIC_DEV);
if (IS_ERR(normal)) {
retval = PTR_ERR(normal);
goto out_kfree; goto out_kfree;
}
drv->tty_driver = normal; drv->tty_driver = normal;
...@@ -2545,7 +2548,6 @@ int uart_register_driver(struct uart_driver *drv) ...@@ -2545,7 +2548,6 @@ int uart_register_driver(struct uart_driver *drv)
normal->init_termios = tty_std_termios; normal->init_termios = tty_std_termios;
normal->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL; normal->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL;
normal->init_termios.c_ispeed = normal->init_termios.c_ospeed = 9600; normal->init_termios.c_ispeed = normal->init_termios.c_ospeed = 9600;
normal->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
normal->driver_state = drv; normal->driver_state = drv;
tty_set_operations(normal, &uart_ops); tty_set_operations(normal, &uart_ops);
......
...@@ -3689,10 +3689,11 @@ static int __init slgt_init(void) ...@@ -3689,10 +3689,11 @@ static int __init slgt_init(void)
printk(KERN_INFO "%s\n", driver_name); printk(KERN_INFO "%s\n", driver_name);
serial_driver = alloc_tty_driver(MAX_DEVICES); serial_driver = tty_alloc_driver(MAX_DEVICES, TTY_DRIVER_REAL_RAW |
if (!serial_driver) { TTY_DRIVER_DYNAMIC_DEV);
if (IS_ERR(serial_driver)) {
printk("%s can't allocate tty driver\n", driver_name); printk("%s can't allocate tty driver\n", driver_name);
return -ENOMEM; return PTR_ERR(serial_driver);
} }
/* Initialize the tty_driver structure */ /* Initialize the tty_driver structure */
...@@ -3708,7 +3709,6 @@ static int __init slgt_init(void) ...@@ -3708,7 +3709,6 @@ static int __init slgt_init(void)
B9600 | CS8 | CREAD | HUPCL | CLOCAL; B9600 | CS8 | CREAD | HUPCL | CLOCAL;
serial_driver->init_termios.c_ispeed = 9600; serial_driver->init_termios.c_ispeed = 9600;
serial_driver->init_termios.c_ospeed = 9600; serial_driver->init_termios.c_ospeed = 9600;
serial_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
tty_set_operations(serial_driver, &ops); tty_set_operations(serial_driver, &ops);
if ((rc = tty_register_driver(serial_driver)) < 0) { if ((rc = tty_register_driver(serial_driver)) < 0) {
DBGERR(("%s can't register serial driver\n", driver_name)); DBGERR(("%s can't register serial driver\n", driver_name));
......
...@@ -3576,8 +3576,9 @@ int __init vty_init(const struct file_operations *console_fops) ...@@ -3576,8 +3576,9 @@ int __init vty_init(const struct file_operations *console_fops)
vcs_init(); vcs_init();
console_driver = alloc_tty_driver(MAX_NR_CONSOLES); console_driver = tty_alloc_driver(MAX_NR_CONSOLES, TTY_DRIVER_REAL_RAW |
if (!console_driver) TTY_DRIVER_RESET_TERMIOS);
if (IS_ERR(console_driver))
panic("Couldn't allocate console driver\n"); panic("Couldn't allocate console driver\n");
console_driver->name = "tty"; console_driver->name = "tty";
...@@ -3588,7 +3589,6 @@ int __init vty_init(const struct file_operations *console_fops) ...@@ -3588,7 +3589,6 @@ int __init vty_init(const struct file_operations *console_fops)
console_driver->init_termios = tty_std_termios; console_driver->init_termios = tty_std_termios;
if (default_utf8) if (default_utf8)
console_driver->init_termios.c_iflag |= IUTF8; console_driver->init_termios.c_iflag |= IUTF8;
console_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_RESET_TERMIOS;
tty_set_operations(console_driver, &con_ops); tty_set_operations(console_driver, &con_ops);
if (tty_register_driver(console_driver)) if (tty_register_driver(console_driver))
panic("Couldn't register console driver\n"); panic("Couldn't register console driver\n");
......
...@@ -2027,16 +2027,16 @@ static const struct tty_operations acm_ops = { ...@@ -2027,16 +2027,16 @@ static const struct tty_operations acm_ops = {
static int __init acm_init(void) static int __init acm_init(void)
{ {
int retval; int retval;
acm_tty_driver = alloc_tty_driver(ACM_TTY_MINORS); acm_tty_driver = tty_alloc_driver(ACM_TTY_MINORS, TTY_DRIVER_REAL_RAW |
if (!acm_tty_driver) TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(acm_tty_driver))
return PTR_ERR(acm_tty_driver);
acm_tty_driver->driver_name = "acm", acm_tty_driver->driver_name = "acm",
acm_tty_driver->name = "ttyACM", acm_tty_driver->name = "ttyACM",
acm_tty_driver->major = ACM_TTY_MAJOR, acm_tty_driver->major = ACM_TTY_MAJOR,
acm_tty_driver->minor_start = 0, acm_tty_driver->minor_start = 0,
acm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL, acm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL,
acm_tty_driver->subtype = SERIAL_TYPE_NORMAL, acm_tty_driver->subtype = SERIAL_TYPE_NORMAL,
acm_tty_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
acm_tty_driver->init_termios = tty_std_termios; acm_tty_driver->init_termios = tty_std_termios;
acm_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD | acm_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD |
HUPCL | CLOCAL; HUPCL | CLOCAL;
......
...@@ -1449,9 +1449,10 @@ static int userial_init(void) ...@@ -1449,9 +1449,10 @@ static int userial_init(void)
unsigned i; unsigned i;
int status; int status;
driver = alloc_tty_driver(MAX_U_SERIAL_PORTS); driver = tty_alloc_driver(MAX_U_SERIAL_PORTS, TTY_DRIVER_REAL_RAW |
if (!driver) TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(driver))
return PTR_ERR(driver);
driver->driver_name = "g_serial"; driver->driver_name = "g_serial";
driver->name = "ttyGS"; driver->name = "ttyGS";
...@@ -1459,7 +1460,6 @@ static int userial_init(void) ...@@ -1459,7 +1460,6 @@ static int userial_init(void)
driver->type = TTY_DRIVER_TYPE_SERIAL; driver->type = TTY_DRIVER_TYPE_SERIAL;
driver->subtype = SERIAL_TYPE_NORMAL; driver->subtype = SERIAL_TYPE_NORMAL;
driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
driver->init_termios = tty_std_termios; driver->init_termios = tty_std_termios;
/* 9600-8-N-1 ... matches defaults expected by "usbser.sys" on /* 9600-8-N-1 ... matches defaults expected by "usbser.sys" on
......
...@@ -1319,9 +1319,10 @@ static int __init usb_serial_init(void) ...@@ -1319,9 +1319,10 @@ static int __init usb_serial_init(void)
{ {
int result; int result;
usb_serial_tty_driver = alloc_tty_driver(USB_SERIAL_TTY_MINORS); usb_serial_tty_driver = tty_alloc_driver(USB_SERIAL_TTY_MINORS,
if (!usb_serial_tty_driver) TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(usb_serial_tty_driver))
return PTR_ERR(usb_serial_tty_driver);
/* Initialize our global data */ /* Initialize our global data */
result = bus_register(&usb_serial_bus_type); result = bus_register(&usb_serial_bus_type);
...@@ -1336,8 +1337,6 @@ static int __init usb_serial_init(void) ...@@ -1336,8 +1337,6 @@ static int __init usb_serial_init(void)
usb_serial_tty_driver->minor_start = 0; usb_serial_tty_driver->minor_start = 0;
usb_serial_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; usb_serial_tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
usb_serial_tty_driver->subtype = SERIAL_TYPE_NORMAL; usb_serial_tty_driver->subtype = SERIAL_TYPE_NORMAL;
usb_serial_tty_driver->flags = TTY_DRIVER_REAL_RAW |
TTY_DRIVER_DYNAMIC_DEV;
usb_serial_tty_driver->init_termios = tty_std_termios; usb_serial_tty_driver->init_termios = tty_std_termios;
usb_serial_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD usb_serial_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD
| HUPCL | CLOCAL; | HUPCL | CLOCAL;
......
...@@ -1127,9 +1127,10 @@ int __init rfcomm_init_ttys(void) ...@@ -1127,9 +1127,10 @@ int __init rfcomm_init_ttys(void)
{ {
int error; int error;
rfcomm_tty_driver = alloc_tty_driver(RFCOMM_TTY_PORTS); rfcomm_tty_driver = tty_alloc_driver(RFCOMM_TTY_PORTS,
if (!rfcomm_tty_driver) TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV);
return -ENOMEM; if (IS_ERR(rfcomm_tty_driver))
return PTR_ERR(rfcomm_tty_driver);
rfcomm_tty_driver->driver_name = "rfcomm"; rfcomm_tty_driver->driver_name = "rfcomm";
rfcomm_tty_driver->name = "rfcomm"; rfcomm_tty_driver->name = "rfcomm";
...@@ -1137,7 +1138,6 @@ int __init rfcomm_init_ttys(void) ...@@ -1137,7 +1138,6 @@ int __init rfcomm_init_ttys(void)
rfcomm_tty_driver->minor_start = RFCOMM_TTY_MINOR; rfcomm_tty_driver->minor_start = RFCOMM_TTY_MINOR;
rfcomm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; rfcomm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL;
rfcomm_tty_driver->subtype = SERIAL_TYPE_NORMAL; rfcomm_tty_driver->subtype = SERIAL_TYPE_NORMAL;
rfcomm_tty_driver->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
rfcomm_tty_driver->init_termios = tty_std_termios; rfcomm_tty_driver->init_termios = tty_std_termios;
rfcomm_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL; rfcomm_tty_driver->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL;
rfcomm_tty_driver->init_termios.c_lflag &= ~ICANON; rfcomm_tty_driver->init_termios.c_lflag &= ~ICANON;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册