print-frag6.c 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. * Copyright (c) 1988, 1989, 1990, 1991, 1993, 1994
  3. * The Regents of the University of California. All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that: (1) source code distributions
  7. * retain the above copyright notice and this paragraph in its entirety, (2)
  8. * distributions including binary code include the above copyright notice and
  9. * this paragraph in its entirety in the documentation or other materials
  10. * provided with the distribution, and (3) all advertising materials mentioning
  11. * features or use of this software display the following acknowledgement:
  12. * ``This product includes software developed by the University of California,
  13. * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
  14. * the University nor the names of its contributors may be used to endorse
  15. * or promote products derived from this software without specific prior
  16. * written permission.
  17. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
  18. * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
  19. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  20. */
  21. /* \summary: IPv6 fragmentation header printer */
  22. #ifdef HAVE_CONFIG_H
  23. #include "config.h"
  24. #endif
  25. #include <netdissect-stdinc.h>
  26. #include "netdissect.h"
  27. #include "extract.h"
  28. #include "ip6.h"
  29. int
  30. frag6_print(netdissect_options *ndo, register const u_char *bp, register const u_char *bp2)
  31. {
  32. register const struct ip6_frag *dp;
  33. register const struct ip6_hdr *ip6;
  34. dp = (const struct ip6_frag *)bp;
  35. ip6 = (const struct ip6_hdr *)bp2;
  36. ND_TCHECK(*dp);
  37. if (ndo->ndo_vflag) {
  38. ND_PRINT((ndo, "frag (0x%08x:%d|%ld)",
  39. EXTRACT_32BITS(&dp->ip6f_ident),
  40. EXTRACT_16BITS(&dp->ip6f_offlg) & IP6F_OFF_MASK,
  41. sizeof(struct ip6_hdr) + EXTRACT_16BITS(&ip6->ip6_plen) -
  42. (long)(bp - bp2) - sizeof(struct ip6_frag)));
  43. } else {
  44. ND_PRINT((ndo, "frag (%d|%ld)",
  45. EXTRACT_16BITS(&dp->ip6f_offlg) & IP6F_OFF_MASK,
  46. sizeof(struct ip6_hdr) + EXTRACT_16BITS(&ip6->ip6_plen) -
  47. (long)(bp - bp2) - sizeof(struct ip6_frag)));
  48. }
  49. /* it is meaningless to decode non-first fragment */
  50. if ((EXTRACT_16BITS(&dp->ip6f_offlg) & IP6F_OFF_MASK) != 0)
  51. return -1;
  52. else
  53. {
  54. ND_PRINT((ndo, " "));
  55. return sizeof(struct ip6_frag);
  56. }
  57. trunc:
  58. ND_PRINT((ndo, "[|frag]"));
  59. return -1;
  60. }