diff options
Diffstat (limited to 'net/netlabel')
| -rw-r--r-- | net/netlabel/netlabel_cipso_v4.c | 12 | ||||
| -rw-r--r-- | net/netlabel/netlabel_unlabeled.c | 6 | 
2 files changed, 8 insertions, 10 deletions
diff --git a/net/netlabel/netlabel_cipso_v4.c b/net/netlabel/netlabel_cipso_v4.c index baf235721c43..894e6b8f1a86 100644 --- a/net/netlabel/netlabel_cipso_v4.c +++ b/net/netlabel/netlabel_cipso_v4.c @@ -144,8 +144,8 @@ static int netlbl_cipsov4_add_std(struct genl_info *info,  		return -ENOMEM;  	doi_def->map.std = kzalloc(sizeof(*doi_def->map.std), GFP_KERNEL);  	if (doi_def->map.std == NULL) { -		ret_val = -ENOMEM; -		goto add_std_failure; +		kfree(doi_def); +		return -ENOMEM;  	}  	doi_def->type = CIPSO_V4_MAP_TRANS; @@ -187,14 +187,14 @@ static int netlbl_cipsov4_add_std(struct genl_info *info,  		}  	doi_def->map.std->lvl.local = kcalloc(doi_def->map.std->lvl.local_size,  					      sizeof(u32), -					      GFP_KERNEL); +					      GFP_KERNEL | __GFP_NOWARN);  	if (doi_def->map.std->lvl.local == NULL) {  		ret_val = -ENOMEM;  		goto add_std_failure;  	}  	doi_def->map.std->lvl.cipso = kcalloc(doi_def->map.std->lvl.cipso_size,  					      sizeof(u32), -					      GFP_KERNEL); +					      GFP_KERNEL | __GFP_NOWARN);  	if (doi_def->map.std->lvl.cipso == NULL) {  		ret_val = -ENOMEM;  		goto add_std_failure; @@ -263,7 +263,7 @@ static int netlbl_cipsov4_add_std(struct genl_info *info,  		doi_def->map.std->cat.local = kcalloc(  					      doi_def->map.std->cat.local_size,  					      sizeof(u32), -					      GFP_KERNEL); +					      GFP_KERNEL | __GFP_NOWARN);  		if (doi_def->map.std->cat.local == NULL) {  			ret_val = -ENOMEM;  			goto add_std_failure; @@ -271,7 +271,7 @@ static int netlbl_cipsov4_add_std(struct genl_info *info,  		doi_def->map.std->cat.cipso = kcalloc(  					      doi_def->map.std->cat.cipso_size,  					      sizeof(u32), -					      GFP_KERNEL); +					      GFP_KERNEL | __GFP_NOWARN);  		if (doi_def->map.std->cat.cipso == NULL) {  			ret_val = -ENOMEM;  			goto add_std_failure; diff --git a/net/netlabel/netlabel_unlabeled.c b/net/netlabel/netlabel_unlabeled.c index 2483df0bbd7c..566ba4397ee4 100644 --- a/net/netlabel/netlabel_unlabeled.c +++ b/net/netlabel/netlabel_unlabeled.c @@ -492,8 +492,7 @@ static int netlbl_unlhsh_remove_addr4(struct net *net,  		netlbl_af4list_audit_addr(audit_buf, 1,  					  (dev != NULL ? dev->name : NULL),  					  addr->s_addr, mask->s_addr); -		if (dev != NULL) -			dev_put(dev); +		dev_put(dev);  		if (entry != NULL &&  		    security_secid_to_secctx(entry->secid,  					     &secctx, &secctx_len) == 0) { @@ -553,8 +552,7 @@ static int netlbl_unlhsh_remove_addr6(struct net *net,  		netlbl_af6list_audit_addr(audit_buf, 1,  					  (dev != NULL ? dev->name : NULL),  					  addr, mask); -		if (dev != NULL) -			dev_put(dev); +		dev_put(dev);  		if (entry != NULL &&  		    security_secid_to_secctx(entry->secid,  					     &secctx, &secctx_len) == 0) {  | 
