aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ieee1394/eth1394.c
diff options
context:
space:
mode:
authorStefan Richter <stefanr@s5r6.in-berlin.de>2007-03-26 19:36:50 -0400
committerStefan Richter <stefanr@s5r6.in-berlin.de>2007-04-29 18:00:30 -0400
commit70093cfde8af52b0b9030d90f9004cbde38f2ff8 (patch)
treef9230ca354e78b129898298095a6ee887c40a16d /drivers/ieee1394/eth1394.c
parente00f04a70fa387b3accc81b5c346200f836e2a52 (diff)
ieee1394: eth1394: don't autoload by hotplug when ohci1394 starts
Until now, ieee1394 put an IP-over-1394 capability entry into each new host's config ROM. As soon as the controller was initialized --- i.e. right after modprobe ohci1394 --- this entry triggered a hotplug event which typically caused auto-loading of eth1394. This irritated or annoyed many users and distributors. Of course they could blacklist eth1394, but then ieee1394 wrongly advertized IP-over- 1394 capability to the FireWire bus. Therefore - remove the offending kernel config option IEEE1394_CONFIG_ROM_IP1394, - let eth1394 add the ROM entry by itself, i.e. only after eth1394 was loaded. This fixes http://bugzilla.kernel.org/show_bug.cgi?id=7793 . To emulate the behaviour of older kernels, simply add the following to to /etc/modprobe.conf: install ohci1394 /sbin/modprobe eth1394; \ /sbin/modprobe --ignore-install ohci1394 Note, autoloading of eth1394 when an _external_ IP-over-1394 capable device is discovered is _not_ affected by this patch. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers/ieee1394/eth1394.c')
-rw-r--r--drivers/ieee1394/eth1394.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/ieee1394/eth1394.c b/drivers/ieee1394/eth1394.c
index d056c5953be3..b4fa754bfd1a 100644
--- a/drivers/ieee1394/eth1394.c
+++ b/drivers/ieee1394/eth1394.c
@@ -561,8 +561,10 @@ static void ether1394_add_host (struct hpsb_host *host)
561 struct eth1394_priv *priv; 561 struct eth1394_priv *priv;
562 u64 fifo_addr; 562 u64 fifo_addr;
563 563
564 if (!(host->config_roms & HPSB_CONFIG_ROM_ENTRY_IP1394)) 564 if (hpsb_config_rom_ip1394_add(host) != 0) {
565 ETH1394_PRINT_G(KERN_ERR, "Can't add IP-over-1394 ROM entry\n");
565 return; 566 return;
567 }
566 568
567 fifo_addr = hpsb_allocate_and_register_addrspace( 569 fifo_addr = hpsb_allocate_and_register_addrspace(
568 &eth1394_highlevel, host, &addr_ops, 570 &eth1394_highlevel, host, &addr_ops,
@@ -570,6 +572,7 @@ static void ether1394_add_host (struct hpsb_host *host)
570 CSR1212_INVALID_ADDR_SPACE, CSR1212_INVALID_ADDR_SPACE); 572 CSR1212_INVALID_ADDR_SPACE, CSR1212_INVALID_ADDR_SPACE);
571 if (fifo_addr == CSR1212_INVALID_ADDR_SPACE) { 573 if (fifo_addr == CSR1212_INVALID_ADDR_SPACE) {
572 ETH1394_PRINT_G(KERN_ERR, "Cannot register CSR space\n"); 574 ETH1394_PRINT_G(KERN_ERR, "Cannot register CSR space\n");
575 hpsb_config_rom_ip1394_remove(host);
573 return; 576 return;
574 } 577 }
575 578
@@ -649,6 +652,7 @@ out:
649 if (hi) 652 if (hi)
650 hpsb_destroy_hostinfo(&eth1394_highlevel, host); 653 hpsb_destroy_hostinfo(&eth1394_highlevel, host);
651 hpsb_unregister_addrspace(&eth1394_highlevel, host, fifo_addr); 654 hpsb_unregister_addrspace(&eth1394_highlevel, host, fifo_addr);
655 hpsb_config_rom_ip1394_remove(host);
652} 656}
653 657
654/* Remove a card from our list */ 658/* Remove a card from our list */
@@ -662,6 +666,7 @@ static void ether1394_remove_host (struct hpsb_host *host)
662 return; 666 return;
663 priv = netdev_priv(hi->dev); 667 priv = netdev_priv(hi->dev);
664 hpsb_unregister_addrspace(&eth1394_highlevel, host, priv->local_fifo); 668 hpsb_unregister_addrspace(&eth1394_highlevel, host, priv->local_fifo);
669 hpsb_config_rom_ip1394_remove(host);
665 if (priv->iso) 670 if (priv->iso)
666 hpsb_iso_shutdown(priv->iso); 671 hpsb_iso_shutdown(priv->iso);
667 unregister_netdev(hi->dev); 672 unregister_netdev(hi->dev);