2006-08-23 11:37:42

by Akinobu Mita

[permalink] [raw]
Subject: call panic if nl_table allocation fails

This patch makes crash happen if initialization of nl_table fails
in initcalls. It is better than getting use after free crash later.

Cc: Patrick McHardy <[email protected]>
Cc: David Miller <[email protected]>
Signed-off-by: Akinobu Mita <[email protected]>

Index: work-failmalloc/net/netlink/af_netlink.c
===================================================================
--- work-failmalloc.orig/net/netlink/af_netlink.c
+++ work-failmalloc/net/netlink/af_netlink.c
@@ -1273,8 +1273,7 @@ netlink_kernel_create(int unit, unsigned
struct netlink_sock *nlk;
unsigned long *listeners = NULL;

- if (!nl_table)
- return NULL;
+ BUG_ON(!nl_table);

if (unit<0 || unit>=MAX_LINKS)
return NULL;
@@ -1745,11 +1744,8 @@ static int __init netlink_proto_init(voi
netlink_skb_parms_too_large();

nl_table = kcalloc(MAX_LINKS, sizeof(*nl_table), GFP_KERNEL);
- if (!nl_table) {
-enomem:
- printk(KERN_CRIT "netlink_init: Cannot allocate nl_table\n");
- return -ENOMEM;
- }
+ if (!nl_table)
+ goto panic;

if (num_physpages >= (128 * 1024))
max = num_physpages >> (21 - PAGE_SHIFT);
@@ -1769,7 +1765,7 @@ enomem:
nl_pid_hash_free(nl_table[i].hash.table,
1 * sizeof(*hash->table));
kfree(nl_table);
- goto enomem;
+ goto panic;
}
memset(hash->table, 0, 1 * sizeof(*hash->table));
hash->max_shift = order;
@@ -1786,6 +1782,8 @@ enomem:
rtnetlink_init();
out:
return err;
+panic:
+ panic("netlink_init: Cannot allocate nl_table\n");
}

core_initcall(netlink_proto_init);


2006-08-23 14:06:28

by James Morris

[permalink] [raw]
Subject: Re: call panic if nl_table allocation fails

On Wed, 23 Aug 2006, Akinobu Mita wrote:

> This patch makes crash happen if initialization of nl_table fails
> in initcalls. It is better than getting use after free crash later.

> nl_table = kcalloc(MAX_LINKS, sizeof(*nl_table), GFP_KERNEL);

Perhaps it'd be better to declare this as an array rather than allocating
it at runtime.



- James
--
James Morris
<[email protected]>

2006-08-23 14:17:11

by Patrick McHardy

[permalink] [raw]
Subject: Re: call panic if nl_table allocation fails

James Morris wrote:
> On Wed, 23 Aug 2006, Akinobu Mita wrote:
>
>
>>This patch makes crash happen if initialization of nl_table fails
>>in initcalls. It is better than getting use after free crash later.
>
>
>> nl_table = kcalloc(MAX_LINKS, sizeof(*nl_table), GFP_KERNEL);
>
>
> Perhaps it'd be better to declare this as an array rather than allocating
> it at runtime.

That would still leave the MAX_LINKS allocations for the pid hashes
which need to be allocated because they are dynamically sized. We
could delay the pid hash allocations until the first bind happens
of course, but I doubt it would be worth it since they start with
just a single bucket.

2006-08-29 09:16:15

by David Miller

[permalink] [raw]
Subject: Re: call panic if nl_table allocation fails

From: Akinobu Mita <[email protected]>
Date: Wed, 23 Aug 2006 20:37:40 +0900

> This patch makes crash happen if initialization of nl_table fails
> in initcalls. It is better than getting use after free crash later.
>
> Cc: Patrick McHardy <[email protected]>
> Cc: David Miller <[email protected]>
> Signed-off-by: Akinobu Mita <[email protected]>

Patch applied, thank you.