summaryrefslogtreecommitdiffstats
path: root/src/vat2/test/vat2_test.api
blob: afc8afa4dd72ce8e53843bd736d40b449b357663 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
 * Copyright (c) 2020 Cisco and/or its affiliates.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

import "vnet/ip/ip_types.api";

autoreply define test_prefix {
  vl_api_prefix_t pref;
};

enumflag test_enumflags {
  RED = 0x1,
  BLUE = 0x2,
  GREEN = 0x4,
};

autoreply define test_enum {
  vl_api_test_enumflags_t flags;
};

typedef test_stringtype {
  string str[];
};

autoreply define test_string {
  vl_api_test_stringtype_t str;
};

autoreply define test_string2 {
  string str[];
};

/* Test of toplevel VLA with basetype */
autoreply define test_vla {
  u32 count;
  u32 vla[count];
};

/* Test of toplevel VLA with u8 */
autoreply define test_vla2 {
  u32 count;
  u8 vla[count];
};
/* Test of toplevel VLA with user type */
typedef test_vlatype {
  u32 data;
};
autoreply define test_vla3 {
  u32 count;
  vl_api_test_vlatype_t vla[count];
};
/* Test of typedefed VLA */
typedef test_vlatype2 {
  u32 count;
  u32 vla[count];
};
autoreply define test_vla4 {
  vl_api_test_vlatype2_t data;
};
/* u8 string in typedef */
typedef test_vlatype3 {
  u32 count;
  u8 vla[count];
};
autoreply define test_vla5 {
  vl_api_test_vlatype3_t data;
};

/* Addresses */
autoreply define test_addresses {
  vl_api_address_t a;
};
autoreply define test_addresses2 {
  vl_api_address_t a[2];
};
autoreply define test_addresses3 {
  u32 n;
  vl_api_address_t a[n];
};

/* Empty */
autoreply define test_empty {
  u32 client_index;
  u32 context;
};
static inline int clib_bihash_is_free_8_8_stats (clib_bihash_kv_8_8_stats_t * v) { if (v->key == ~0ULL && v->value == ~0ULL) return 1; return 0; } /** Hash a clib_bihash_kv_8_8_t instance @param v - pointer to the (key,value) pair, hash the key (only) */ static inline u64 clib_bihash_hash_8_8_stats (clib_bihash_kv_8_8_stats_t * v) { /* Note: to torture-test linear scan, make this fn return a constant */ #ifdef clib_crc32c_uses_intrinsics return clib_crc32c ((u8 *) & v->key, 8); #else return clib_xxhash (v->key); #endif } /** Format a clib_bihash_kv_8_8_t instance @param s - u8 * vector under construction @param args (vararg) - the (key,value) pair to format @return s - the u8 * vector under construction */ static inline u8 * format_bihash_kvp_8_8_stats (u8 * s, va_list * args) { clib_bihash_kv_8_8_stats_t *v = va_arg (*args, clib_bihash_kv_8_8_stats_t *); s = format (s, "key %llu value %llu", v->key, v->value); return s; } /** Compare two clib_bihash_kv_8_8_t instances @param a - first key @param b - second key */ static inline int clib_bihash_key_compare_8_8_stats (u64 a, u64 b) { return a == b; } #undef __included_bihash_template_h__ #include <vppinfra/bihash_template.h> #endif /* __included_bihash_8_8_stats_h__ */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */