print-otv.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  2. * Redistribution and use in source and binary forms, with or without
  3. * modification, are permitted provided that: (1) source code
  4. * distributions retain the above copyright notice and this paragraph
  5. * in its entirety, and (2) distributions including binary code include
  6. * the above copyright notice and this paragraph in its entirety in
  7. * the documentation or other materials provided with the distribution.
  8. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND
  9. * WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT
  10. * LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  11. * FOR A PARTICULAR PURPOSE.
  12. *
  13. * Original code by Francesco Fondelli (francesco dot fondelli, gmail dot com)
  14. */
  15. /* \summary: Overlay Transport Virtualization (OTV) printer */
  16. /* specification: draft-hasmit-otv-04 */
  17. #ifdef HAVE_CONFIG_H
  18. #include "config.h"
  19. #endif
  20. #include <netdissect-stdinc.h>
  21. #include "netdissect.h"
  22. #include "extract.h"
  23. /*
  24. * OTV header, draft-hasmit-otv-04
  25. *
  26. * 0 1 2 3
  27. * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
  28. * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
  29. * |R|R|R|R|I|R|R|R| Overlay ID |
  30. * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
  31. * | Instance ID | Reserved |
  32. * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
  33. */
  34. void
  35. otv_print(netdissect_options *ndo, const u_char *bp, u_int len)
  36. {
  37. uint8_t flags;
  38. ND_PRINT((ndo, "OTV, "));
  39. if (len < 8)
  40. goto trunc;
  41. ND_TCHECK(*bp);
  42. flags = *bp;
  43. ND_PRINT((ndo, "flags [%s] (0x%02x), ", flags & 0x08 ? "I" : ".", flags));
  44. bp += 1;
  45. ND_TCHECK2(*bp, 3);
  46. ND_PRINT((ndo, "overlay %u, ", EXTRACT_24BITS(bp)));
  47. bp += 3;
  48. ND_TCHECK2(*bp, 3);
  49. ND_PRINT((ndo, "instance %u\n", EXTRACT_24BITS(bp)));
  50. bp += 3;
  51. /* Reserved */
  52. ND_TCHECK(*bp);
  53. bp += 1;
  54. ether_print(ndo, bp, len - 8, ndo->ndo_snapend - bp, NULL, NULL);
  55. return;
  56. trunc:
  57. ND_PRINT((ndo, " [|OTV]"));
  58. }