提交 6ff9c364 编写于 作者: S stephen hemminger 提交者: David S. Miller

net sched: printk message severity

The previous patch encourage me to go look at all the messages in
the network scheduler and fix them. Many messages were missing
any severity level. Some serious ones that should never happen
were turned into WARN(), and the random noise messages that were
handled changed to pr_debug().
Signed-off-by: NStephen Hemminger <shemminger@vyatta.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 00c60a83
...@@ -153,7 +153,7 @@ int tcf_generic_walker(struct sk_buff *skb, struct netlink_callback *cb, ...@@ -153,7 +153,7 @@ int tcf_generic_walker(struct sk_buff *skb, struct netlink_callback *cb,
} else if (type == RTM_GETACTION) { } else if (type == RTM_GETACTION) {
return tcf_dump_walker(skb, cb, a, hinfo); return tcf_dump_walker(skb, cb, a, hinfo);
} else { } else {
printk("tcf_generic_walker: unknown action %d\n", type); WARN(1, "tcf_generic_walker: unknown action %d\n", type);
return -EINVAL; return -EINVAL;
} }
} }
...@@ -403,8 +403,9 @@ void tcf_action_destroy(struct tc_action *act, int bind) ...@@ -403,8 +403,9 @@ void tcf_action_destroy(struct tc_action *act, int bind)
module_put(a->ops->owner); module_put(a->ops->owner);
act = act->next; act = act->next;
kfree(a); kfree(a);
} else { /*FIXME: Remove later - catch insertion bugs*/ } else {
printk("tcf_action_destroy: BUG? destroying NULL ops\n"); /*FIXME: Remove later - catch insertion bugs*/
WARN(1, "tcf_action_destroy: BUG? destroying NULL ops\n");
act = act->next; act = act->next;
kfree(a); kfree(a);
} }
...@@ -744,7 +745,7 @@ static struct tc_action *create_a(int i) ...@@ -744,7 +745,7 @@ static struct tc_action *create_a(int i)
act = kzalloc(sizeof(*act), GFP_KERNEL); act = kzalloc(sizeof(*act), GFP_KERNEL);
if (act == NULL) { if (act == NULL) {
printk("create_a: failed to alloc!\n"); pr_debug("create_a: failed to alloc!\n");
return NULL; return NULL;
} }
act->order = i; act->order = i;
...@@ -766,13 +767,13 @@ static int tca_action_flush(struct net *net, struct nlattr *nla, ...@@ -766,13 +767,13 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,
int err = -ENOMEM; int err = -ENOMEM;
if (a == NULL) { if (a == NULL) {
printk("tca_action_flush: couldnt create tc_action\n"); pr_debug("tca_action_flush: couldnt create tc_action\n");
return err; return err;
} }
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL); skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
if (!skb) { if (!skb) {
printk("tca_action_flush: failed skb alloc\n"); pr_debug("tca_action_flush: failed skb alloc\n");
kfree(a); kfree(a);
return err; return err;
} }
...@@ -979,7 +980,7 @@ static int tc_ctl_action(struct sk_buff *skb, struct nlmsghdr *n, void *arg) ...@@ -979,7 +980,7 @@ static int tc_ctl_action(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
return ret; return ret;
if (tca[TCA_ACT_TAB] == NULL) { if (tca[TCA_ACT_TAB] == NULL) {
printk("tc_ctl_action: received NO action attribs\n"); pr_notice("tc_ctl_action: received NO action attribs\n");
return -EINVAL; return -EINVAL;
} }
...@@ -1056,7 +1057,7 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb) ...@@ -1056,7 +1057,7 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb)
struct nlattr *kind = find_dump_kind(cb->nlh); struct nlattr *kind = find_dump_kind(cb->nlh);
if (kind == NULL) { if (kind == NULL) {
printk("tc_dump_action: action bad kind\n"); pr_info("tc_dump_action: action bad kind\n");
return 0; return 0;
} }
...@@ -1069,7 +1070,8 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb) ...@@ -1069,7 +1070,8 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb)
a.ops = a_o; a.ops = a_o;
if (a_o->walk == NULL) { if (a_o->walk == NULL) {
printk("tc_dump_action: %s !capable of dumping table\n", a_o->kind); WARN(1, "tc_dump_action: %s !capable of dumping table\n",
a_o->kind);
goto nla_put_failure; goto nla_put_failure;
} }
......
...@@ -202,9 +202,9 @@ MODULE_LICENSE("GPL"); ...@@ -202,9 +202,9 @@ MODULE_LICENSE("GPL");
static int __init gact_init_module(void) static int __init gact_init_module(void)
{ {
#ifdef CONFIG_GACT_PROB #ifdef CONFIG_GACT_PROB
printk("GACT probability on\n"); printk(KERN_INFO "GACT probability on\n");
#else #else
printk("GACT probability NOT on\n"); printk(KERN_INFO "GACT probability NOT on\n");
#endif #endif
return tcf_register_action(&act_gact_ops); return tcf_register_action(&act_gact_ops);
} }
......
...@@ -235,7 +235,8 @@ static int tcf_ipt(struct sk_buff *skb, struct tc_action *a, ...@@ -235,7 +235,8 @@ static int tcf_ipt(struct sk_buff *skb, struct tc_action *a,
break; break;
default: default:
if (net_ratelimit()) if (net_ratelimit())
printk("Bogus netfilter code %d assume ACCEPT\n", ret); pr_notice("tc filter: Bogus netfilter code"
" %d assume ACCEPT\n", ret);
result = TC_POLICE_OK; result = TC_POLICE_OK;
break; break;
} }
......
...@@ -164,8 +164,8 @@ static int tcf_mirred(struct sk_buff *skb, struct tc_action *a, ...@@ -164,8 +164,8 @@ static int tcf_mirred(struct sk_buff *skb, struct tc_action *a,
dev = m->tcfm_dev; dev = m->tcfm_dev;
if (!(dev->flags & IFF_UP)) { if (!(dev->flags & IFF_UP)) {
if (net_ratelimit()) if (net_ratelimit())
printk("mirred to Houston: device %s is gone!\n", pr_notice("tc mirred to Houston: device %s is gone!\n",
dev->name); dev->name);
goto out; goto out;
} }
...@@ -252,7 +252,7 @@ MODULE_LICENSE("GPL"); ...@@ -252,7 +252,7 @@ MODULE_LICENSE("GPL");
static int __init mirred_init_module(void) static int __init mirred_init_module(void)
{ {
printk("Mirror/redirect action on\n"); pr_info("Mirror/redirect action on\n");
return tcf_register_action(&act_mirred_ops); return tcf_register_action(&act_mirred_ops);
} }
......
...@@ -158,11 +158,13 @@ static int tcf_pedit(struct sk_buff *skb, struct tc_action *a, ...@@ -158,11 +158,13 @@ static int tcf_pedit(struct sk_buff *skb, struct tc_action *a,
} }
if (offset % 4) { if (offset % 4) {
printk("offset must be on 32 bit boundaries\n"); pr_info("tc filter pedit"
" offset must be on 32 bit boundaries\n");
goto bad; goto bad;
} }
if (offset > 0 && offset > skb->len) { if (offset > 0 && offset > skb->len) {
printk("offset %d cant exceed pkt length %d\n", pr_info("tc filter pedit"
" offset %d cant exceed pkt length %d\n",
offset, skb->len); offset, skb->len);
goto bad; goto bad;
} }
...@@ -176,9 +178,8 @@ static int tcf_pedit(struct sk_buff *skb, struct tc_action *a, ...@@ -176,9 +178,8 @@ static int tcf_pedit(struct sk_buff *skb, struct tc_action *a,
if (munged) if (munged)
skb->tc_verd = SET_TC_MUNGED(skb->tc_verd); skb->tc_verd = SET_TC_MUNGED(skb->tc_verd);
goto done; goto done;
} else { } else
printk("pedit BUG: index %d\n", p->tcf_index); WARN(1, "pedit BUG: index %d\n", p->tcf_index);
}
bad: bad:
p->tcf_qstats.overlimits++; p->tcf_qstats.overlimits++;
......
...@@ -49,7 +49,7 @@ static int tcf_simp(struct sk_buff *skb, struct tc_action *a, struct tcf_result ...@@ -49,7 +49,7 @@ static int tcf_simp(struct sk_buff *skb, struct tc_action *a, struct tcf_result
* Example if this was the 3rd packet and the string was "hello" * Example if this was the 3rd packet and the string was "hello"
* then it would look like "hello_3" (without quotes) * then it would look like "hello_3" (without quotes)
**/ **/
printk("simple: %s_%d\n", pr_info("simple: %s_%d\n",
(char *)d->tcfd_defdata, d->tcf_bstats.packets); (char *)d->tcfd_defdata, d->tcf_bstats.packets);
spin_unlock(&d->tcf_lock); spin_unlock(&d->tcf_lock);
return d->tcf_action; return d->tcf_action;
...@@ -205,7 +205,7 @@ static int __init simp_init_module(void) ...@@ -205,7 +205,7 @@ static int __init simp_init_module(void)
{ {
int ret = tcf_register_action(&act_simp_ops); int ret = tcf_register_action(&act_simp_ops);
if (!ret) if (!ret)
printk("Simple TC action Loaded\n"); pr_info("Simple TC action Loaded\n");
return ret; return ret;
} }
......
...@@ -211,7 +211,7 @@ static int u32_classify(struct sk_buff *skb, struct tcf_proto *tp, struct tcf_re ...@@ -211,7 +211,7 @@ static int u32_classify(struct sk_buff *skb, struct tcf_proto *tp, struct tcf_re
deadloop: deadloop:
if (net_ratelimit()) if (net_ratelimit())
printk("cls_u32: dead loop\n"); printk(KERN_WARNING "cls_u32: dead loop\n");
return -1; return -1;
} }
...@@ -768,15 +768,15 @@ static struct tcf_proto_ops cls_u32_ops __read_mostly = { ...@@ -768,15 +768,15 @@ static struct tcf_proto_ops cls_u32_ops __read_mostly = {
static int __init init_u32(void) static int __init init_u32(void)
{ {
printk("u32 classifier\n"); pr_info("u32 classifier\n");
#ifdef CONFIG_CLS_U32_PERF #ifdef CONFIG_CLS_U32_PERF
printk(" Performance counters on\n"); pr_info(" Performance counters on\n");
#endif #endif
#ifdef CONFIG_NET_CLS_IND #ifdef CONFIG_NET_CLS_IND
printk(" input device check on\n"); pr_info(" input device check on\n");
#endif #endif
#ifdef CONFIG_NET_CLS_ACT #ifdef CONFIG_NET_CLS_ACT
printk(" Actions configured\n"); pr_info(" Actions configured\n");
#endif #endif
return register_tcf_proto_ops(&cls_u32_ops); return register_tcf_proto_ops(&cls_u32_ops);
} }
......
...@@ -527,7 +527,8 @@ int __tcf_em_tree_match(struct sk_buff *skb, struct tcf_ematch_tree *tree, ...@@ -527,7 +527,8 @@ int __tcf_em_tree_match(struct sk_buff *skb, struct tcf_ematch_tree *tree,
stack_overflow: stack_overflow:
if (net_ratelimit()) if (net_ratelimit())
printk("Local stack overflow, increase NET_EMATCH_STACK\n"); printk(KERN_WARNING "tc ematch: local stack overflow,"
" increase NET_EMATCH_STACK\n");
return -1; return -1;
} }
EXPORT_SYMBOL(__tcf_em_tree_match); EXPORT_SYMBOL(__tcf_em_tree_match);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册