inflate.c 5.9 KB

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