inflate.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. /* inflate.c -- zlib interface to inflate modules
  2. * Copyright (C) 1995-1998 Mark Adler
  3. * For conditions of distribution and use, see copyright notice in zlib.h
  4. */
  5. #include <linux/zutil.h>
  6. #include "infblock.h"
  7. #include "infutil.h"
  8. int zlib_inflate_workspacesize(void)
  9. {
  10. return sizeof(struct inflate_workspace);
  11. }
  12. int zlib_inflateReset(
  13. z_streamp z
  14. )
  15. {
  16. if (z == NULL || z->state == NULL || z->workspace == NULL)
  17. return Z_STREAM_ERROR;
  18. z->total_in = z->total_out = 0;
  19. z->msg = NULL;
  20. z->state->mode = z->state->nowrap ? BLOCKS : METHOD;
  21. zlib_inflate_blocks_reset(z->state->blocks, z, NULL);
  22. return Z_OK;
  23. }
  24. int zlib_inflateEnd(
  25. z_streamp z
  26. )
  27. {
  28. if (z == NULL || z->state == NULL || z->workspace == NULL)
  29. return Z_STREAM_ERROR;
  30. if (z->state->blocks != NULL)
  31. zlib_inflate_blocks_free(z->state->blocks, z);
  32. z->state = NULL;
  33. return Z_OK;
  34. }
  35. int zlib_inflateInit2_(
  36. z_streamp z,
  37. int w,
  38. const char *version,
  39. int stream_size
  40. )
  41. {
  42. if (version == NULL || version[0] != ZLIB_VERSION[0] ||
  43. stream_size != sizeof(z_stream) || z->workspace == NULL)
  44. return Z_VERSION_ERROR;
  45. /* initialize state */
  46. z->msg = NULL;
  47. z->state = &WS(z)->internal_state;
  48. z->state->blocks = NULL;
  49. /* handle undocumented nowrap option (no zlib header or check) */
  50. z->state->nowrap = 0;
  51. if (w < 0)
  52. {
  53. w = - w;
  54. z->state->nowrap = 1;
  55. }
  56. /* set window size */
  57. if (w < 8 || w > 15)
  58. {
  59. zlib_inflateEnd(z);
  60. return Z_STREAM_ERROR;
  61. }
  62. z->state->wbits = (uInt)w;
  63. /* create inflate_blocks state */
  64. if ((z->state->blocks =
  65. zlib_inflate_blocks_new(z, z->state->nowrap ? NULL : zlib_adler32, (uInt)1 << w))
  66. == NULL)
  67. {
  68. zlib_inflateEnd(z);
  69. return Z_MEM_ERROR;
  70. }
  71. /* reset state */
  72. zlib_inflateReset(z);
  73. return Z_OK;
  74. }
  75. /*
  76. * At the end of a Deflate-compressed PPP packet, we expect to have seen
  77. * a `stored' block type value but not the (zero) length bytes.
  78. */
  79. static int zlib_inflate_packet_flush(inflate_blocks_statef *s)
  80. {
  81. if (s->mode != LENS)
  82. return Z_DATA_ERROR;
  83. s->mode = TYPE;
  84. return Z_OK;
  85. }
  86. int zlib_inflateInit_(
  87. z_streamp z,
  88. const char *version,
  89. int stream_size
  90. )
  91. {
  92. return zlib_inflateInit2_(z, DEF_WBITS, version, stream_size);
  93. }
  94. #undef NEEDBYTE
  95. #undef NEXTBYTE
  96. #define NEEDBYTE {if(z->avail_in==0)goto empty;r=trv;}
  97. #define NEXTBYTE (z->avail_in--,z->total_in++,*z->next_in++)
  98. int zlib_inflate(
  99. z_streamp z,
  100. int f
  101. )
  102. {
  103. int r, trv;
  104. uInt b;
  105. if (z == NULL || z->state == NULL || z->next_in == NULL)
  106. return Z_STREAM_ERROR;
  107. trv = f == Z_FINISH ? Z_BUF_ERROR : Z_OK;
  108. r = Z_BUF_ERROR;
  109. while (1) switch (z->state->mode)
  110. {
  111. case METHOD:
  112. NEEDBYTE
  113. if (((z->state->sub.method = NEXTBYTE) & 0xf) != Z_DEFLATED)
  114. {
  115. z->state->mode = I_BAD;
  116. z->msg = (char*)"unknown compression method";
  117. z->state->sub.marker = 5; /* can't try inflateSync */
  118. break;
  119. }
  120. if ((z->state->sub.method >> 4) + 8 > z->state->wbits)
  121. {
  122. z->state->mode = I_BAD;
  123. z->msg = (char*)"invalid window size";
  124. z->state->sub.marker = 5; /* can't try inflateSync */
  125. break;
  126. }
  127. z->state->mode = FLAG;
  128. case FLAG:
  129. NEEDBYTE
  130. b = NEXTBYTE;
  131. if (((z->state->sub.method << 8) + b) % 31)
  132. {
  133. z->state->mode = I_BAD;
  134. z->msg = (char*)"incorrect header check";
  135. z->state->sub.marker = 5; /* can't try inflateSync */
  136. break;
  137. }
  138. if (!(b & PRESET_DICT))
  139. {
  140. z->state->mode = BLOCKS;
  141. break;
  142. }
  143. z->state->mode = DICT4;
  144. case DICT4:
  145. NEEDBYTE
  146. z->state->sub.check.need = (uLong)NEXTBYTE << 24;
  147. z->state->mode = DICT3;
  148. case DICT3:
  149. NEEDBYTE
  150. z->state->sub.check.need += (uLong)NEXTBYTE << 16;
  151. z->state->mode = DICT2;
  152. case DICT2:
  153. NEEDBYTE
  154. z->state->sub.check.need += (uLong)NEXTBYTE << 8;
  155. z->state->mode = DICT1;
  156. case DICT1:
  157. NEEDBYTE
  158. z->state->sub.check.need += (uLong)NEXTBYTE;
  159. z->adler = z->state->sub.check.need;
  160. z->state->mode = DICT0;
  161. return Z_NEED_DICT;
  162. case DICT0:
  163. z->state->mode = I_BAD;
  164. z->msg = (char*)"need dictionary";
  165. z->state->sub.marker = 0; /* can try inflateSync */
  166. return Z_STREAM_ERROR;
  167. case BLOCKS:
  168. r = zlib_inflate_blocks(z->state->blocks, z, r);
  169. if (f == Z_PACKET_FLUSH && z->avail_in == 0 && z->avail_out != 0)
  170. r = zlib_inflate_packet_flush(z->state->blocks);
  171. if (r == Z_DATA_ERROR)
  172. {
  173. z->state->mode = I_BAD;
  174. z->state->sub.marker = 0; /* can try inflateSync */
  175. break;
  176. }
  177. if (r == Z_OK)
  178. r = trv;
  179. if (r != Z_STREAM_END)
  180. return r;
  181. r = trv;
  182. zlib_inflate_blocks_reset(z->state->blocks, z, &z->state->sub.check.was);
  183. if (z->state->nowrap)
  184. {
  185. z->state->mode = I_DONE;
  186. break;
  187. }
  188. z->state->mode = CHECK4;
  189. case CHECK4:
  190. NEEDBYTE
  191. z->state->sub.check.need = (uLong)NEXTBYTE << 24;
  192. z->state->mode = CHECK3;
  193. case CHECK3:
  194. NEEDBYTE
  195. z->state->sub.check.need += (uLong)NEXTBYTE << 16;
  196. z->state->mode = CHECK2;
  197. case CHECK2:
  198. NEEDBYTE
  199. z->state->sub.check.need += (uLong)NEXTBYTE << 8;
  200. z->state->mode = CHECK1;
  201. case CHECK1:
  202. NEEDBYTE
  203. z->state->sub.check.need += (uLong)NEXTBYTE;
  204. if (z->state->sub.check.was != z->state->sub.check.need)
  205. {
  206. z->state->mode = I_BAD;
  207. z->msg = (char*)"incorrect data check";
  208. z->state->sub.marker = 5; /* can't try inflateSync */
  209. break;
  210. }
  211. z->state->mode = I_DONE;
  212. case I_DONE:
  213. return Z_STREAM_END;
  214. case I_BAD:
  215. return Z_DATA_ERROR;
  216. default:
  217. return Z_STREAM_ERROR;
  218. }
  219. empty:
  220. if (f != Z_PACKET_FLUSH)
  221. return r;
  222. z->state->mode = I_BAD;
  223. z->msg = (char *)"need more for packet flush";
  224. z->state->sub.marker = 0; /* can try inflateSync */
  225. return Z_DATA_ERROR;
  226. }