Amritha Nambiar <amritha.namb...@intel.com> writes: [...]
> @@ -72,6 +73,8 @@ parse_direction(struct action_util *a, int *argc_p, char > ***argv_p, > struct tc_mirred p = {}; > struct rtattr *tail; > char d[16] = {}; > + __u32 flags = 0; > + __u8 tc; > > while (argc > 0) { > > @@ -142,6 +145,18 @@ parse_direction(struct action_util *a, int *argc_p, char > ***argv_p, > argc--; > argv++; > > + if ((argc > 0) && (matches(*argv, "tc") == 0)) { > + NEXT_ARG(); > + tc = atoi(*argv); Probably better to use strtol() instead, somebody wants to specify hex base, also it has stronger error checks. > + if (tc >= MIRRED_TC_MAP_MAX) { > + fprintf(stderr, "Invalid TC > index\n"); > + return -1; > + } > + flags |= MIRRED_F_TC_MAP; > + ok++; > + argc--; > + argv++; > + } > break; > > } > @@ -193,6 +208,9 @@ parse_direction(struct action_util *a, int *argc_p, char > ***argv_p, > tail = NLMSG_TAIL(n); > addattr_l(n, MAX_MSG, tca_id, NULL, 0); > addattr_l(n, MAX_MSG, TCA_MIRRED_PARMS, &p, sizeof(p)); > + if (flags & MIRRED_F_TC_MAP) > + addattr_l(n, MAX_MSG, TCA_MIRRED_TC_MAP, > + &tc, sizeof(tc)); > tail->rta_len = (void *) NLMSG_TAIL(n) - (void *) tail; > > *argc_p = argc; > @@ -248,6 +266,7 @@ print_mirred(struct action_util *au, FILE * f, struct > rtattr *arg) > struct tc_mirred *p; > struct rtattr *tb[TCA_MIRRED_MAX + 1]; > const char *dev; > + __u8 *tc; > > if (arg == NULL) > return -1; > @@ -273,6 +292,11 @@ print_mirred(struct action_util *au, FILE * f, struct > rtattr *arg) > fprintf(f, "mirred (%s to device %s)", mirred_n2a(p->eaction), dev); > print_action_control(f, " ", p->action, ""); > > + if (tb[TCA_MIRRED_TC_MAP]) { > + tc = RTA_DATA(tb[TCA_MIRRED_TC_MAP]); > + fprintf(f, " tc %d", *tc); 'tc' is declared as __u8 so format should be %u > + } > + > fprintf(f, "\n "); > fprintf(f, "\tindex %u ref %d bind %d", p->index, p->refcnt, > p->bindcnt);