diff options
| author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-29 18:54:48 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-29 18:54:48 -0700 | 
| commit | bf603625660b1742004bf86432ce3c210d14d4fd (patch) | |
| tree | db327975e92e01f2f2badb8ec5ae55282f156674 /net/netlabel/netlabel_mgmt.c | |
| parent | fbe96f92b3d9450e77a3a4bb1d46aa1bb908c1ab (diff) | |
| parent | 6656e3c4c8e0c80f2d2bfece574876d269f64861 (diff) | |
| download | blackbird-op-linux-bf603625660b1742004bf86432ce3c210d14d4fd.tar.gz blackbird-op-linux-bf603625660b1742004bf86432ce3c210d14d4fd.zip | |
Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
* master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6:
  [ATM]: [lec] use refcnt to protect lec_arp_entries outside lock
  [ATM]: [lec] add reference counting to lec_arp entries
  [ATM]: [lec] use work queue instead of timer for lec arp expiry
  [ATM]: [lec] old_close is no longer used
  [ATM]: [lec] convert lec_arp_table to hlist
  [ATM]: [lec] header indent, comment and whitespace cleanup
  [ATM]: [lec] indent, comment and whitespace cleanup [continued]
  [ATM]: [lec] indent, comment and whitespace cleanup
  [SCTP]: Do not timestamp every SCTP packet.
  [SCTP]: Use correct mask when disabling PMTUD.
  [SCTP]: Include sk_buff overhead while updating the peer's receive window.
  [SCTP]: Enable Nagle algorithm by default.
  [BNX2]: Disable MSI on 5706 if AMD 8132 bridge is present.
  [NetLabel]: audit fixups due to delayed feedback
Diffstat (limited to 'net/netlabel/netlabel_mgmt.c')
| -rw-r--r-- | net/netlabel/netlabel_mgmt.c | 27 | 
1 files changed, 19 insertions, 8 deletions
| diff --git a/net/netlabel/netlabel_mgmt.c b/net/netlabel/netlabel_mgmt.c index 0ac314f18ad1..53c9079ad2c3 100644 --- a/net/netlabel/netlabel_mgmt.c +++ b/net/netlabel/netlabel_mgmt.c @@ -87,11 +87,14 @@ static int netlbl_mgmt_add(struct sk_buff *skb, struct genl_info *info)  	struct netlbl_dom_map *entry = NULL;  	size_t tmp_size;  	u32 tmp_val; +	struct netlbl_audit audit_info;  	if (!info->attrs[NLBL_MGMT_A_DOMAIN] ||  	    !info->attrs[NLBL_MGMT_A_PROTOCOL])  		goto add_failure; +	netlbl_netlink_auditinfo(skb, &audit_info); +  	entry = kzalloc(sizeof(*entry), GFP_KERNEL);  	if (entry == NULL) {  		ret_val = -ENOMEM; @@ -108,7 +111,7 @@ static int netlbl_mgmt_add(struct sk_buff *skb, struct genl_info *info)  	switch (entry->type) {  	case NETLBL_NLTYPE_UNLABELED: -		ret_val = netlbl_domhsh_add(entry, NETLINK_CB(skb).sid); +		ret_val = netlbl_domhsh_add(entry, &audit_info);  		break;  	case NETLBL_NLTYPE_CIPSOV4:  		if (!info->attrs[NLBL_MGMT_A_CV4DOI]) @@ -125,7 +128,7 @@ static int netlbl_mgmt_add(struct sk_buff *skb, struct genl_info *info)  			rcu_read_unlock();  			goto add_failure;  		} -		ret_val = netlbl_domhsh_add(entry, NETLINK_CB(skb).sid); +		ret_val = netlbl_domhsh_add(entry, &audit_info);  		rcu_read_unlock();  		break;  	default: @@ -156,12 +159,15 @@ add_failure:  static int netlbl_mgmt_remove(struct sk_buff *skb, struct genl_info *info)  {  	char *domain; +	struct netlbl_audit audit_info;  	if (!info->attrs[NLBL_MGMT_A_DOMAIN])  		return -EINVAL; +	netlbl_netlink_auditinfo(skb, &audit_info); +  	domain = nla_data(info->attrs[NLBL_MGMT_A_DOMAIN]); -	return netlbl_domhsh_remove(domain, NETLINK_CB(skb).sid); +	return netlbl_domhsh_remove(domain, &audit_info);  }  /** @@ -264,10 +270,13 @@ static int netlbl_mgmt_adddef(struct sk_buff *skb, struct genl_info *info)  	int ret_val = -EINVAL;  	struct netlbl_dom_map *entry = NULL;  	u32 tmp_val; +	struct netlbl_audit audit_info;  	if (!info->attrs[NLBL_MGMT_A_PROTOCOL])  		goto adddef_failure; +	netlbl_netlink_auditinfo(skb, &audit_info); +  	entry = kzalloc(sizeof(*entry), GFP_KERNEL);  	if (entry == NULL) {  		ret_val = -ENOMEM; @@ -277,8 +286,7 @@ static int netlbl_mgmt_adddef(struct sk_buff *skb, struct genl_info *info)  	switch (entry->type) {  	case NETLBL_NLTYPE_UNLABELED: -		ret_val = netlbl_domhsh_add_default(entry, -						    NETLINK_CB(skb).sid); +		ret_val = netlbl_domhsh_add_default(entry, &audit_info);  		break;  	case NETLBL_NLTYPE_CIPSOV4:  		if (!info->attrs[NLBL_MGMT_A_CV4DOI]) @@ -295,8 +303,7 @@ static int netlbl_mgmt_adddef(struct sk_buff *skb, struct genl_info *info)  			rcu_read_unlock();  			goto adddef_failure;  		} -		ret_val = netlbl_domhsh_add_default(entry, -						    NETLINK_CB(skb).sid); +		ret_val = netlbl_domhsh_add_default(entry, &audit_info);  		rcu_read_unlock();  		break;  	default: @@ -324,7 +331,11 @@ adddef_failure:   */  static int netlbl_mgmt_removedef(struct sk_buff *skb, struct genl_info *info)  { -	return netlbl_domhsh_remove_default(NETLINK_CB(skb).sid); +	struct netlbl_audit audit_info; + +	netlbl_netlink_auditinfo(skb, &audit_info); + +	return netlbl_domhsh_remove_default(&audit_info);  }  /** | 

