print-ipcomp.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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: IP Payload Compression Protocol (IPComp) printer */
  22. #ifdef HAVE_CONFIG_H
  23. #include "config.h"
  24. #endif
  25. #include <netdissect-stdinc.h>
  26. struct ipcomp {
  27. uint8_t comp_nxt; /* Next Header */
  28. uint8_t comp_flags; /* Length of data, in 32bit */
  29. uint16_t comp_cpi; /* Compression parameter index */
  30. };
  31. #include "netdissect.h"
  32. #include "extract.h"
  33. void
  34. ipcomp_print(netdissect_options *ndo, register const u_char *bp)
  35. {
  36. register const struct ipcomp *ipcomp;
  37. uint16_t cpi;
  38. ipcomp = (const struct ipcomp *)bp;
  39. ND_TCHECK(*ipcomp);
  40. cpi = EXTRACT_16BITS(&ipcomp->comp_cpi);
  41. ND_PRINT((ndo, "IPComp(cpi=0x%04x)", cpi));
  42. /*
  43. * XXX - based on the CPI, we could decompress the packet here.
  44. * Packet buffer management is a headache (if we decompress,
  45. * packet will become larger).
  46. *
  47. * We would decompress the packet and then call a routine that,
  48. * based on ipcomp->comp_nxt, dissects the decompressed data.
  49. *
  50. * Until we do that, however, we just return -1, so that
  51. * the loop that processes "protocol"/"next header" types
  52. * stops - there's nothing more it can do with a compressed
  53. * payload.
  54. */
  55. return;
  56. trunc:
  57. ND_PRINT((ndo, "[|IPCOMP]"));
  58. return;
  59. }