diff options
author | Dan Carpenter <dan.carpenter@oracle.com> | 2013-02-04 06:22:36 -0500 |
---|---|---|
committer | Roland Dreier <roland@purestorage.com> | 2013-02-15 18:22:26 -0500 |
commit | cab66d1273e6490603cf5256155584d38cecca68 (patch) | |
tree | 3c698a4645dd873c0f4ac025b4a4ccb005b3f1af /drivers/infiniband | |
parent | 836dc9e3fbbab0c30aa6e664417225f5c1fb1c39 (diff) |
IB/mlx4: Fix bug unwinding on error in mlx4_ib_init_sriov()
We have to decrement "i" before calling mlx4_ib_free_demux_ctx() or we
free something that wasn't allocated. That's fine for free_pv_object()
but it would lead to a NULL dereference calling mlx4_ib_free_demux_ctx().
The null dereference is because ->tun is NULL when we check:
if (!ctx->tun[i])
Also we didn't free ->sriov.demux[0] so it was a small leak.
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r-- | drivers/infiniband/hw/mlx4/mad.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/infiniband/hw/mlx4/mad.c b/drivers/infiniband/hw/mlx4/mad.c index 0a903c129f0a..934792c477bc 100644 --- a/drivers/infiniband/hw/mlx4/mad.c +++ b/drivers/infiniband/hw/mlx4/mad.c | |||
@@ -1999,16 +1999,17 @@ int mlx4_ib_init_sriov(struct mlx4_ib_dev *dev) | |||
1999 | goto demux_err; | 1999 | goto demux_err; |
2000 | err = mlx4_ib_alloc_demux_ctx(dev, &dev->sriov.demux[i], i + 1); | 2000 | err = mlx4_ib_alloc_demux_ctx(dev, &dev->sriov.demux[i], i + 1); |
2001 | if (err) | 2001 | if (err) |
2002 | goto demux_err; | 2002 | goto free_pv; |
2003 | } | 2003 | } |
2004 | mlx4_ib_master_tunnels(dev, 1); | 2004 | mlx4_ib_master_tunnels(dev, 1); |
2005 | return 0; | 2005 | return 0; |
2006 | 2006 | ||
2007 | free_pv: | ||
2008 | free_pv_object(dev, mlx4_master_func_num(dev->dev), i + 1); | ||
2007 | demux_err: | 2009 | demux_err: |
2008 | while (i > 0) { | 2010 | while (--i >= 0) { |
2009 | free_pv_object(dev, mlx4_master_func_num(dev->dev), i + 1); | 2011 | free_pv_object(dev, mlx4_master_func_num(dev->dev), i + 1); |
2010 | mlx4_ib_free_demux_ctx(&dev->sriov.demux[i]); | 2012 | mlx4_ib_free_demux_ctx(&dev->sriov.demux[i]); |
2011 | --i; | ||
2012 | } | 2013 | } |
2013 | mlx4_ib_device_unregister_sysfs(dev); | 2014 | mlx4_ib_device_unregister_sysfs(dev); |
2014 | 2015 | ||