netfilter: Remove unnecessary OOM logging messages

Site specific OOM messages are duplications of a generic MM
out of memory message and aren't really useful, so just
delete them.

Signed-off-by: Joe Perches <joe@perches.com>
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
This commit is contained in:
Joe Perches 2011-08-29 14:17:25 -07:00 committed by Pablo Neira Ayuso
parent 40cb1f9bc5
commit 0a9ee81349
18 changed files with 37 additions and 92 deletions

View File

@ -102,16 +102,15 @@ static struct sk_buff *ulog_alloc_skb(unsigned int size)
unsigned int n; unsigned int n;
n = max(size, nlbufsiz); n = max(size, nlbufsiz);
skb = alloc_skb(n, GFP_ATOMIC); skb = alloc_skb(n, GFP_ATOMIC | __GFP_NOWARN);
if (!skb) { if (!skb) {
pr_debug("cannot alloc whole buffer of size %ub!\n", n);
if (n > size) { if (n > size) {
/* try to allocate only as much as we need for /* try to allocate only as much as we need for
* current packet */ * current packet */
skb = alloc_skb(size, GFP_ATOMIC); skb = alloc_skb(size, GFP_ATOMIC);
if (!skb) if (!skb)
pr_debug("cannot even allocate " pr_debug("cannot even allocate buffer of size %ub\n",
"buffer of size %ub\n", size); size);
} }
} }

View File

@ -395,7 +395,6 @@ static int clusterip_tg_check(const struct xt_tgchk_param *par)
config = clusterip_config_init(cipinfo, config = clusterip_config_init(cipinfo,
e->ip.dst.s_addr, dev); e->ip.dst.s_addr, dev);
if (!config) { if (!config) {
pr_info("cannot allocate config\n");
dev_put(dev); dev_put(dev);
return -ENOMEM; return -ENOMEM;
} }

View File

@ -135,10 +135,8 @@ static struct sk_buff *ulog_alloc_skb(unsigned int size)
* due to slab allocator restrictions */ * due to slab allocator restrictions */
n = max(size, nlbufsiz); n = max(size, nlbufsiz);
skb = alloc_skb(n, GFP_ATOMIC); skb = alloc_skb(n, GFP_ATOMIC | __GFP_NOWARN);
if (!skb) { if (!skb) {
pr_debug("cannot alloc whole buffer %ub!\n", n);
if (n > size) { if (n > size) {
/* try to allocate only as much as we need for /* try to allocate only as much as we need for
* current packet */ * current packet */

View File

@ -400,11 +400,8 @@ static unsigned char asn1_octets_decode(struct asn1_ctx *ctx,
*len = 0; *len = 0;
*octets = kmalloc(eoc - ctx->pointer, GFP_ATOMIC); *octets = kmalloc(eoc - ctx->pointer, GFP_ATOMIC);
if (*octets == NULL) { if (*octets == NULL)
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
}
ptr = *octets; ptr = *octets;
while (ctx->pointer < eoc) { while (ctx->pointer < eoc) {
@ -451,11 +448,8 @@ static unsigned char asn1_oid_decode(struct asn1_ctx *ctx,
return 0; return 0;
*oid = kmalloc(size * sizeof(unsigned long), GFP_ATOMIC); *oid = kmalloc(size * sizeof(unsigned long), GFP_ATOMIC);
if (*oid == NULL) { if (*oid == NULL)
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
}
optr = *oid; optr = *oid;
@ -728,8 +722,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
*obj = kmalloc(sizeof(struct snmp_object) + len, GFP_ATOMIC); *obj = kmalloc(sizeof(struct snmp_object) + len, GFP_ATOMIC);
if (*obj == NULL) { if (*obj == NULL) {
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
(*obj)->syntax.l[0] = l; (*obj)->syntax.l[0] = l;
@ -744,8 +736,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
if (*obj == NULL) { if (*obj == NULL) {
kfree(p); kfree(p);
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
memcpy((*obj)->syntax.c, p, len); memcpy((*obj)->syntax.c, p, len);
@ -759,8 +749,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
*obj = kmalloc(sizeof(struct snmp_object), GFP_ATOMIC); *obj = kmalloc(sizeof(struct snmp_object), GFP_ATOMIC);
if (*obj == NULL) { if (*obj == NULL) {
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
if (!asn1_null_decode(ctx, end)) { if (!asn1_null_decode(ctx, end)) {
@ -780,8 +768,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
if (*obj == NULL) { if (*obj == NULL) {
kfree(lp); kfree(lp);
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
memcpy((*obj)->syntax.ul, lp, len); memcpy((*obj)->syntax.ul, lp, len);
@ -801,8 +787,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
if (*obj == NULL) { if (*obj == NULL) {
kfree(p); kfree(p);
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
memcpy((*obj)->syntax.uc, p, len); memcpy((*obj)->syntax.uc, p, len);
@ -819,8 +803,6 @@ static unsigned char snmp_object_decode(struct asn1_ctx *ctx,
*obj = kmalloc(sizeof(struct snmp_object) + len, GFP_ATOMIC); *obj = kmalloc(sizeof(struct snmp_object) + len, GFP_ATOMIC);
if (*obj == NULL) { if (*obj == NULL) {
kfree(id); kfree(id);
if (net_ratelimit())
pr_notice("OOM in bsalg (%d)\n", __LINE__);
return 0; return 0;
} }
(*obj)->syntax.ul[0] = ul; (*obj)->syntax.ul[0] = ul;

View File

@ -182,7 +182,6 @@ fq_find(__be32 id, u32 user, struct in6_addr *src, struct in6_addr *dst)
return container_of(q, struct nf_ct_frag6_queue, q); return container_of(q, struct nf_ct_frag6_queue, q);
oom: oom:
pr_debug("Can't alloc new queue\n");
return NULL; return NULL;
} }
@ -370,10 +369,10 @@ nf_ct_frag6_reasm(struct nf_ct_frag6_queue *fq, struct net_device *dev)
struct sk_buff *clone; struct sk_buff *clone;
int i, plen = 0; int i, plen = 0;
if ((clone = alloc_skb(0, GFP_ATOMIC)) == NULL) { clone = alloc_skb(0, GFP_ATOMIC);
pr_debug("Can't alloc skb\n"); if (clone == NULL)
goto out_oom; goto out_oom;
}
clone->next = head->next; clone->next = head->next;
head->next = clone; head->next = clone;
skb_shinfo(clone)->frag_list = skb_shinfo(head)->frag_list; skb_shinfo(clone)->frag_list = skb_shinfo(head)->frag_list;

View File

@ -1699,10 +1699,8 @@ ip_set_init(void)
ip_set_list = kzalloc(sizeof(struct ip_set *) * ip_set_max, ip_set_list = kzalloc(sizeof(struct ip_set *) * ip_set_max,
GFP_KERNEL); GFP_KERNEL);
if (!ip_set_list) { if (!ip_set_list)
pr_err("ip_set: Unable to create ip_set_list\n");
return -ENOMEM; return -ENOMEM;
}
ret = nfnetlink_subsys_register(&ip_set_netlink_subsys); ret = nfnetlink_subsys_register(&ip_set_netlink_subsys);
if (ret != 0) { if (ret != 0) {

View File

@ -1877,10 +1877,9 @@ static int __net_init __ip_vs_init(struct net *net)
struct netns_ipvs *ipvs; struct netns_ipvs *ipvs;
ipvs = net_generic(net, ip_vs_net_id); ipvs = net_generic(net, ip_vs_net_id);
if (ipvs == NULL) { if (ipvs == NULL)
pr_err("%s(): no memory.\n", __func__);
return -ENOMEM; return -ENOMEM;
}
/* Hold the beast until a service is registerd */ /* Hold the beast until a service is registerd */
ipvs->enable = 0; ipvs->enable = 0;
ipvs->net = net; ipvs->net = net;

View File

@ -856,15 +856,12 @@ ip_vs_new_dest(struct ip_vs_service *svc, struct ip_vs_dest_user_kern *udest,
} }
dest = kzalloc(sizeof(struct ip_vs_dest), GFP_KERNEL); dest = kzalloc(sizeof(struct ip_vs_dest), GFP_KERNEL);
if (dest == NULL) { if (dest == NULL)
pr_err("%s(): no memory.\n", __func__);
return -ENOMEM; return -ENOMEM;
}
dest->stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats); dest->stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats);
if (!dest->stats.cpustats) { if (!dest->stats.cpustats)
pr_err("%s() alloc_percpu failed\n", __func__);
goto err_alloc; goto err_alloc;
}
dest->af = svc->af; dest->af = svc->af;
dest->protocol = svc->protocol; dest->protocol = svc->protocol;
@ -1168,10 +1165,8 @@ ip_vs_add_service(struct net *net, struct ip_vs_service_user_kern *u,
goto out_err; goto out_err;
} }
svc->stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats); svc->stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats);
if (!svc->stats.cpustats) { if (!svc->stats.cpustats)
pr_err("%s() alloc_percpu failed\n", __func__);
goto out_err; goto out_err;
}
/* I'm the first user of the service */ /* I'm the first user of the service */
atomic_set(&svc->usecnt, 0); atomic_set(&svc->usecnt, 0);
@ -3716,10 +3711,9 @@ int __net_init ip_vs_control_net_init(struct net *net)
/* procfs stats */ /* procfs stats */
ipvs->tot_stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats); ipvs->tot_stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats);
if (!ipvs->tot_stats.cpustats) { if (!ipvs->tot_stats.cpustats)
pr_err("%s(): alloc_percpu.\n", __func__);
return -ENOMEM; return -ENOMEM;
}
spin_lock_init(&ipvs->tot_stats.lock); spin_lock_init(&ipvs->tot_stats.lock);
proc_net_fops_create(net, "ip_vs", 0, &ip_vs_info_fops); proc_net_fops_create(net, "ip_vs", 0, &ip_vs_info_fops);

View File

@ -150,10 +150,9 @@ static int ip_vs_dh_init_svc(struct ip_vs_service *svc)
/* allocate the DH table for this service */ /* allocate the DH table for this service */
tbl = kmalloc(sizeof(struct ip_vs_dh_bucket)*IP_VS_DH_TAB_SIZE, tbl = kmalloc(sizeof(struct ip_vs_dh_bucket)*IP_VS_DH_TAB_SIZE,
GFP_ATOMIC); GFP_ATOMIC);
if (tbl == NULL) { if (tbl == NULL)
pr_err("%s(): no memory\n", __func__);
return -ENOMEM; return -ENOMEM;
}
svc->sched_data = tbl; svc->sched_data = tbl;
IP_VS_DBG(6, "DH hash table (memory=%Zdbytes) allocated for " IP_VS_DBG(6, "DH hash table (memory=%Zdbytes) allocated for "
"current service\n", "current service\n",

View File

@ -202,10 +202,8 @@ ip_vs_lblc_new(struct ip_vs_lblc_table *tbl, const union nf_inet_addr *daddr,
en = ip_vs_lblc_get(dest->af, tbl, daddr); en = ip_vs_lblc_get(dest->af, tbl, daddr);
if (!en) { if (!en) {
en = kmalloc(sizeof(*en), GFP_ATOMIC); en = kmalloc(sizeof(*en), GFP_ATOMIC);
if (!en) { if (!en)
pr_err("%s(): no memory\n", __func__);
return NULL; return NULL;
}
en->af = dest->af; en->af = dest->af;
ip_vs_addr_copy(dest->af, &en->addr, daddr); ip_vs_addr_copy(dest->af, &en->addr, daddr);
@ -345,10 +343,9 @@ static int ip_vs_lblc_init_svc(struct ip_vs_service *svc)
* Allocate the ip_vs_lblc_table for this service * Allocate the ip_vs_lblc_table for this service
*/ */
tbl = kmalloc(sizeof(*tbl), GFP_ATOMIC); tbl = kmalloc(sizeof(*tbl), GFP_ATOMIC);
if (tbl == NULL) { if (tbl == NULL)
pr_err("%s(): no memory\n", __func__);
return -ENOMEM; return -ENOMEM;
}
svc->sched_data = tbl; svc->sched_data = tbl;
IP_VS_DBG(6, "LBLC hash table (memory=%Zdbytes) allocated for " IP_VS_DBG(6, "LBLC hash table (memory=%Zdbytes) allocated for "
"current service\n", sizeof(*tbl)); "current service\n", sizeof(*tbl));

View File

@ -112,10 +112,8 @@ ip_vs_dest_set_insert(struct ip_vs_dest_set *set, struct ip_vs_dest *dest)
} }
e = kmalloc(sizeof(*e), GFP_ATOMIC); e = kmalloc(sizeof(*e), GFP_ATOMIC);
if (e == NULL) { if (e == NULL)
pr_err("%s(): no memory\n", __func__);
return NULL; return NULL;
}
atomic_inc(&dest->refcnt); atomic_inc(&dest->refcnt);
e->dest = dest; e->dest = dest;
@ -373,10 +371,8 @@ ip_vs_lblcr_new(struct ip_vs_lblcr_table *tbl, const union nf_inet_addr *daddr,
en = ip_vs_lblcr_get(dest->af, tbl, daddr); en = ip_vs_lblcr_get(dest->af, tbl, daddr);
if (!en) { if (!en) {
en = kmalloc(sizeof(*en), GFP_ATOMIC); en = kmalloc(sizeof(*en), GFP_ATOMIC);
if (!en) { if (!en)
pr_err("%s(): no memory\n", __func__);
return NULL; return NULL;
}
en->af = dest->af; en->af = dest->af;
ip_vs_addr_copy(dest->af, &en->addr, daddr); ip_vs_addr_copy(dest->af, &en->addr, daddr);
@ -516,10 +512,9 @@ static int ip_vs_lblcr_init_svc(struct ip_vs_service *svc)
* Allocate the ip_vs_lblcr_table for this service * Allocate the ip_vs_lblcr_table for this service
*/ */
tbl = kmalloc(sizeof(*tbl), GFP_ATOMIC); tbl = kmalloc(sizeof(*tbl), GFP_ATOMIC);
if (tbl == NULL) { if (tbl == NULL)
pr_err("%s(): no memory\n", __func__);
return -ENOMEM; return -ENOMEM;
}
svc->sched_data = tbl; svc->sched_data = tbl;
IP_VS_DBG(6, "LBLCR hash table (memory=%Zdbytes) allocated for " IP_VS_DBG(6, "LBLCR hash table (memory=%Zdbytes) allocated for "
"current service\n", sizeof(*tbl)); "current service\n", sizeof(*tbl));

View File

@ -74,10 +74,9 @@ register_ip_vs_proto_netns(struct net *net, struct ip_vs_protocol *pp)
struct ip_vs_proto_data *pd = struct ip_vs_proto_data *pd =
kzalloc(sizeof(struct ip_vs_proto_data), GFP_ATOMIC); kzalloc(sizeof(struct ip_vs_proto_data), GFP_ATOMIC);
if (!pd) { if (!pd)
pr_err("%s(): no memory.\n", __func__);
return -ENOMEM; return -ENOMEM;
}
pd->pp = pp; /* For speed issues */ pd->pp = pp; /* For speed issues */
pd->next = ipvs->proto_data_table[hash]; pd->next = ipvs->proto_data_table[hash];
ipvs->proto_data_table[hash] = pd; ipvs->proto_data_table[hash] = pd;

View File

@ -147,10 +147,9 @@ static int ip_vs_sh_init_svc(struct ip_vs_service *svc)
/* allocate the SH table for this service */ /* allocate the SH table for this service */
tbl = kmalloc(sizeof(struct ip_vs_sh_bucket)*IP_VS_SH_TAB_SIZE, tbl = kmalloc(sizeof(struct ip_vs_sh_bucket)*IP_VS_SH_TAB_SIZE,
GFP_ATOMIC); GFP_ATOMIC);
if (tbl == NULL) { if (tbl == NULL)
pr_err("%s(): no memory\n", __func__);
return -ENOMEM; return -ENOMEM;
}
svc->sched_data = tbl; svc->sched_data = tbl;
IP_VS_DBG(6, "SH hash table (memory=%Zdbytes) allocated for " IP_VS_DBG(6, "SH hash table (memory=%Zdbytes) allocated for "
"current service\n", "current service\n",

View File

@ -85,10 +85,9 @@ static int ip_vs_wrr_init_svc(struct ip_vs_service *svc)
* Allocate the mark variable for WRR scheduling * Allocate the mark variable for WRR scheduling
*/ */
mark = kmalloc(sizeof(struct ip_vs_wrr_mark), GFP_ATOMIC); mark = kmalloc(sizeof(struct ip_vs_wrr_mark), GFP_ATOMIC);
if (mark == NULL) { if (mark == NULL)
pr_err("%s(): no memory\n", __func__);
return -ENOMEM; return -ENOMEM;
}
mark->cl = &svc->destinations; mark->cl = &svc->destinations;
mark->cw = 0; mark->cw = 0;
mark->mw = ip_vs_wrr_max_weight(svc); mark->mw = ip_vs_wrr_max_weight(svc);

View File

@ -661,7 +661,6 @@ __nf_conntrack_alloc(struct net *net, u16 zone,
*/ */
ct = kmem_cache_alloc(net->ct.nf_conntrack_cachep, gfp); ct = kmem_cache_alloc(net->ct.nf_conntrack_cachep, gfp);
if (ct == NULL) { if (ct == NULL) {
pr_debug("nf_conntrack_alloc: Can't alloc conntrack.\n");
atomic_dec(&net->ct.count); atomic_dec(&net->ct.count);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
@ -749,10 +748,8 @@ init_conntrack(struct net *net, struct nf_conn *tmpl,
ct = __nf_conntrack_alloc(net, zone, tuple, &repl_tuple, GFP_ATOMIC, ct = __nf_conntrack_alloc(net, zone, tuple, &repl_tuple, GFP_ATOMIC,
hash); hash);
if (IS_ERR(ct)) { if (IS_ERR(ct))
pr_debug("Can't allocate conntrack.\n");
return (struct nf_conntrack_tuple_hash *)ct; return (struct nf_conntrack_tuple_hash *)ct;
}
if (!l4proto->new(ct, skb, dataoff)) { if (!l4proto->new(ct, skb, dataoff)) {
nf_conntrack_free(ct); nf_conntrack_free(ct);

View File

@ -307,17 +307,14 @@ nfulnl_alloc_skb(unsigned int inst_size, unsigned int pkt_size)
n = max(inst_size, pkt_size); n = max(inst_size, pkt_size);
skb = alloc_skb(n, GFP_ATOMIC); skb = alloc_skb(n, GFP_ATOMIC);
if (!skb) { if (!skb) {
pr_notice("nfnetlink_log: can't alloc whole buffer (%u bytes)\n",
inst_size);
if (n > pkt_size) { if (n > pkt_size) {
/* try to allocate only as much as we need for current /* try to allocate only as much as we need for current
* packet */ * packet */
skb = alloc_skb(pkt_size, GFP_ATOMIC); skb = alloc_skb(pkt_size, GFP_ATOMIC);
if (!skb) if (!skb)
pr_err("nfnetlink_log: can't even alloc %u " pr_err("nfnetlink_log: can't even alloc %u bytes\n",
"bytes\n", pkt_size); pkt_size);
} }
} }

View File

@ -122,14 +122,12 @@ static int idletimer_tg_create(struct idletimer_tg_info *info)
info->timer = kmalloc(sizeof(*info->timer), GFP_KERNEL); info->timer = kmalloc(sizeof(*info->timer), GFP_KERNEL);
if (!info->timer) { if (!info->timer) {
pr_debug("couldn't alloc timer\n");
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
info->timer->attr.attr.name = kstrdup(info->label, GFP_KERNEL); info->timer->attr.attr.name = kstrdup(info->label, GFP_KERNEL);
if (!info->timer->attr.attr.name) { if (!info->timer->attr.attr.name) {
pr_debug("couldn't alloc attribute name\n");
ret = -ENOMEM; ret = -ENOMEM;
goto out_free_timer; goto out_free_timer;
} }

View File

@ -176,10 +176,7 @@ dsthash_alloc_init(struct xt_hashlimit_htable *ht,
ent = NULL; ent = NULL;
} else } else
ent = kmem_cache_alloc(hashlimit_cachep, GFP_ATOMIC); ent = kmem_cache_alloc(hashlimit_cachep, GFP_ATOMIC);
if (!ent) { if (ent) {
if (net_ratelimit())
pr_err("cannot allocate dsthash_ent\n");
} else {
memcpy(&ent->dst, dst, sizeof(ent->dst)); memcpy(&ent->dst, dst, sizeof(ent->dst));
spin_lock_init(&ent->lock); spin_lock_init(&ent->lock);