diff options
| author | Alan Cox <alan@etchedpixels.co.uk> | 2009-06-02 11:58:10 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-06-02 12:53:22 -0400 |
| commit | 05ad709d04799125ed85dd816fdb558258102172 (patch) | |
| tree | a2fffcedd4d9178663175dcc3816d86734336505 | |
| parent | d3ae33efb8e2f277f9007eb060c9d0b91ab38ae1 (diff) | |
parport: quickfix the proc registration bug
Ideally we should have a directory of drivers and a link to the 'active'
driver. For now just show the first device which is effectively the existing
semantics without a warning.
This is an update on the original buggy patch that I then forgot to
resubmit. Confusingly it was proposed by Red Hat, written by Etched Pixels
fixed and submitted by Intel ...
Resolves-Bug: http://bugzilla.kernel.org/show_bug.cgi?id=9749
Signed-off-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
| -rw-r--r-- | drivers/parport/share.c | 13 | ||||
| -rw-r--r-- | include/linux/parport.h | 4 |
2 files changed, 14 insertions, 3 deletions
diff --git a/drivers/parport/share.c b/drivers/parport/share.c index 0ebca450ed29..dffa5d4fb298 100644 --- a/drivers/parport/share.c +++ b/drivers/parport/share.c | |||
| @@ -614,7 +614,10 @@ parport_register_device(struct parport *port, const char *name, | |||
| 614 | * pardevice fields. -arca | 614 | * pardevice fields. -arca |
| 615 | */ | 615 | */ |
| 616 | port->ops->init_state(tmp, tmp->state); | 616 | port->ops->init_state(tmp, tmp->state); |
| 617 | parport_device_proc_register(tmp); | 617 | if (!test_and_set_bit(PARPORT_DEVPROC_REGISTERED, &port->devflags)) { |
| 618 | port->proc_device = tmp; | ||
| 619 | parport_device_proc_register(tmp); | ||
| 620 | } | ||
| 618 | return tmp; | 621 | return tmp; |
| 619 | 622 | ||
| 620 | out_free_all: | 623 | out_free_all: |
| @@ -646,10 +649,14 @@ void parport_unregister_device(struct pardevice *dev) | |||
| 646 | } | 649 | } |
| 647 | #endif | 650 | #endif |
| 648 | 651 | ||
| 649 | parport_device_proc_unregister(dev); | ||
| 650 | |||
| 651 | port = dev->port->physport; | 652 | port = dev->port->physport; |
| 652 | 653 | ||
| 654 | if (port->proc_device == dev) { | ||
| 655 | port->proc_device = NULL; | ||
| 656 | clear_bit(PARPORT_DEVPROC_REGISTERED, &port->devflags); | ||
| 657 | parport_device_proc_unregister(dev); | ||
| 658 | } | ||
| 659 | |||
| 653 | if (port->cad == dev) { | 660 | if (port->cad == dev) { |
| 654 | printk(KERN_DEBUG "%s: %s forgot to release port\n", | 661 | printk(KERN_DEBUG "%s: %s forgot to release port\n", |
| 655 | port->name, dev->name); | 662 | port->name, dev->name); |
diff --git a/include/linux/parport.h b/include/linux/parport.h index e1f83c5065c5..38a423ed3c01 100644 --- a/include/linux/parport.h +++ b/include/linux/parport.h | |||
| @@ -324,6 +324,10 @@ struct parport { | |||
| 324 | int spintime; | 324 | int spintime; |
| 325 | atomic_t ref_count; | 325 | atomic_t ref_count; |
| 326 | 326 | ||
| 327 | unsigned long devflags; | ||
| 328 | #define PARPORT_DEVPROC_REGISTERED 0 | ||
| 329 | struct pardevice *proc_device; /* Currently register proc device */ | ||
| 330 | |||
| 327 | struct list_head full_list; | 331 | struct list_head full_list; |
| 328 | struct parport *slaves[3]; | 332 | struct parport *slaves[3]; |
| 329 | }; | 333 | }; |
