From 94bec7ffb6dc971261ab4da0f9b2bb63560047d2 Mon Sep 17 00:00:00 2001 From: Dan Carpenter Date: Mon, 4 Feb 2013 11:22:36 +0000 Subject: [PATCH] --- yaml --- r: 358873 b: refs/heads/master c: cab66d1273e6490603cf5256155584d38cecca68 h: refs/heads/master i: 358871: 141182116b5442f582414b7914b75f9268e60942 v: v3 --- [refs] | 2 +- trunk/drivers/infiniband/hw/amso1100/c2.c | 13 ++++++++++++- trunk/drivers/infiniband/hw/mlx4/mad.c | 7 ++++--- 3 files changed, 17 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index 7c27a2438fba..45742c401e5a 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 8ab10f75372fc59b95d96af40b9a3b4c2a0da059 +refs/heads/master: cab66d1273e6490603cf5256155584d38cecca68 diff --git a/trunk/drivers/infiniband/hw/amso1100/c2.c b/trunk/drivers/infiniband/hw/amso1100/c2.c index d53cf519f42a..7275e727e0f5 100644 --- a/trunk/drivers/infiniband/hw/amso1100/c2.c +++ b/trunk/drivers/infiniband/hw/amso1100/c2.c @@ -1238,4 +1238,15 @@ static struct pci_driver c2_pci_driver = { .remove = c2_remove, }; -module_pci_driver(c2_pci_driver); +static int __init c2_init_module(void) +{ + return pci_register_driver(&c2_pci_driver); +} + +static void __exit c2_exit_module(void) +{ + pci_unregister_driver(&c2_pci_driver); +} + +module_init(c2_init_module); +module_exit(c2_exit_module); diff --git a/trunk/drivers/infiniband/hw/mlx4/mad.c b/trunk/drivers/infiniband/hw/mlx4/mad.c index 0a903c129f0a..934792c477bc 100644 --- a/trunk/drivers/infiniband/hw/mlx4/mad.c +++ b/trunk/drivers/infiniband/hw/mlx4/mad.c @@ -1999,16 +1999,17 @@ int mlx4_ib_init_sriov(struct mlx4_ib_dev *dev) goto demux_err; err = mlx4_ib_alloc_demux_ctx(dev, &dev->sriov.demux[i], i + 1); if (err) - goto demux_err; + goto free_pv; } mlx4_ib_master_tunnels(dev, 1); return 0; +free_pv: + free_pv_object(dev, mlx4_master_func_num(dev->dev), i + 1); demux_err: - while (i > 0) { + while (--i >= 0) { free_pv_object(dev, mlx4_master_func_num(dev->dev), i + 1); mlx4_ib_free_demux_ctx(&dev->sriov.demux[i]); - --i; } mlx4_ib_device_unregister_sysfs(dev);