* [PATCH iproute2-next] tc: Correct json output for actions
@ 2018-04-04 12:24 Yuval Mintz
2018-04-04 17:13 ` David Ahern
2018-04-04 21:09 ` Roman Mashak
0 siblings, 2 replies; 4+ messages in thread
From: Yuval Mintz @ 2018-04-04 12:24 UTC (permalink / raw)
To: dsahern; +Cc: mlxsw, netdev, Yuval Mintz
Commit 9fd3f0b255d9 ("tc: enable json output for actions") added JSON
support for tc-actions at the expense of breaking other use cases that
reach tc_print_action(), as the latter don't expect the 'actions' array
to be a new object.
Consider the following taken duringrun of tc_chain.sh selftest,
and see the latter command output is broken:
$ ./tc/tc -j -p actions list action gact | grep -C 3 actions
[ {
"total acts": 1
},{
"actions": [ {
"order": 0,
$ ./tc/tc -p -j -s filter show dev enp3s0np2 ingress | grep -C 3 actions
},
"skip_hw": true,
"not_in_hw": true,{
"actions": [ {
"order": 1,
"kind": "gact",
"control_action": {
Relocate the open/close of the JSON object to declare the object only
for the case that needs it.
Signed-off-by: Yuval Mintz <yuvalm@mellanox.com>
---
tc/m_action.c | 5 ++---
1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/tc/m_action.c b/tc/m_action.c
index 2f85d35..8993b93 100644
--- a/tc/m_action.c
+++ b/tc/m_action.c
@@ -366,7 +366,6 @@ tc_print_action(FILE *f, const struct rtattr *arg, unsigned short tot_acts)
if (tab_flush && NULL != tb[0] && NULL == tb[1])
return tc_print_action_flush(f, tb[0]);
- open_json_object(NULL);
open_json_array(PRINT_JSON, "actions");
for (i = 0; i <= tot_acts; i++) {
if (tb[i]) {
@@ -383,7 +382,6 @@ tc_print_action(FILE *f, const struct rtattr *arg, unsigned short tot_acts)
}
close_json_array(PRINT_JSON, NULL);
- close_json_object();
return 0;
}
@@ -439,8 +437,9 @@ int print_action(const struct sockaddr_nl *who,
}
}
-
+ open_json_object(NULL);
tc_print_action(fp, tb[TCA_ACT_TAB], tot_acts ? *tot_acts:0);
+ close_json_object();
return 0;
}
--
2.4.3
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH iproute2-next] tc: Correct json output for actions
2018-04-04 12:24 [PATCH iproute2-next] tc: Correct json output for actions Yuval Mintz
@ 2018-04-04 17:13 ` David Ahern
2018-04-04 21:09 ` Roman Mashak
1 sibling, 0 replies; 4+ messages in thread
From: David Ahern @ 2018-04-04 17:13 UTC (permalink / raw)
To: Yuval Mintz; +Cc: mlxsw, netdev, Stephen Hemminger, Roman Mashak
On 4/4/18 6:24 AM, Yuval Mintz wrote:
> Commit 9fd3f0b255d9 ("tc: enable json output for actions") added JSON
> support for tc-actions at the expense of breaking other use cases that
> reach tc_print_action(), as the latter don't expect the 'actions' array
> to be a new object.
>
> Consider the following taken duringrun of tc_chain.sh selftest,
> and see the latter command output is broken:
>
> $ ./tc/tc -j -p actions list action gact | grep -C 3 actions
> [ {
> "total acts": 1
> },{
> "actions": [ {
> "order": 0,
>
> $ ./tc/tc -p -j -s filter show dev enp3s0np2 ingress | grep -C 3 actions
> },
> "skip_hw": true,
> "not_in_hw": true,{
> "actions": [ {
> "order": 1,
> "kind": "gact",
> "control_action": {
>
> Relocate the open/close of the JSON object to declare the object only
> for the case that needs it.
>
> Signed-off-by: Yuval Mintz <yuvalm@mellanox.com>
> ---
> tc/m_action.c | 5 ++---
> 1 file changed, 2 insertions(+), 3 deletions(-)
This is a bug fix so it should go through master.
Added Roman so he is aware of the mistake.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH iproute2-next] tc: Correct json output for actions
2018-04-04 12:24 [PATCH iproute2-next] tc: Correct json output for actions Yuval Mintz
2018-04-04 17:13 ` David Ahern
@ 2018-04-04 21:09 ` Roman Mashak
2018-04-04 23:42 ` Stephen Hemminger
1 sibling, 1 reply; 4+ messages in thread
From: Roman Mashak @ 2018-04-04 21:09 UTC (permalink / raw)
To: Yuval Mintz; +Cc: dsahern, mlxsw, netdev
Yuval Mintz <yuvalm@mellanox.com> writes:
> Commit 9fd3f0b255d9 ("tc: enable json output for actions") added JSON
> support for tc-actions at the expense of breaking other use cases that
> reach tc_print_action(), as the latter don't expect the 'actions' array
> to be a new object.
>
> Consider the following taken duringrun of tc_chain.sh selftest,
> and see the latter command output is broken:
>
> $ ./tc/tc -j -p actions list action gact | grep -C 3 actions
> [ {
> "total acts": 1
> },{
> "actions": [ {
> "order": 0,
>
> $ ./tc/tc -p -j -s filter show dev enp3s0np2 ingress | grep -C 3 actions
> },
> "skip_hw": true,
> "not_in_hw": true,{
> "actions": [ {
> "order": 1,
> "kind": "gact",
> "control_action": {
>
> Relocate the open/close of the JSON object to declare the object only
> for the case that needs it.
>
> Signed-off-by: Yuval Mintz <yuvalm@mellanox.com>
[...]
Good catch, thanks Yuval.
Tested-by: Roman Mashak <mrv@mojatatu.com>
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH iproute2-next] tc: Correct json output for actions
2018-04-04 21:09 ` Roman Mashak
@ 2018-04-04 23:42 ` Stephen Hemminger
0 siblings, 0 replies; 4+ messages in thread
From: Stephen Hemminger @ 2018-04-04 23:42 UTC (permalink / raw)
To: Roman Mashak; +Cc: Yuval Mintz, dsahern, mlxsw, netdev
On Wed, 04 Apr 2018 17:09:04 -0400
Roman Mashak <mrv@mojatatu.com> wrote:
> Yuval Mintz <yuvalm@mellanox.com> writes:
>
> > Commit 9fd3f0b255d9 ("tc: enable json output for actions") added JSON
> > support for tc-actions at the expense of breaking other use cases that
> > reach tc_print_action(), as the latter don't expect the 'actions' array
> > to be a new object.
> >
> > Consider the following taken duringrun of tc_chain.sh selftest,
> > and see the latter command output is broken:
> >
> > $ ./tc/tc -j -p actions list action gact | grep -C 3 actions
> > [ {
> > "total acts": 1
> > },{
> > "actions": [ {
> > "order": 0,
> >
> > $ ./tc/tc -p -j -s filter show dev enp3s0np2 ingress | grep -C 3 actions
> > },
> > "skip_hw": true,
> > "not_in_hw": true,{
> > "actions": [ {
> > "order": 1,
> > "kind": "gact",
> > "control_action": {
> >
> > Relocate the open/close of the JSON object to declare the object only
> > for the case that needs it.
> >
> > Signed-off-by: Yuval Mintz <yuvalm@mellanox.com>
>
> [...]
>
>
> Good catch, thanks Yuval.
>
> Tested-by: Roman Mashak <mrv@mojatatu.com>
Applied
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2018-04-04 23:42 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-04-04 12:24 [PATCH iproute2-next] tc: Correct json output for actions Yuval Mintz
2018-04-04 17:13 ` David Ahern
2018-04-04 21:09 ` Roman Mashak
2018-04-04 23:42 ` Stephen Hemminger
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).