aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorRoland Dreier <roland@purestorage.com>2012-05-02 18:42:33 -0400
committerRoland Dreier <roland@purestorage.com>2012-05-08 14:17:49 -0400
commit349556692df946b9cd5b84f2b0fa09b98732e986 (patch)
tree3c887f8b85e864b103aff9a56c75c8f756185470 /drivers/infiniband
parentd19081e044356ae6464e939aef04514c5e227b5a (diff)
RDMA/ocrdma: Fix build with IPV6=n
When IPV6 is not enabled: ERROR: "register_inet6addr_notifier" [drivers/infiniband/hw/ocrdma/ocrdma.ko] undefined! ERROR: "unregister_inet6addr_notifier" [drivers/infiniband/hw/ocrdma/ocrdma.ko] undefined! Fix this by wrapping the inet6 calls in #ifdef IPV6. Also make the ocrdma module depend on (IPV6 || IPV6=n) to forbid the case of modular ipv6 but built-in ocrdma (which can't work, because ocrdma calls ipv6 functions). Reported-by: Randy Dunlap <rdunlap@xenotime.net> Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/hw/ocrdma/Kconfig2
-rw-r--r--drivers/infiniband/hw/ocrdma/ocrdma_main.c29
2 files changed, 22 insertions, 9 deletions
diff --git a/drivers/infiniband/hw/ocrdma/Kconfig b/drivers/infiniband/hw/ocrdma/Kconfig
index cf993424e2fb..b5b6056c8518 100644
--- a/drivers/infiniband/hw/ocrdma/Kconfig
+++ b/drivers/infiniband/hw/ocrdma/Kconfig
@@ -1,6 +1,6 @@
1config INFINIBAND_OCRDMA 1config INFINIBAND_OCRDMA
2 tristate "Emulex One Connect HCA support" 2 tristate "Emulex One Connect HCA support"
3 depends on ETHERNET && NETDEVICES && PCI 3 depends on ETHERNET && NETDEVICES && PCI && (IPV6 || IPV6=n)
4 select NET_VENDOR_EMULEX 4 select NET_VENDOR_EMULEX
5 select BE2NET 5 select BE2NET
6 ---help--- 6 ---help---
diff --git a/drivers/infiniband/hw/ocrdma/ocrdma_main.c b/drivers/infiniband/hw/ocrdma/ocrdma_main.c
index 0bc1efb02ff5..a20d16eaae71 100644
--- a/drivers/infiniband/hw/ocrdma/ocrdma_main.c
+++ b/drivers/infiniband/hw/ocrdma/ocrdma_main.c
@@ -51,12 +51,6 @@ static DEFINE_SPINLOCK(ocrdma_devlist_lock);
51static DEFINE_IDR(ocrdma_dev_id); 51static DEFINE_IDR(ocrdma_dev_id);
52 52
53static union ib_gid ocrdma_zero_sgid; 53static union ib_gid ocrdma_zero_sgid;
54static int ocrdma_inet6addr_event(struct notifier_block *,
55 unsigned long, void *);
56
57static struct notifier_block ocrdma_inet6addr_notifier = {
58 .notifier_call = ocrdma_inet6addr_event
59};
60 54
61static int ocrdma_get_instance(void) 55static int ocrdma_get_instance(void)
62{ 56{
@@ -204,6 +198,8 @@ static int ocrdma_build_sgid_tbl(struct ocrdma_dev *dev)
204 return 0; 198 return 0;
205} 199}
206 200
201#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
202
207static int ocrdma_inet6addr_event(struct notifier_block *notifier, 203static int ocrdma_inet6addr_event(struct notifier_block *notifier,
208 unsigned long event, void *ptr) 204 unsigned long event, void *ptr)
209{ 205{
@@ -259,6 +255,12 @@ static int ocrdma_inet6addr_event(struct notifier_block *notifier,
259 return NOTIFY_OK; 255 return NOTIFY_OK;
260} 256}
261 257
258static struct notifier_block ocrdma_inet6addr_notifier = {
259 .notifier_call = ocrdma_inet6addr_event
260};
261
262#endif /* IPV6 */
263
262static enum rdma_link_layer ocrdma_link_layer(struct ib_device *device, 264static enum rdma_link_layer ocrdma_link_layer(struct ib_device *device,
263 u8 port_num) 265 u8 port_num)
264{ 266{
@@ -541,23 +543,34 @@ static struct ocrdma_driver ocrdma_drv = {
541 .state_change_handler = ocrdma_event_handler, 543 .state_change_handler = ocrdma_event_handler,
542}; 544};
543 545
546static void ocrdma_unregister_inet6addr_notifier(void)
547{
548#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
549 unregister_inet6addr_notifier(&ocrdma_inet6addr_notifier);
550#endif
551}
552
544static int __init ocrdma_init_module(void) 553static int __init ocrdma_init_module(void)
545{ 554{
546 int status; 555 int status;
547 556
557#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
548 status = register_inet6addr_notifier(&ocrdma_inet6addr_notifier); 558 status = register_inet6addr_notifier(&ocrdma_inet6addr_notifier);
549 if (status) 559 if (status)
550 return status; 560 return status;
561#endif
562
551 status = be_roce_register_driver(&ocrdma_drv); 563 status = be_roce_register_driver(&ocrdma_drv);
552 if (status) 564 if (status)
553 unregister_inet6addr_notifier(&ocrdma_inet6addr_notifier); 565 ocrdma_unregister_inet6addr_notifier();
566
554 return status; 567 return status;
555} 568}
556 569
557static void __exit ocrdma_exit_module(void) 570static void __exit ocrdma_exit_module(void)
558{ 571{
559 be_roce_unregister_driver(&ocrdma_drv); 572 be_roce_unregister_driver(&ocrdma_drv);
560 unregister_inet6addr_notifier(&ocrdma_inet6addr_notifier); 573 ocrdma_unregister_inet6addr_notifier();
561} 574}
562 575
563module_init(ocrdma_init_module); 576module_init(ocrdma_init_module);