datapath: small potential memory leak in ovs_vport_alloc()
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 6 Dec 2011 19:08:25 +0000 (11:08 -0800)
committerJesse Gross <jesse@nicira.com>
Tue, 6 Dec 2011 19:12:24 +0000 (11:12 -0800)
We're unlikely to hit this leak, but the static checkers complain if we
don't take care of it.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Jesse Gross <jesse@nicira.com>
datapath/vport.c

index ad5a10e..2e36803 100644 (file)
@@ -185,8 +185,10 @@ struct vport *vport_alloc(int priv_size, const struct vport_ops *ops, const stru
        kobject_init(&vport->kobj, &brport_ktype);
 
        vport->percpu_stats = alloc_percpu(struct vport_percpu_stats);
-       if (!vport->percpu_stats)
+       if (!vport->percpu_stats) {
+               kfree(vport);
                return ERR_PTR(-ENOMEM);
+       }
 
        spin_lock_init(&vport->stats_lock);