api: autogenerate api trace print/endian 72/21772/11
authorOle Troan <ot@cisco.com>
Wed, 4 Sep 2019 07:12:29 +0000 (09:12 +0200)
committerDave Barach <openvpp@barachs.net>
Mon, 16 Sep 2019 12:23:27 +0000 (12:23 +0000)
commit33a58171e5995d9e649b414bfc77f2aab26e4c58
tree85e072422b46ef44bbefbdf49231da507ec99536
parent1292d19c79c2fd4f09ffcc43ebf39f5d9d485c35
api: autogenerate api trace print/endian

In addition to the external vppapitrace tool, VPP itself supports dumping of API trace files.
In two formats, "custom-dump" and "dump". "dump" gives a human friendly list,
and "custom-dump" is meant to give a list of commands that can be fed to VAT.
This patch only deals with "dump".
Prior to this fix, auto-generation was only done for the basic types.
This fix adds support for any type, including lists, and supports pretty-printing
of enums, strings, IP addresses, MAC addresses and so on.

Usage: api trace dump <api-trace-file>

For example

Change-Id: I4e485680e6dcfce7489299ae6cf31d835071ac40

---------- trace 48 -----------
vl_api_sw_interface_set_flags_t:
  _vl_msg_id: 75
  client_index: 0
  context: 10
  sw_if_index: 1
  flags: IF_STATUS_API_FLAG_ADMIN_UP
---------- trace 49 -----------
vl_api_sw_interface_add_del_address_t:
  _vl_msg_id: 88
  client_index: 0
  context: 11
  sw_if_index: 1
  is_add: 1
  del_all: 0
  prefix: 172.16.1.1/24
---------- trace 51 -----------
vl_api_cli_inband_t:
  _vl_msg_id: 819
  client_index: 0
  context: 13
  cmd: packet-generator capture pg0 pcap /tmp/vpp-unittest-TestMAP-YhcmDX/pg0_out.pcap disable
---------- trace 58 -----------
vl_api_ip_neighbor_add_del_t:
  _vl_msg_id: 199
  client_index: 0
  context: 20
  is_add: 1
  neighbor:
    sw_if_index: 2
    flags: IP_API_NEIGHBOR_FLAG_NONE
    mac_address: 0202.0000.ff02
    ip_address: fd01:2::2

Signed-off-by: Ole Troan <ot@cisco.com>
Change-Id: I5556d06008de2762e7c2d35a8b0963ae670b3db1
Type: fix
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
Signed-off-by: Ole Troan <ot@cisco.com>
34 files changed:
src/examples/sample-plugin/sample/sample.api
src/plugins/abf/abf_all_api_h.h
src/plugins/acl/CMakeLists.txt
src/plugins/acl/acl_all_api_h.h
src/plugins/acl/manual_fns.h
src/plugins/gbp/gbp_all_api_h.h
src/plugins/igmp/igmp_all_api_h.h
src/plugins/l3xc/l3xc_all_api_h.h
src/plugins/lb/lb_all_api_h.h
src/plugins/lb/lb_test.c
src/plugins/map/map_all_api_h.h
src/plugins/map/map_api.c
src/plugins/memif/memif_all_api_h.h
src/plugins/nat/nat_all_api_h.h
src/plugins/svs/svs_all_api_h.h
src/tools/vppapigen/vppapigen.py
src/tools/vppapigen/vppapigen_c.py
src/tools/vppapigen/vppapigen_json.py
src/tools/vppapitrace/vppapitrace.py
src/vat/api_format.c
src/vlibapi/api_shared.c
src/vlibapi/api_types.h
src/vlibmemory/vlib_api_cli.c
src/vnet/ethernet/ethernet_format_fns.h [new file with mode: 0644]
src/vnet/ethernet/ethernet_types.api
src/vnet/format_fns.h [new file with mode: 0644]
src/vnet/interface_api.c
src/vnet/ip/ip4_forward.c
src/vnet/ip/ip_api.c
src/vnet/ip/ip_format_fns.h [new file with mode: 0644]
src/vnet/ip/ip_types.api
src/vnet/vnet_all_api_h.h
src/vpp-api/python/vpp_papi/vpp_serializer.py
src/vpp/api/custom_dump.c