tcpreplay_opts.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. /* -*- buffer-read-only: t -*- vi: set ro:
  2. *
  3. * DO NOT EDIT THIS FILE (tcpreplay_opts.h)
  4. *
  5. * It has been AutoGen-ed
  6. * From the definitions ../../src/tcpreplay_opts.def
  7. * and the template file options
  8. *
  9. * Generated from AutoOpts 42:1:17 templates.
  10. *
  11. * AutoOpts is a copyrighted work. This header file is not encumbered
  12. * by AutoOpts licensing, but is provided under the licensing terms chosen
  13. * by the tcpreplay author or copyright holder. AutoOpts is
  14. * licensed under the terms of the LGPL. The redistributable library
  15. * (``libopts'') is licensed under the terms of either the LGPL or, at the
  16. * users discretion, the BSD license. See the AutoOpts and/or libopts sources
  17. * for details.
  18. *
  19. * The tcpreplay program is copyrighted and licensed
  20. * under the following terms:
  21. *
  22. * Copyright (C) 2000-2024 Aaron Turner and Fred Klassen, all rights reserved.
  23. * This is free software. It is licensed for use, modification and
  24. * redistribution under the terms of the GNU General Public License,
  25. * version 3 or later <http://gnu.org/licenses/gpl.html>
  26. *
  27. * tcpreplay is free software: you can redistribute it and/or modify it
  28. * under the terms of the GNU General Public License as published by the
  29. * Free Software Foundation, either version 3 of the License, or
  30. * (at your option) any later version.
  31. *
  32. * tcpreplay is distributed in the hope that it will be useful, but
  33. * WITHOUT ANY WARRANTY; without even the implied warranty of
  34. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  35. * See the GNU General Public License for more details.
  36. *
  37. * You should have received a copy of the GNU General Public License along
  38. * with this program. If not, see <http://www.gnu.org/licenses/>.
  39. */
  40. /**
  41. * This file contains the programmatic interface to the Automated
  42. * Options generated for the tcpreplay program.
  43. * These macros are documented in the AutoGen info file in the
  44. * "AutoOpts" chapter. Please refer to that doc for usage help.
  45. */
  46. #ifndef AUTOOPTS_TCPREPLAY_OPTS_H_GUARD
  47. #define AUTOOPTS_TCPREPLAY_OPTS_H_GUARD 1
  48. #include "config.h"
  49. #include <autoopts/options.h>
  50. #include <stdarg.h>
  51. #include <stdnoreturn.h>
  52. /**
  53. * Ensure that the library used for compiling this generated header is at
  54. * least as new as the version current when the header template was released
  55. * (not counting patch version increments). Also ensure that the oldest
  56. * tolerable version is at least as old as what was current when the header
  57. * template was released.
  58. */
  59. #define AO_TEMPLATE_VERSION 172033
  60. #if (AO_TEMPLATE_VERSION < OPTIONS_MINIMUM_VERSION) \
  61. || (AO_TEMPLATE_VERSION > OPTIONS_STRUCT_VERSION)
  62. # error option template version mismatches autoopts/options.h header
  63. Choke Me.
  64. #endif
  65. #if GCC_VERSION > 40400
  66. #define NOT_REACHED __builtin_unreachable();
  67. #else
  68. #define NOT_REACHED
  69. #endif
  70. /**
  71. * Enumeration of each option type for tcpreplay
  72. */
  73. typedef enum {
  74. INDEX_OPT_DBUG = 0,
  75. INDEX_OPT_QUIET = 1,
  76. INDEX_OPT_TIMER = 2,
  77. INDEX_OPT_MAXSLEEP = 3,
  78. INDEX_OPT_VERBOSE = 4,
  79. INDEX_OPT_DECODE = 5,
  80. INDEX_OPT_PRELOAD_PCAP = 6,
  81. INDEX_OPT_CACHEFILE = 7,
  82. INDEX_OPT_DUALFILE = 8,
  83. INDEX_OPT_INTF1 = 9,
  84. INDEX_OPT_INTF2 = 10,
  85. INDEX_OPT_WRITE = 11,
  86. INDEX_OPT_INCLUDE = 12,
  87. INDEX_OPT_EXCLUDE = 13,
  88. INDEX_OPT_LISTNICS = 14,
  89. INDEX_OPT_LOOP = 15,
  90. INDEX_OPT_LOOPDELAY_MS = 16,
  91. INDEX_OPT_LOOPDELAY_NS = 17,
  92. INDEX_OPT_PKTLEN = 18,
  93. INDEX_OPT_LIMIT = 19,
  94. INDEX_OPT_DURATION = 20,
  95. INDEX_OPT_MULTIPLIER = 21,
  96. INDEX_OPT_PPS = 22,
  97. INDEX_OPT_MBPS = 23,
  98. INDEX_OPT_TOPSPEED = 24,
  99. INDEX_OPT_ONEATATIME = 25,
  100. INDEX_OPT_PPS_MULTI = 26,
  101. INDEX_OPT_UNIQUE_IP = 27,
  102. INDEX_OPT_UNIQUE_IP_LOOPS = 28,
  103. INDEX_OPT_NETMAP = 29,
  104. INDEX_OPT_NM_DELAY = 30,
  105. INDEX_OPT_NO_FLOW_STATS = 31,
  106. INDEX_OPT_FLOW_EXPIRY = 32,
  107. INDEX_OPT_PID = 33,
  108. INDEX_OPT_STATS = 34,
  109. INDEX_OPT_SUPPRESS_WARNINGS = 35,
  110. INDEX_OPT_XDP = 36,
  111. INDEX_OPT_XDP_BATCH_SIZE = 37,
  112. INDEX_OPT_VERSION = 38,
  113. INDEX_OPT_LESS_HELP = 39,
  114. INDEX_OPT_HELP = 40,
  115. INDEX_OPT_MORE_HELP = 41,
  116. INDEX_OPT_SAVE_OPTS = 42,
  117. INDEX_OPT_LOAD_OPTS = 43
  118. } teOptIndex;
  119. /** count of all options for tcpreplay */
  120. #define OPTION_CT 44
  121. /**
  122. * Interface defines for all options. Replace "n" with the UPPER_CASED
  123. * option name (as in the teOptIndex enumeration above).
  124. * e.g. HAVE_OPT(DBUG)
  125. */
  126. #define DESC(n) (tcpreplayOptions.pOptDesc[INDEX_OPT_## n])
  127. /** 'true' if an option has been specified in any way */
  128. #define HAVE_OPT(n) (! UNUSED_OPT(& DESC(n)))
  129. /** The string argument to an option. The argument type must be \"string\". */
  130. #define OPT_ARG(n) (DESC(n).optArg.argString)
  131. /** Mask the option state revealing how an option was specified.
  132. * It will be one and only one of \a OPTST_SET, \a OPTST_PRESET,
  133. * \a OPTST_DEFINED, \a OPTST_RESET or zero.
  134. */
  135. #define STATE_OPT(n) (DESC(n).fOptState & OPTST_SET_MASK)
  136. /** Count of option's occurrances *on the command line*. */
  137. #define COUNT_OPT(n) (DESC(n).optOccCt)
  138. /** mask of \a OPTST_SET and \a OPTST_DEFINED. */
  139. #define ISSEL_OPT(n) (SELECTED_OPT(&DESC(n)))
  140. /** 'true' if \a HAVE_OPT would yield 'false'. */
  141. #define ISUNUSED_OPT(n) (UNUSED_OPT(& DESC(n)))
  142. /** 'true' if OPTST_DISABLED bit not set. */
  143. #define ENABLED_OPT(n) (! DISABLED_OPT(& DESC(n)))
  144. /** number of stacked option arguments.
  145. * Valid only for stacked option arguments. */
  146. #define STACKCT_OPT(n) (((tArgList*)(DESC(n).optCookie))->useCt)
  147. /** stacked argument vector.
  148. * Valid only for stacked option arguments. */
  149. #define STACKLST_OPT(n) (((tArgList*)(DESC(n).optCookie))->apzArgs)
  150. /** Reset an option. */
  151. #define CLEAR_OPT(n) STMTS( \
  152. DESC(n).fOptState &= OPTST_PERSISTENT_MASK; \
  153. if ((DESC(n).fOptState & OPTST_INITENABLED) == 0) \
  154. DESC(n).fOptState |= OPTST_DISABLED; \
  155. DESC(n).optCookie = NULL )
  156. /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
  157. /**
  158. * Enumeration of tcpreplay exit codes
  159. */
  160. typedef enum {
  161. TCPREPLAY_EXIT_SUCCESS = 0,
  162. TCPREPLAY_EXIT_FAILURE = 1,
  163. TCPREPLAY_EXIT_USAGE_ERROR = 64,
  164. TCPREPLAY_EXIT_NO_CONFIG_INPUT = 66,
  165. TCPREPLAY_EXIT_LIBOPTS_FAILURE = 70
  166. } tcpreplay_exit_code_t;
  167. /**
  168. * Interface defines for specific options.
  169. * @{
  170. */
  171. #define VALUE_OPT_DBUG 'd'
  172. #ifdef DEBUG
  173. #define OPT_VALUE_DBUG (DESC(DBUG).optArg.argInt)
  174. #endif /* DEBUG */
  175. #define VALUE_OPT_QUIET 'q'
  176. #define VALUE_OPT_TIMER 'T'
  177. #define VALUE_OPT_MAXSLEEP 0x1001
  178. #define OPT_VALUE_MAXSLEEP (DESC(MAXSLEEP).optArg.argInt)
  179. #define VALUE_OPT_VERBOSE 'v'
  180. #ifdef ENABLE_VERBOSE
  181. #define SET_OPT_VERBOSE STMTS( \
  182. DESC(VERBOSE).optActualIndex = 4; \
  183. DESC(VERBOSE).optActualValue = VALUE_OPT_VERBOSE; \
  184. DESC(VERBOSE).fOptState &= OPTST_PERSISTENT_MASK; \
  185. DESC(VERBOSE).fOptState |= OPTST_SET )
  186. #endif /* ENABLE_VERBOSE */
  187. #define VALUE_OPT_DECODE 'A'
  188. #define VALUE_OPT_PRELOAD_PCAP 'K'
  189. #define VALUE_OPT_CACHEFILE 'c'
  190. #define VALUE_OPT_DUALFILE '2'
  191. #define VALUE_OPT_INTF1 'i'
  192. /** Define the option value intf1 is equivalenced to */
  193. #define WHICH_OPT_INTF1 (DESC(INTF1).optActualValue)
  194. /** Define the index of the option intf1 is equivalenced to */
  195. #define WHICH_IDX_INTF1 (DESC(INTF1).optActualIndex)
  196. #define VALUE_OPT_INTF2 'I'
  197. #define VALUE_OPT_WRITE 'w'
  198. #define VALUE_OPT_INCLUDE 0x1002
  199. #define VALUE_OPT_EXCLUDE 0x1003
  200. #define VALUE_OPT_LISTNICS 0x1004
  201. #define VALUE_OPT_LOOP 'l'
  202. #define OPT_VALUE_LOOP (DESC(LOOP).optArg.argInt)
  203. #define VALUE_OPT_LOOPDELAY_MS 0x1005
  204. #define OPT_VALUE_LOOPDELAY_MS (DESC(LOOPDELAY_MS).optArg.argInt)
  205. #define VALUE_OPT_LOOPDELAY_NS 0x1006
  206. #define OPT_VALUE_LOOPDELAY_NS (DESC(LOOPDELAY_NS).optArg.argInt)
  207. #define VALUE_OPT_PKTLEN 0x1007
  208. #define VALUE_OPT_LIMIT 'L'
  209. #define OPT_VALUE_LIMIT (DESC(LIMIT).optArg.argInt)
  210. #define VALUE_OPT_DURATION 0x1008
  211. #define OPT_VALUE_DURATION (DESC(DURATION).optArg.argInt)
  212. #define VALUE_OPT_MULTIPLIER 'x'
  213. #define VALUE_OPT_PPS 'p'
  214. #define VALUE_OPT_MBPS 'M'
  215. #define VALUE_OPT_TOPSPEED 't'
  216. #define VALUE_OPT_ONEATATIME 'o'
  217. #define VALUE_OPT_PPS_MULTI 0x1009
  218. #define OPT_VALUE_PPS_MULTI (DESC(PPS_MULTI).optArg.argInt)
  219. #define VALUE_OPT_UNIQUE_IP 0x100A
  220. #define VALUE_OPT_UNIQUE_IP_LOOPS 0x100B
  221. #define VALUE_OPT_NETMAP 0x100C
  222. #define VALUE_OPT_NM_DELAY 0x100D
  223. #ifdef HAVE_NETMAP
  224. #define OPT_VALUE_NM_DELAY (DESC(NM_DELAY).optArg.argInt)
  225. #endif /* HAVE_NETMAP */
  226. #define VALUE_OPT_NO_FLOW_STATS 0x100E
  227. #define VALUE_OPT_FLOW_EXPIRY 0x100F
  228. #define OPT_VALUE_FLOW_EXPIRY (DESC(FLOW_EXPIRY).optArg.argInt)
  229. #define VALUE_OPT_PID 'P'
  230. #define VALUE_OPT_STATS 0x1010
  231. #define OPT_VALUE_STATS (DESC(STATS).optArg.argInt)
  232. #define VALUE_OPT_SUPPRESS_WARNINGS 'W'
  233. #define SET_OPT_SUPPRESS_WARNINGS STMTS( \
  234. DESC(SUPPRESS_WARNINGS).optActualIndex = 35; \
  235. DESC(SUPPRESS_WARNINGS).optActualValue = VALUE_OPT_SUPPRESS_WARNINGS; \
  236. DESC(SUPPRESS_WARNINGS).fOptState &= OPTST_PERSISTENT_MASK; \
  237. DESC(SUPPRESS_WARNINGS).fOptState |= OPTST_SET )
  238. #define VALUE_OPT_XDP 0x1011
  239. #define VALUE_OPT_XDP_BATCH_SIZE 0x1012
  240. #ifdef HAVE_LIBXDP
  241. #define OPT_VALUE_XDP_BATCH_SIZE (DESC(XDP_BATCH_SIZE).optArg.argInt)
  242. #endif /* HAVE_LIBXDP */
  243. #define VALUE_OPT_VERSION 'V'
  244. #define VALUE_OPT_LESS_HELP 'h'
  245. /** option flag (value) for help-value option */
  246. #define VALUE_OPT_HELP 'H'
  247. /** option flag (value) for more-help-value option */
  248. #define VALUE_OPT_MORE_HELP '!'
  249. /** option flag (value) for save-opts-value option */
  250. #define VALUE_OPT_SAVE_OPTS 0x1013
  251. /** option flag (value) for load-opts-value option */
  252. #define VALUE_OPT_LOAD_OPTS 0x1014
  253. #define SET_OPT_SAVE_OPTS(a) STMTS( \
  254. DESC(SAVE_OPTS).fOptState &= OPTST_PERSISTENT_MASK; \
  255. DESC(SAVE_OPTS).fOptState |= OPTST_SET; \
  256. DESC(SAVE_OPTS).optArg.argString = (char const*)(a))
  257. /*
  258. * Interface defines not associated with particular options
  259. */
  260. #define ERRSKIP_OPTERR STMTS(tcpreplayOptions.fOptSet &= ~OPTPROC_ERRSTOP)
  261. #define ERRSTOP_OPTERR STMTS(tcpreplayOptions.fOptSet |= OPTPROC_ERRSTOP)
  262. #define RESTART_OPT(n) STMTS( \
  263. tcpreplayOptions.curOptIdx = (n); \
  264. tcpreplayOptions.pzCurOpt = NULL )
  265. #define START_OPT RESTART_OPT(1)
  266. #define USAGE(c) (*tcpreplayOptions.pUsageProc)(&tcpreplayOptions, c)
  267. #ifdef __cplusplus
  268. extern "C" {
  269. #endif
  270. /* * * * * *
  271. *
  272. * Declare the tcpreplay option descriptor.
  273. */
  274. extern tOptions tcpreplayOptions;
  275. #if defined(ENABLE_NLS)
  276. # ifndef _
  277. # include <stdio.h>
  278. # ifndef HAVE_GETTEXT
  279. extern char * gettext(char const *);
  280. # else
  281. # include <libintl.h>
  282. # endif
  283. # ifndef ATTRIBUTE_FORMAT_ARG
  284. # define ATTRIBUTE_FORMAT_ARG(_a)
  285. # endif
  286. static inline char* aoGetsText(char const* pz) ATTRIBUTE_FORMAT_ARG(1);
  287. static inline char* aoGetsText(char const* pz) {
  288. if (pz == NULL) return NULL;
  289. return (char*)gettext(pz);
  290. }
  291. # define _(s) aoGetsText(s)
  292. # endif /* _() */
  293. # define OPT_NO_XLAT_CFG_NAMES STMTS(tcpreplayOptions.fOptSet |= \
  294. OPTPROC_NXLAT_OPT_CFG;)
  295. # define OPT_NO_XLAT_OPT_NAMES STMTS(tcpreplayOptions.fOptSet |= \
  296. OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG;)
  297. # define OPT_XLAT_CFG_NAMES STMTS(tcpreplayOptions.fOptSet &= \
  298. ~(OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG);)
  299. # define OPT_XLAT_OPT_NAMES STMTS(tcpreplayOptions.fOptSet &= \
  300. ~OPTPROC_NXLAT_OPT;)
  301. #else /* ENABLE_NLS */
  302. # define OPT_NO_XLAT_CFG_NAMES
  303. # define OPT_NO_XLAT_OPT_NAMES
  304. # define OPT_XLAT_CFG_NAMES
  305. # define OPT_XLAT_OPT_NAMES
  306. # ifndef _
  307. # define _(_s) _s
  308. # endif
  309. #endif /* ENABLE_NLS */
  310. #ifdef __cplusplus
  311. }
  312. #endif
  313. #endif /* AUTOOPTS_TCPREPLAY_OPTS_H_GUARD */
  314. /* tcpreplay_opts.h ends here */