null.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /* $Id: null.h 1841 2007-04-26 03:43:14Z aturner $ */
  2. /*
  3. * Copyright (c) 2006-2007 Aaron Turner.
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the names of the copyright owners nor the names of its
  16. * contributors may be used to endorse or promote products derived from
  17. * this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
  20. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  21. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  22. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  23. * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  24. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
  25. * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  26. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
  27. * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  28. * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  29. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  30. */
  31. #include "dlt_plugins-int.h"
  32. #ifndef _DLT_null_H_
  33. #define _DLT_null_H_
  34. int dlt_null_register(tcpeditdlt_t *ctx);
  35. int dlt_null_init(tcpeditdlt_t *ctx);
  36. int dlt_null_cleanup(tcpeditdlt_t *ctx);
  37. int dlt_null_parse_opts(tcpeditdlt_t *ctx);
  38. int dlt_null_decode(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen);
  39. int dlt_null_encode(tcpeditdlt_t *ctx, u_char **packet, int pktlen, tcpr_dir_t dir);
  40. int dlt_null_proto(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen);
  41. u_char *dlt_null_get_layer3(tcpeditdlt_t *ctx, u_char *packet, const int pktlen);
  42. u_char *dlt_null_merge_layer3(tcpeditdlt_t *ctx, u_char *packet, const int pktlen, u_char *l3data);
  43. tcpeditdlt_l2addr_type_t dlt_null_l2addr_type(void);
  44. int dlt_null_l2len(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen);
  45. u_char *dlt_null_get_mac(tcpeditdlt_t *ctx, tcpeditdlt_mac_type_t mac, const u_char *packet, const int pktlen);
  46. /*
  47. * structure to hold any data parsed from the packet by the decoder.
  48. * Example: Ethernet VLAN tag info
  49. */
  50. struct null_extra_s {
  51. };
  52. typedef struct null_extra_s null_extra_t;
  53. /*
  54. * FIXME: structure to hold any data in the tcpeditdlt_plugin_t->config
  55. * Things like:
  56. * - Parsed user options
  57. * - State between packets
  58. * - Note, you should only use this for the encoder function, decoder functions should place
  59. * "extra" data parsed from the packet in the tcpeditdlt_t->decoded_extra buffer since that
  60. * is available to any encoder plugin.
  61. */
  62. struct null_config_s {
  63. };
  64. typedef struct null_config_s null_config_t;
  65. #endif