Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1764525AbXJOLZq (ORCPT ); Mon, 15 Oct 2007 07:25:46 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1758910AbXJOLZQ (ORCPT ); Mon, 15 Oct 2007 07:25:16 -0400 Received: from general-networks3.cust.sloane.cz ([88.146.176.14]:56674 "EHLO server.generalnetworks.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756555AbXJOLZM (ORCPT ); Mon, 15 Oct 2007 07:25:12 -0400 From: Jiri Slaby To: Ferenc Wagner Cc: Subject: Re: RocketPort Linux driver errors on module reload In-reply-to: <87abqk1z3t.fsf@tac.ki.iif.hu> Message-id: Date: Mon, 15 Oct 2007 07:25:12 -0400 Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4072 Lines: 100 > -------------------- Start of forwarded message -------------------- > From: Ferenc Wagner > To: support@comtrol.co.uk > Subject: RocketPort Linux driver errors on module reload > Date: Fri, 12 Oct 2007 00:22:17 +0200 > Message-ID: <87fy0hwaue.fsf@tac.ki.iif.hu> > > Hi, > > I hope I send this message to the right address... > > I experience the following with the 2.09 version of the driver, as > included in vanilla Linux 2.6.23. If I insert the module, I got some > pretty normal messages, like: > > RocketPort device driver module, version 2.09, 12-June-2003 > ACPI: PCI Interrupt 0000:01:08.0[A] -> GSI 20 (level, low) -> IRQ 21 > Comtrol PCI controller #0 ID 0x802 found in bus:slot:fn 0000:01:08.0 at address d800, 1 AIOP(s) (RocketPort UPCI 8 port w/external I/F) > Installing RocketPort UPCI 8 port w/external I/F, creating /dev/ttyR0 - 7 > ACPI: PCI Interrupt 0000:02:06.0[A] -> GSI 24 (level, low) -> IRQ 22 > Comtrol PCI controller #1 ID 0x802 found in bus:slot:fn 0000:02:06.0 at address c800, 1 AIOP(s) (RocketPort UPCI 8 port w/external I/F) > Installing RocketPort UPCI 8 port w/external I/F, creating /dev/ttyR8 - 15 > > However, if I remove the module from the kernel, and then insert it > again, lots of error messages result: > > RocketPort device driver module, version 2.09, 12-June-2003 > Comtrol PCI controller #0 ID 0x802 found in bus:slot:fn 0000:01:08.0 at address d800, 1 AIOP(s) (RocketPort UPCI 8 port w/external I/F) > Installing RocketPort UPCI 8 port w/external I/F, creating /dev/ttyR0 - 7 > kobject_add failed for ttyR0 with -EEXIST, don't try to register things with the same name in the same directory. > [] kobject_shadow_add+0x156/0x188 > [] kobject_set_name+0x2b/0x92 > [] device_add+0x87/0x50f > [] kobject_init+0x2f/0x3f > [] device_create+0x77/0x97 > [] tty_register_device+0xb5/0xbd > [] init_r_port+0x5f1/0x623 [rocket] > [] pci_read+0x29/0x2e > [] rp_init+0xff7/0x111a [rocket] > [] __link_module+0x0/0x1f > [] sys_init_module+0x1470/0x15a9 > [] __request_region+0x0/0x80 > [] sysenter_past_esp+0x6b/0xa1 > ======================= > And so on for each device. > > However, the card seems to operate all right. Still, the messages > suggest something isn't quite right and could use some fixing. Hope > you can find the problem. Could you try the attached patch below? -- diff --git a/drivers/char/rocket.c b/drivers/char/rocket.c index 56cbba7..94bb3d0 100644 --- a/drivers/char/rocket.c +++ b/drivers/char/rocket.c @@ -699,8 +699,8 @@ static void init_r_port(int board, int aiop, int chan, struct pci_dev *pci_dev) spin_lock_init(&info->slock); mutex_init(&info->write_mtx); rp_table[line] = info; - if (pci_dev) - tty_register_device(rocket_driver, line, &pci_dev->dev); + tty_register_device(rocket_driver, line, pci_dev ? &pci_dev->dev : + NULL); } /* @@ -2434,7 +2434,7 @@ static int __init rp_init(void) rocket_driver->init_termios.c_ispeed = 9600; rocket_driver->init_termios.c_ospeed = 9600; #ifdef ROCKET_SOFT_FLOW - rocket_driver->flags |= TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV; + rocket_driver->flags |= TTY_DRIVER_REAL_RAW; #endif tty_set_operations(rocket_driver, &rocket_ops); @@ -2491,10 +2491,14 @@ static void rp_cleanup_module(void) if (retval) printk(KERN_INFO "Error %d while trying to unregister " "rocketport driver\n", -retval); - put_tty_driver(rocket_driver); for (i = 0; i < MAX_RP_PORTS; i++) - kfree(rp_table[i]); + if (rp_table[i]) { + tty_unregister_device(rocket_driver, i); + kfree(rp_table[i]); + } + + put_tty_driver(rocket_driver); for (i = 0; i < NUM_BOARDS; i++) { if (rcktpt_io_addr[i] <= 0 || is_PCI[i]) - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/