From: jamal Date: Sun, 20 Apr 2008 14:47:48 +0000 (-0400) Subject: Expose the filter protocol X-Git-Tag: v2.6.26~19 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=eefcbc72062a235efe391163962f7353dba1af4c;p=thirdparty%2Fiproute2.git Expose the filter protocol makes protocol accessible .. cheers, jamal [PATCH 2/3] [TC/FILTERS] Expose the filter protocol Expose the filter protocol so it can be used by underlying classifiers when they need it. Signed-off-by: Jamal Hadi Salim --- diff --git a/tc/tc_filter.c b/tc/tc_filter.c index 6701f9ae2..db44dec42 100644 --- a/tc/tc_filter.c +++ b/tc/tc_filter.c @@ -175,6 +175,7 @@ static __u32 filter_parent; static int filter_ifindex; static __u32 filter_prio; static __u32 filter_protocol; +__u16 f_proto = 0; int print_filter(const struct sockaddr_nl *who, struct nlmsghdr *n, @@ -221,13 +222,13 @@ int print_filter(const struct sockaddr_nl *who, } } if (t->tcm_info) { - __u32 protocol = TC_H_MIN(t->tcm_info); + f_proto = TC_H_MIN(t->tcm_info); __u32 prio = TC_H_MAJ(t->tcm_info)>>16; - if (!filter_protocol || filter_protocol != protocol) { - if (protocol) { + if (!filter_protocol || filter_protocol != f_proto) { + if (f_proto) { SPRINT_BUF(b1); fprintf(fp, "protocol %s ", - ll_proto_n2a(protocol, b1, sizeof(b1))); + ll_proto_n2a(f_proto, b1, sizeof(b1))); } } if (!filter_prio || filter_prio != prio) { diff --git a/tc/tc_util.h b/tc/tc_util.h index 301b5c7ff..796da5427 100644 --- a/tc/tc_util.h +++ b/tc/tc_util.h @@ -19,6 +19,7 @@ struct qdisc_util int (*print_copt)(struct qdisc_util *qu, FILE *f, struct rtattr *opt); }; +extern __u16 f_proto; struct filter_util { struct filter_util *next;