phix_manager.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. /*
  2. * $Id: phix_manager.c 897 2011-08-28 21:43:57Z Kaori.Hagihara@gmail.com $
  3. *
  4. * Copyright (c) 2002-2014, Universite catholique de Louvain (UCL), Belgium
  5. * Copyright (c) 2002-2014, Professor Benoit Macq
  6. * Copyright (c) 2003-2004, Yannick Verschueren
  7. * Copyright (c) 2010-2011, Kaori Hagihara
  8. * All rights reserved.
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. * 1. Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in the
  17. * documentation and/or other materials provided with the distribution.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
  20. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  21. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  22. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  23. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  24. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  25. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  26. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  27. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  28. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  29. * POSSIBILITY OF SUCH DAMAGE.
  30. */
  31. /*! \file
  32. * \brief Modification of jpip.c from 2KAN indexer
  33. */
  34. #include "opj_includes.h"
  35. /*
  36. * Write faix box of phix
  37. *
  38. * @param[in] coff offset of j2k codestream
  39. * @param[in] compno component number
  40. * @param[in] cstr_info codestream information
  41. * @param[in] EPHused true if if EPH option used
  42. * @param[in] j2klen length of j2k codestream
  43. * @param[in] cio file output handle
  44. * @return length of faix box
  45. */
  46. int opj_write_phix(int coff, opj_codestream_info_t cstr_info, OPJ_BOOL EPHused,
  47. int j2klen, opj_stream_private_t *cio,
  48. opj_event_mgr_t * p_manager)
  49. {
  50. OPJ_BYTE l_data_header [8];
  51. OPJ_UINT32 len, compno, i;
  52. opj_jp2_box_t *box;
  53. OPJ_OFF_T lenp = 0;
  54. box = (opj_jp2_box_t *)opj_calloc((size_t)cstr_info.numcomps,
  55. sizeof(opj_jp2_box_t));
  56. if (box == NULL) {
  57. return 0;
  58. }
  59. for (i = 0; i < 2; i++) {
  60. if (i) {
  61. opj_stream_seek(cio, lenp, p_manager);
  62. }
  63. lenp = opj_stream_tell(cio);
  64. opj_stream_skip(cio, 4, p_manager); /* L [at the end] */
  65. opj_write_bytes(l_data_header, JPIP_PHIX, 4); /* PHIX */
  66. opj_stream_write_data(cio, l_data_header, 4, p_manager);
  67. opj_write_manf((int)i, cstr_info.numcomps, box, cio, p_manager);
  68. for (compno = 0; compno < (OPJ_UINT32)cstr_info.numcomps; compno++) {
  69. box[compno].length = (OPJ_UINT32)opj_write_phixfaix(coff, (int)compno,
  70. cstr_info, EPHused, j2klen, cio, p_manager);
  71. box[compno].type = JPIP_FAIX;
  72. }
  73. len = (OPJ_UINT32)(opj_stream_tell(cio) - lenp);
  74. opj_stream_seek(cio, 4, p_manager);
  75. opj_write_bytes(l_data_header, len, 4); /* L */
  76. opj_stream_write_data(cio, l_data_header, 4, p_manager);
  77. opj_stream_seek(cio, lenp + len, p_manager);
  78. }
  79. opj_free(box);
  80. return (int)len;
  81. }
  82. int opj_write_phixfaix(int coff, int compno, opj_codestream_info_t cstr_info,
  83. OPJ_BOOL EPHused, int j2klen, opj_stream_private_t *cio,
  84. opj_event_mgr_t * p_manager)
  85. {
  86. OPJ_UINT32 tileno, version, i, nmax, size_of_coding; /* 4 or 8 */
  87. opj_tile_info_t *tile_Idx;
  88. opj_packet_info_t packet;
  89. int resno, precno, layno;
  90. OPJ_UINT32 num_packet;
  91. int numOfres, numOfprec, numOflayers;
  92. OPJ_BYTE l_data_header [8];
  93. OPJ_OFF_T lenp;
  94. OPJ_UINT32 len;
  95. packet.end_ph_pos = packet.start_pos = -1;
  96. (void)EPHused; /* unused ? */
  97. if (j2klen > pow(2, 32)) {
  98. size_of_coding = 8;
  99. version = 1;
  100. } else {
  101. size_of_coding = 4;
  102. version = 0;
  103. }
  104. lenp = opj_stream_tell(cio);
  105. opj_stream_skip(cio, 4, p_manager); /* L [at the end] */
  106. opj_write_bytes(l_data_header, JPIP_FAIX, 4); /* FAIX */
  107. opj_stream_write_data(cio, l_data_header, 4, p_manager);
  108. opj_write_bytes(l_data_header, version, 1); /* Version 0 = 4 bytes */
  109. opj_stream_write_data(cio, l_data_header, 1, p_manager);
  110. nmax = 0;
  111. for (i = 0; i <= (OPJ_UINT32)cstr_info.numdecompos[compno]; i++) {
  112. nmax += (OPJ_UINT32)(cstr_info.tile[0].ph[i] * cstr_info.tile[0].pw[i] *
  113. cstr_info.numlayers);
  114. }
  115. opj_write_bytes(l_data_header, nmax, size_of_coding); /* NMAX */
  116. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  117. opj_write_bytes(l_data_header, (OPJ_UINT32)(cstr_info.tw * cstr_info.th),
  118. size_of_coding); /* M */
  119. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  120. for (tileno = 0; tileno < (OPJ_UINT32)(cstr_info.tw * cstr_info.th); tileno++) {
  121. tile_Idx = &cstr_info.tile[ tileno];
  122. num_packet = 0;
  123. numOfres = cstr_info.numdecompos[compno] + 1;
  124. for (resno = 0; resno < numOfres ; resno++) {
  125. numOfprec = tile_Idx->pw[resno] * tile_Idx->ph[resno];
  126. for (precno = 0; precno < numOfprec; precno++) {
  127. numOflayers = cstr_info.numlayers;
  128. for (layno = 0; layno < numOflayers; layno++) {
  129. switch (cstr_info.prog) {
  130. case OPJ_LRCP:
  131. packet = tile_Idx->packet[((layno * numOfres + resno) * cstr_info.numcomps +
  132. compno) * numOfprec + precno];
  133. break;
  134. case OPJ_RLCP:
  135. packet = tile_Idx->packet[((resno * numOflayers + layno) * cstr_info.numcomps +
  136. compno) * numOfprec + precno];
  137. break;
  138. case OPJ_RPCL:
  139. packet = tile_Idx->packet[((resno * numOfprec + precno) * cstr_info.numcomps +
  140. compno) * numOflayers + layno];
  141. break;
  142. case OPJ_PCRL:
  143. packet = tile_Idx->packet[((precno * cstr_info.numcomps + compno) * numOfres +
  144. resno) * numOflayers + layno];
  145. break;
  146. case OPJ_CPRL:
  147. packet = tile_Idx->packet[((compno * numOfprec + precno) * numOfres + resno) *
  148. numOflayers + layno];
  149. break;
  150. default:
  151. fprintf(stderr, "failed to ppix indexing\n");
  152. }
  153. opj_write_bytes(l_data_header, (OPJ_UINT32)(packet.start_pos - coff),
  154. size_of_coding); /* start position */
  155. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  156. opj_write_bytes(l_data_header,
  157. (OPJ_UINT32)(packet.end_ph_pos - packet.start_pos + 1),
  158. size_of_coding); /* length */
  159. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  160. num_packet++;
  161. }
  162. }
  163. }
  164. /* PADDING */
  165. while (num_packet < nmax) {
  166. opj_write_bytes(l_data_header, 0,
  167. size_of_coding); /* start position */
  168. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  169. opj_write_bytes(l_data_header, 0,
  170. size_of_coding); /* length */
  171. opj_stream_write_data(cio, l_data_header, size_of_coding, p_manager);
  172. num_packet++;
  173. }
  174. }
  175. len = (OPJ_UINT32)(opj_stream_tell(cio) - lenp);
  176. opj_stream_seek(cio, lenp, p_manager);
  177. opj_write_bytes(l_data_header, len, 4); /* L */
  178. opj_stream_write_data(cio, l_data_header, 4, p_manager);
  179. opj_stream_seek(cio, lenp + len, p_manager);
  180. return (int)len;
  181. }