/* * Copyright (c) 2003-2004, Yannick Verschueren * Copyright (c) 2003-2004, Communications and remote sensing Laboratory, Universite catholique de Louvain, Belgium * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #include #include #include #include #include #include #include "j2k.h" #include "cio.h" #include "tcd.h" #include "int.h" #define JPIP_CIDX 0x63696478 /* Codestream index */ #define JPIP_CPTR 0x63707472 /* Codestream Finder Box */ #define JPIP_MANF 0x6d616e66 /* Manifest Box */ #define JPIP_FAIX 0x66616978 /* Fragment array Index box */ #define JPIP_MHIX 0x6d686978 /* Main Header Index Table */ #define JPIP_TPIX 0x74706978 /* Tile-part Index Table box */ #define JPIP_THIX 0x74686978 /* Tile header Index Table box */ #define JPIP_PPIX 0x70706978 /* Precinct Packet Index Table box */ #define JPIP_PHIX 0x70686978 /* Packet Header index Table */ #define JPIP_FIDX 0x66696478 /* File Index */ #define JPIP_FPTR 0x66707472 /* File Finder */ #define JPIP_PRXY 0x70727879 /* Proxy boxes */ #define JPIP_IPTR 0x69707472 /* Index finder box */ #define JPIP_PHLD 0x70686c64 /* Place holder */ #define JP2C 0x6a703263 //static info_marker_t marker_jpip[32], marker_local_jpip[32]; /* SIZE to precise ! */ //static int num_marker_jpip, num_marker_local_jpip; /* * Write the CPTR box * * Codestream finder box (box) * */ void jpip_write_cptr(int offset, info_image_t img) { int len, lenp; lenp=cio_tell(); cio_skip(4); /* L [at the end] */ cio_write(JPIP_CPTR,4); /* T */ cio_write(0,2); /* DR A PRECISER !! */ cio_write(0,2); /* CONT */ cio_write(offset,8); /* COFF A PRECISER !! */ cio_write(img.codestream_size,8); /* CLEN */ len=cio_tell()-lenp; cio_seek(lenp); cio_write(len, 4); /* L */ cio_seek(lenp+len); } /* * Read the CPTR box * * Codestream finder box (box) * */ void jpip_read_cptr() { int DR, CONT; long long Coff, codestream_size; DR = cio_read(2); /* DR */ CONT = cio_read(2); /* CONT */ Coff = cio_read(8); /* COFF */ codestream_size = cio_read(8); /* CLEN */ } /* * Write the MANF box * * Manifest box (box) * */ void jpip_write_manf(int second, int v, info_marker_t *marker) { int len, lenp, i; lenp=cio_tell(); cio_skip(4); /* L [at the end] */ cio_write(JPIP_MANF,4); /* T */ if (second) /* Write only during the second pass */ { for(i=0;i= 0; i--) /* COC */ { cio_write(img.marker_mul.COC[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.COC[i].start_pos, 8); cio_write(img.marker_mul.COC[i].len, 2); } for(i = img.marker_mul.num_RGN - 1; i >= 0; i--) /* RGN */ { cio_write(img.marker_mul.RGN[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.RGN[i].start_pos, 8); cio_write(img.marker_mul.RGN[i].len, 2); } for(i = img.marker_mul.num_QCC - 1; i >= 0; i--) /* QCC */ { cio_write(img.marker_mul.QCC[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.QCC[i].start_pos, 8); cio_write(img.marker_mul.QCC[i].len, 2); } for(i = img.marker_mul.num_TLM - 1; i >= 0; i--) /* TLM */ { cio_write(img.marker_mul.TLM[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.TLM[i].start_pos, 8); cio_write(img.marker_mul.TLM[i].len, 2); } for(i = img.marker_mul.num_PLM - 1; i >= 0; i--) /* PLM */ { cio_write(img.marker_mul.PLM[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.PLM[i].start_pos, 8); cio_write(img.marker_mul.PLM[i].len, 2); } for(i = img.marker_mul.num_PPM - 1; i >= 0; i--) /* PPM */ { cio_write(img.marker_mul.PPM[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.PPM[i].start_pos, 8); cio_write(img.marker_mul.PPM[i].len, 2); } for(i = img.marker_mul.num_COM - 1; i >= 0; i--) /* COM */ { cio_write(img.marker_mul.COM[i].type, 2); cio_write(i, 2); cio_write(img.marker_mul.COM[i].start_pos, 8); cio_write(img.marker_mul.COM[i].len, 2); } } else /* TILE HEADER */ { tile = &img.tile[tileno]; cio_write(tile->tile_parts[0].length_header, 8); /* TLEN */ for(i = 0; i < tile->num_marker; i++) /* Marker restricted to 1 apparition */ { cio_write(tile->marker[i].type, 2); cio_write(0, 2); cio_write(tile->marker[i].start_pos, 8); cio_write(tile->marker[i].len, 2); } /* Marker NOT restricted to 1 apparition */ for(i = tile->marker_mul.num_COC - 1; i >= 0; i--) /* COC */ { cio_write(tile->marker_mul.COC[i].type, 2); cio_write(i, 2); cio_write(tile->marker_mul.COC[i].start_pos, 8); cio_write(tile->marker_mul.COC[i].len, 2); } for(i = tile->marker_mul.num_RGN - 1; i >= 0; i--) /* RGN */ { cio_write(tile->marker_mul.RGN[i].type, 2); cio_write(i, 2); cio_write(tile->marker_mul.RGN[i].start_pos, 8); cio_write(tile->marker_mul.RGN[i].len, 2); } for(i = tile->marker_mul.num_QCC - 1; i >= 0; i--) /* QCC */ { cio_write(tile->marker_mul.QCC[i].type, 2); cio_write(i, 2); cio_write(tile->marker_mul.QCC[i].start_pos, 8); cio_write(tile->marker_mul.QCC[i].len, 2); } for(i = tile->marker_mul.num_PLT - 1; i >= 0; i--) /* PLT */ { cio_write(tile->marker_mul.PLT[i].type,2); cio_write(i,2); cio_write(tile->marker_mul.PLT[i].start_pos,8); cio_write(tile->marker_mul.PLT[i].len,2); } for(i = tile->marker_mul.num_PPT - 1; i >= 0; i--) /* PPT */ { cio_write(tile->marker_mul.PPT[i].type, 2); cio_write(i, 2); cio_write(tile->marker_mul.PPT[i].start_pos, 8); cio_write(tile->marker_mul.PPT[i].len, 2); } for(i = tile->marker_mul.num_COM - 1; i >= 0; i--) /* COM */ { cio_write(tile->marker_mul.COM[i].type, 2); cio_write(i, 2); cio_write(tile->marker_mul.COM[i].start_pos, 8); cio_write(tile->marker_mul.COM[i].len, 2); } } len=cio_tell()-lenp; cio_seek(lenp); cio_write(len, 4); /* L */ cio_seek(lenp+len); return len; } /* * Read the MHIX box * * Main Header Index Table (box) * */ void jpip_read_mhix(int len) { int i, v, marker_type, marker_start_pos, marker_len, marker_remains; v = (len - 8) / 14; for (i=0; icompo[compno]; int correction; num_packet=0; if(j2k_cp->tcps[tileno].csty&J2K_CP_CSTY_EPH) correction=3; else correction=1; for(resno=0;resnoreso[resno]; for (precno=0;precnoprec[precno]; for(layno=0;laynolayer[layno]; cio_write(layer_Idx->offset,(version & 0x01)?8:4); /* start position */ cio_write((layer_Idx->len_header-correction)?0:layer_Idx->len,(version & 0x01)?8:4); /* length */ if (version & 0x02) cio_write(0,4); /* Aux_i,j : Auxiliary value */ num_packet++; } } } /* PADDING */ while (num_packet < img.num_packet_max) { cio_write(0,(version & 0x01)?8:4); /* start position */ cio_write(0,(version & 0x01)?8:4); /* length */ if (version & 0x02) cio_write(0,4); /* Aux_i,j : Auxiliary value */ num_packet++; } } break; case 3: /* PHIX NOT FINISHED !! */ cio_write(img.num_packet_max,(version & 0x01)?8:4); /* NMAX */ cio_write(img.tw*img.th,(version & 0x01)?8:4); /* M */ for(tileno=0;tilenocompo[compno]; int correction; num_packet = 0; if(j2k_cp->tcps[tileno].csty&J2K_CP_CSTY_EPH) correction=3; else correction=1; for(resno=0;resnoreso[resno]; for (precno=0;precnoprec[precno]; for(layno=0;laynolayer[layno]; cio_write(layer_Idx->offset_header,(version & 0x01)?8:4); /* start position */ cio_write((layer_Idx->len_header-correction)?0:layer_Idx->len_header,(version & 0x01)?8:4); /* length */ if (version & 0x02) cio_write(0,4); /* Aux_i,j : Auxiliary value */ num_packet++; } } } /* PADDING */ while (num_packettw*j2k_cp->th); for ( i = 0; i < 2 ; i++ ) { if (i) cio_seek(lenp); lenp = cio_tell(); cio_skip(4); /* L [at the end] */ cio_write(JPIP_THIX, 4); /* THIX */ jpip_write_manf(i, j2k_cp->tw*j2k_cp->th, marker); num_marker_local_jpip=img.Comp; for (tileno = 0; tileno < j2k_cp->tw*j2k_cp->th; tileno++) { marker[tileno].len = jpip_write_mhix(img, 1, tileno); marker[tileno].type = JPIP_MHIX; } len=cio_tell()-lenp; cio_seek(lenp); cio_write(len, 4); /* L */ cio_seek(lenp+len); } free(marker); return len; } /* * Write the PPIX box * * Precinct Packet Index table box (superbox) * */ int jpip_write_ppix(info_image_t img,j2k_cp_t *j2k_cp) { int len, lenp, compno, i; info_marker_t *marker; int num_marker_local_jpip; marker = (info_marker_t*)calloc(sizeof(info_marker_t), img.Comp); for (i=0;i<2;i++) { if (i) cio_seek(lenp); lenp=cio_tell(); cio_skip(4); /* L [at the end] */ cio_write(JPIP_PPIX, 4); /* PPIX */ jpip_write_manf(i,img.Comp,marker); num_marker_local_jpip=img.Comp; for (compno=0; compno