* PPM markers handling modified (comment keyword : ppmbug1)
* empty resolution level or subband handling (comment keyword : sizebug1) * index_on field forwarded to j2k_cp_t structure
This commit is contained in:
		| @@ -288,7 +288,7 @@ int main(int argc, char **argv) | |||||||
|   cblockh_init = 64; |   cblockh_init = 64; | ||||||
|   cp.tw = 1; |   cp.tw = 1; | ||||||
|   cp.th = 1; |   cp.th = 1; | ||||||
|   img.index_on = 0; |   cp.index_on = 0; | ||||||
|   Prog_order = 0; |   Prog_order = 0; | ||||||
|   numpocs = 0; |   numpocs = 0; | ||||||
|   mode = 0; |   mode = 0; | ||||||
| @@ -491,7 +491,7 @@ int main(int argc, char **argv) | |||||||
|       /* ----------------------------------------------------- */ |       /* ----------------------------------------------------- */ | ||||||
|     case 'x':			/* creation of index file */ |     case 'x':			/* creation of index file */ | ||||||
|       index = optarg; |       index = optarg; | ||||||
|       img.index_on = 1; |       cp.index_on = 1; | ||||||
|       break; |       break; | ||||||
|       /* ----------------------------------------------------- */ |       /* ----------------------------------------------------- */ | ||||||
|     case 'p':			/* progression order */ |     case 'p':			/* progression order */ | ||||||
|   | |||||||
| @@ -72,7 +72,6 @@ typedef struct { | |||||||
|   int x0, y0;          /* XOsiz, YOsiz              */ |   int x0, y0;          /* XOsiz, YOsiz              */ | ||||||
|   int x1, y1;          /* Xsiz, Ysiz                */  |   int x1, y1;          /* Xsiz, Ysiz                */  | ||||||
|   int numcomps;        /* number of components      */ |   int numcomps;        /* number of components      */ | ||||||
|   int index_on;        /* 0 = no index || 1 = index */ |  | ||||||
|   j2k_comp_t *comps;   /* image-components          */ |   j2k_comp_t *comps;   /* image-components          */ | ||||||
| } j2k_image_t; | } j2k_image_t; | ||||||
|  |  | ||||||
| @@ -128,6 +127,7 @@ typedef struct { | |||||||
|   int ppm;                   /* If ppm == 1 --> there was a PPM marker for the present tile             */ |   int ppm;                   /* If ppm == 1 --> there was a PPM marker for the present tile             */ | ||||||
|   int ppm_store;             /* Use in case of multiple marker PPM (number of info already store)       */ |   int ppm_store;             /* Use in case of multiple marker PPM (number of info already store)       */ | ||||||
|   int ppm_previous;          /* Use in case of multiple marker PPM (case on non-finished previous info) */ |   int ppm_previous;          /* Use in case of multiple marker PPM (case on non-finished previous info) */ | ||||||
|  |   int index_on;		     /* 0 = no index || 1 = index */ | ||||||
|   j2k_tcp_t *tcps;           /* tile coding parameters                                                  */ |   j2k_tcp_t *tcps;           /* tile coding parameters                                                  */ | ||||||
| } j2k_cp_t; | } j2k_cp_t; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -702,15 +702,18 @@ void j2k_read_ppm() | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     j = j2k_cp->ppm_store; |     j = j2k_cp->ppm_store; | ||||||
|     if (Z_ppm == 0)		/* First PPM marker */ |     if (Z_ppm == 0) {		/* First PPM marker */ | ||||||
|       j2k_cp->ppm_data = |       j2k_cp->ppm_data = | ||||||
| 	(unsigned char *) calloc(N_ppm, sizeof(unsigned char)); | 	(unsigned char *) calloc(N_ppm, sizeof(unsigned char)); | ||||||
|     else			/* NON-first PPM marker */ |       j2k_cp->ppm_len = N_ppm;	      //Add antonin : ppmbug1 | ||||||
|  |     } else {			/* NON-first PPM marker */ | ||||||
|       j2k_cp->ppm_data = |       j2k_cp->ppm_data = | ||||||
| 	(unsigned char *) realloc(j2k_cp->ppm_data, | 	(unsigned char *) realloc(j2k_cp->ppm_data, | ||||||
| 				  (N_ppm + | 				  (N_ppm + | ||||||
| 				   j2k_cp->ppm_store) * | 				   j2k_cp->ppm_store) * | ||||||
| 				  sizeof(unsigned char)); | 				  sizeof(unsigned char)); | ||||||
|  |       j2k_cp->ppm_len = N_ppm + j2k_cp->ppm_store; //Add antonin : ppmbug1 | ||||||
|  |     } | ||||||
|  |  | ||||||
|     for (i = N_ppm; i > 0; i--) {	/* Read packet header */ |     for (i = N_ppm; i > 0; i--) {	/* Read packet header */ | ||||||
|       j2k_cp->ppm_data[j] = cio_read(1); |       j2k_cp->ppm_data[j] = cio_read(1); | ||||||
| @@ -738,11 +741,14 @@ void j2k_read_ppt() | |||||||
|     tcp->ppt_data = |     tcp->ppt_data = | ||||||
|       (unsigned char *) calloc(len - 3, sizeof(unsigned char)); |       (unsigned char *) calloc(len - 3, sizeof(unsigned char)); | ||||||
|     tcp->ppt_store = 0; |     tcp->ppt_store = 0; | ||||||
|   } else			/* NON-first PPT marker */ |     tcp->ppt_len = len-3;	//Add antonin : ppmbug1 | ||||||
|  |   } else {			/* NON-first PPT marker */ | ||||||
|     tcp->ppt_data = |     tcp->ppt_data = | ||||||
|       (unsigned char *) realloc(tcp->ppt_data, |       (unsigned char *) realloc(tcp->ppt_data, | ||||||
| 				(len - 3 + | 				(len - 3 + | ||||||
| 				 tcp->ppt_store) * sizeof(unsigned char)); | 				 tcp->ppt_store) * sizeof(unsigned char)); | ||||||
|  |     tcp->ppt_len=len - 3 + tcp->ppt_store;    //Add antonin : ppmbug1 | ||||||
|  |   } | ||||||
|  |  | ||||||
|   j = tcp->ppt_store; |   j = tcp->ppt_store; | ||||||
|   for (i = len - 3; i > 0; i--) { |   for (i = len - 3; i > 0; i--) { | ||||||
| @@ -972,7 +978,7 @@ LIBJ2K_API int j2k_encode(j2k_image_t * img, j2k_cp_t * cp, char *output, | |||||||
|   /* j2k_dump_cp(j2k_img, j2k_cp); */ |   /* j2k_dump_cp(j2k_img, j2k_cp); */ | ||||||
|  |  | ||||||
|   /* INDEX >> */ |   /* INDEX >> */ | ||||||
|   info_IM.index_on = j2k_img->index_on; |   info_IM.index_on = j2k_cp->index_on; | ||||||
|   if (info_IM.index_on) { |   if (info_IM.index_on) { | ||||||
|     info_IM.tile = |     info_IM.tile = | ||||||
|       (info_tile *) malloc(j2k_cp->tw * j2k_cp->th * sizeof(info_tile)); |       (info_tile *) malloc(j2k_cp->tw * j2k_cp->th * sizeof(info_tile)); | ||||||
|   | |||||||
| @@ -74,7 +74,6 @@ typedef struct { | |||||||
|   int x0, y0;			/* XOsiz, YOsiz              */ |   int x0, y0;			/* XOsiz, YOsiz              */ | ||||||
|   int x1, y1;			/* Xsiz, Ysiz                */ |   int x1, y1;			/* Xsiz, Ysiz                */ | ||||||
|   int numcomps;			/* number of components      */ |   int numcomps;			/* number of components      */ | ||||||
|   int index_on;			/* 0 = no index || 1 = index */ |  | ||||||
|   int color_space;		/* sRGB, Greyscale or YUV */ |   int color_space;		/* sRGB, Greyscale or YUV */ | ||||||
|   j2k_comp_t *comps;		/* image-components          */ |   j2k_comp_t *comps;		/* image-components          */ | ||||||
| } j2k_image_t; | } j2k_image_t; | ||||||
| @@ -120,6 +119,7 @@ typedef struct { | |||||||
|   unsigned char *ppt_data;	/* packet header store there for futur use in t2_decode_packet       */ |   unsigned char *ppt_data;	/* packet header store there for futur use in t2_decode_packet       */ | ||||||
|   int ppt;			/* If ppt == 1 --> there was a PPT marker for the present tile       */ |   int ppt;			/* If ppt == 1 --> there was a PPT marker for the present tile       */ | ||||||
|   int ppt_store;		/* Use in case of multiple marker PPT (number of info already store) */ |   int ppt_store;		/* Use in case of multiple marker PPT (number of info already store) */ | ||||||
|  |   int ppt_len;			/* ppmbug1 */ | ||||||
|   float distoratio[100];	/* add fixed_quality */ |   float distoratio[100];	/* add fixed_quality */ | ||||||
|   j2k_tccp_t *tccps;		/* tile-component coding parameters                                  */ |   j2k_tccp_t *tccps;		/* tile-component coding parameters                                  */ | ||||||
| } j2k_tcp_t; | } j2k_tcp_t; | ||||||
| @@ -133,6 +133,7 @@ typedef struct { | |||||||
|   int fixed_quality;		/* add fixed_quality */ |   int fixed_quality;		/* add fixed_quality */ | ||||||
|   int reduce_on;		/* option reduce is used if reduce = 1 */ |   int reduce_on;		/* option reduce is used if reduce = 1 */ | ||||||
|   int reduce_value;		/* if option reduce is used -> original dimension divided by 2^value */ |   int reduce_value;		/* if option reduce is used -> original dimension divided by 2^value */ | ||||||
|  |   int index_on;			/* 0 = no index || 1 = index */ | ||||||
|   int tx0, ty0;			/* XTOsiz, YTOsiz                    */ |   int tx0, ty0;			/* XTOsiz, YTOsiz                    */ | ||||||
|   int tdx, tdy;			/* XTsiz, YTsiz                      */ |   int tdx, tdy;			/* XTsiz, YTsiz                      */ | ||||||
|   char *comment;		/* comment for coding                */ |   char *comment;		/* comment for coding                */ | ||||||
| @@ -143,6 +144,7 @@ typedef struct { | |||||||
|   int ppm;			/* If ppm == 1 --> there was a PPM marker for the present tile             */ |   int ppm;			/* If ppm == 1 --> there was a PPM marker for the present tile             */ | ||||||
|   int ppm_store;		/* Use in case of multiple marker PPM (number of info already store)       */ |   int ppm_store;		/* Use in case of multiple marker PPM (number of info already store)       */ | ||||||
|   int ppm_previous;		/* Use in case of multiple marker PPM (case on non-finished previous info) */ |   int ppm_previous;		/* Use in case of multiple marker PPM (case on non-finished previous info) */ | ||||||
|  |   int ppm_len;			/* ppmbug1 */ | ||||||
|   j2k_tcp_t *tcps;		/* tile coding parameters                                                  */ |   j2k_tcp_t *tcps;		/* tile coding parameters                                                  */ | ||||||
|   int *matrice;			/* Fixed layer                                                             */ |   int *matrice;			/* Fixed layer                                                             */ | ||||||
| } j2k_cp_t; | } j2k_cp_t; | ||||||
|   | |||||||
| @@ -97,8 +97,8 @@ pi_iterator_t *pi_create(j2k_image_t * img, j2k_cp_t * cp, int tileno) | |||||||
| 	py0 = int_floordivpow2(ry0, res->pdy) << res->pdy; | 	py0 = int_floordivpow2(ry0, res->pdy) << res->pdy; | ||||||
| 	px1 = int_ceildivpow2(rx1, res->pdx) << res->pdx; | 	px1 = int_ceildivpow2(rx1, res->pdx) << res->pdx; | ||||||
| 	py1 = int_ceildivpow2(ry1, res->pdy) << res->pdy; | 	py1 = int_ceildivpow2(ry1, res->pdy) << res->pdy; | ||||||
| 	res->pw = (px1 - px0) >> res->pdx; | 	res->pw = (rx0==rx1)?0:((px1 - px0) >> res->pdx); //Mod Antonin : sizebug1 | ||||||
| 	res->ph = (py1 - py0) >> res->pdy; | 	res->ph = (ry0==ry1)?0:((py1 - py0) >> res->pdy); //Mod Antonin : sizebug1 | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -291,6 +291,11 @@ int pi_next_rpcl(pi_iterator_t * pi) | |||||||
| 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | ||||||
| 	    continue; | 	    continue; | ||||||
| 	  } | 	  } | ||||||
|  |  | ||||||
|  | 	  //Add Antonin : sizebug1 | ||||||
|  | 	  if ((res->pw==0)||(res->pw==0)) continue; | ||||||
|  | 	  //ddA | ||||||
|  |  | ||||||
| 	  prci = | 	  prci = | ||||||
| 	    int_floordivpow2(int_ceildiv | 	    int_floordivpow2(int_ceildiv | ||||||
| 			     (pi->x, comp->dx << levelno), | 			     (pi->x, comp->dx << levelno), | ||||||
| @@ -382,6 +387,11 @@ int pi_next_pcrl(pi_iterator_t * pi) | |||||||
| 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | ||||||
| 	    continue; | 	    continue; | ||||||
| 	  } | 	  } | ||||||
|  |  | ||||||
|  | 	  //Add Antonin : sizebug1 | ||||||
|  | 	  if ((res->pw==0)||(res->pw==0)) continue; | ||||||
|  | 	  //ddA | ||||||
|  |  | ||||||
| 	  prci = | 	  prci = | ||||||
| 	    int_floordivpow2(int_ceildiv | 	    int_floordivpow2(int_ceildiv | ||||||
| 			     (pi->x, comp->dx << levelno), | 			     (pi->x, comp->dx << levelno), | ||||||
| @@ -468,6 +478,11 @@ int pi_next_cprl(pi_iterator_t * pi) | |||||||
| 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | 	       || (pi->y == pi->ty0 && (try0 << levelno) % (1 << rpx)))) { | ||||||
| 	    continue; | 	    continue; | ||||||
| 	  } | 	  } | ||||||
|  |  | ||||||
|  | 	  //Add Antonin : sizebug1 | ||||||
|  | 	  if ((res->pw==0)||(res->pw==0)) continue; | ||||||
|  | 	  //ddA | ||||||
|  |  | ||||||
| 	  prci = | 	  prci = | ||||||
| 	    int_floordivpow2(int_ceildiv | 	    int_floordivpow2(int_ceildiv | ||||||
| 			     (pi->x, comp->dx << levelno), | 			     (pi->x, comp->dx << levelno), | ||||||
|   | |||||||
							
								
								
									
										137
									
								
								libopenjpeg/t2.c
									
									
									
									
									
								
							
							
						
						
									
										137
									
								
								libopenjpeg/t2.c
									
									
									
									
									
								
							| @@ -303,12 +303,18 @@ int t2_decode_packet(unsigned char *src, int len, tcd_tile_t * tile, | |||||||
|   tcd_tilecomp_t *tilec = &tile->comps[compno]; |   tcd_tilecomp_t *tilec = &tile->comps[compno]; | ||||||
|   tcd_resolution_t *res = &tilec->resolutions[resno]; |   tcd_resolution_t *res = &tilec->resolutions[resno]; | ||||||
|   unsigned char *c = src; |   unsigned char *c = src; | ||||||
|  |   unsigned char *hd = NULL; | ||||||
|   int present; |   int present; | ||||||
|  |  | ||||||
|   if (layno == 0) { |   if (layno == 0) { | ||||||
|     for (bandno = 0; bandno < res->numbands; bandno++) { |     for (bandno = 0; bandno < res->numbands; bandno++) { | ||||||
|       tcd_band_t *band = &res->bands[bandno]; |       tcd_band_t *band = &res->bands[bandno]; | ||||||
|       tcd_precinct_t *prc = &band->precincts[precno]; |       tcd_precinct_t *prc = &band->precincts[precno]; | ||||||
|  |        | ||||||
|  |       //Add Antonin : sizebug1 | ||||||
|  |       if ((band->x1-band->x0 == 0)||(band->y1-band->y0 == 0)) continue; | ||||||
|  |       //ddA | ||||||
|  |        | ||||||
|       tgt_reset(prc->incltree); |       tgt_reset(prc->incltree); | ||||||
|       tgt_reset(prc->imsbtree); |       tgt_reset(prc->imsbtree); | ||||||
|       for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { |       for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { | ||||||
| @@ -317,57 +323,70 @@ int t2_decode_packet(unsigned char *src, int len, tcd_tile_t * tile, | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |    | ||||||
|   /* When the marker PPT/PPM is used the packet header are store in PPT/PPM marker |   // SOP markers | ||||||
|      This part deal with this caracteristic |   if (tcp->csty & J2K_CP_CSTY_SOP) { | ||||||
|      step 1: Read packet header in the saved structure |     if ((*c) != 0xff || (*(c + 1) != 0x91)) { | ||||||
|      step 2: (futher) return to codestream for decoding */ |       printf("Warning : expected SOP marker\n"); | ||||||
|   if (cp->ppm == 1) {		/* PPM */ |     } else { | ||||||
|     c = cp->ppm_data; |       c += 6; | ||||||
|     bio_init_dec(c, 1000); |  | ||||||
|   } else { |  | ||||||
|     if (tcp->ppt == 1) {	/* PPT */ |  | ||||||
|       c = tcp->ppt_data; |  | ||||||
|       bio_init_dec(c, 1000); |  | ||||||
|     } else {			/* Normal Case */ |  | ||||||
|  |  | ||||||
|       if (tcp->csty & J2K_CP_CSTY_SOP) { |  | ||||||
| 	if ((*c) != 255 || (*(c + 1) != 145)) { |  | ||||||
| 	  printf("Error : expected SOP marker [1]!!!\n"); |  | ||||||
| 	} |  | ||||||
| 	c += 6; |  | ||||||
|       } |  | ||||||
|       bio_init_dec(c, src + len - c); |  | ||||||
|     } |     } | ||||||
|  |     //TODO : check the Nsop value | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* When the marker PPT/PPM is used the packet header are store in PPT/PPM marker | ||||||
|  |   This part deal with this caracteristic | ||||||
|  |   step 1: Read packet header in the saved structure | ||||||
|  |   step 2: Return to codestream for decoding */ | ||||||
|  |  | ||||||
|  |   if (cp->ppm == 1) {		/* PPM */ | ||||||
|  |     hd = cp->ppm_data; | ||||||
|  |     bio_init_dec(hd, cp->ppm_len); //Mod Antonin : ppmbug1 | ||||||
|  |   } else if (tcp->ppt == 1) {	/* PPT */ | ||||||
|  |     hd = tcp->ppt_data; | ||||||
|  |     bio_init_dec(hd, tcp->ppt_len);  //Mod Antonin : ppmbug1 | ||||||
|  |   } else {			/* Normal Case */ | ||||||
|  |     hd = c; | ||||||
|  |     bio_init_dec(hd, src+len-hd); | ||||||
|  |   } | ||||||
|  |    | ||||||
|   present = bio_read(1); |   present = bio_read(1); | ||||||
|  |  | ||||||
|   if (!present) { |   if (!present) { | ||||||
|     bio_inalign(); |     bio_inalign(); | ||||||
|     /* Normal case */ |     hd += bio_numbytes(); | ||||||
|     c += bio_numbytes(); |  | ||||||
|  |     // EPH markers | ||||||
|     if (tcp->csty & J2K_CP_CSTY_EPH) { |     if (tcp->csty & J2K_CP_CSTY_EPH) { | ||||||
|       if ((*c) != 255 || (*(c + 1) != 146)) { |       if ((*hd) != 0xff || (*(hd + 1) != 0x92)) { | ||||||
| 	printf("Error : expected EPH marker [1]!!!\n"); | 	printf("Error : expected EPH marker\n"); | ||||||
|  |       } else { | ||||||
|  | 	hd += 2; | ||||||
|       } |       } | ||||||
|       c += 2; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* PPT and PPM dealing */ |     if (cp->ppm == 1) {		/* PPM case */ | ||||||
|     if (cp->ppm == 1) {		/* PPM */ |       cp->ppm_len+=cp->ppm_data-hd; | ||||||
|       cp->ppm_data = c; |       cp->ppm_data = hd; | ||||||
|       return 0; |       return c - src; | ||||||
|     } |     } | ||||||
|     if (tcp->ppt == 1) {	/* PPT */ |     if (tcp->ppt == 1) {	/* PPT case */ | ||||||
|       tcp->ppt_data = c; |       tcp->ppt_len+=tcp->ppt_data-hd; | ||||||
|       return 0; |       tcp->ppt_data = hd; | ||||||
|  |       return c - src; | ||||||
|     } |     } | ||||||
|     return c - src; |  | ||||||
|  |     return hd - src; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   for (bandno = 0; bandno < res->numbands; bandno++) { |   for (bandno = 0; bandno < res->numbands; bandno++) { | ||||||
|     tcd_band_t *band = &res->bands[bandno]; |     tcd_band_t *band = &res->bands[bandno]; | ||||||
|     tcd_precinct_t *prc = &band->precincts[precno]; |     tcd_precinct_t *prc = &band->precincts[precno]; | ||||||
|  |  | ||||||
|  |     //Add Antonin : sizebug1 | ||||||
|  |     if ((band->x1-band->x0 == 0)||(band->y1-band->y0 == 0)) continue; | ||||||
|  |     //ddA | ||||||
|  |  | ||||||
|     for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { |     for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { | ||||||
|       int included, increment, n; |       int included, increment, n; | ||||||
|       tcd_cblk_t *cblk = &prc->cblks[cblkno]; |       tcd_cblk_t *cblk = &prc->cblks[cblkno]; | ||||||
| @@ -423,45 +442,37 @@ int t2_decode_packet(unsigned char *src, int len, tcd_tile_t * tile, | |||||||
|   if (bio_inalign()) |   if (bio_inalign()) | ||||||
|     return -999; |     return -999; | ||||||
|  |  | ||||||
|   c += bio_numbytes(); |   hd += bio_numbytes(); | ||||||
|  |  | ||||||
|   if (tcp->csty & J2K_CP_CSTY_EPH) {	/* EPH marker */ |   // EPH markers | ||||||
|     if ((*c) != 255 || (*(c + 1) != 146)) { |   if (tcp->csty & J2K_CP_CSTY_EPH) { | ||||||
|       printf("Error : expected EPH marker [2]!!!\n"); |     if ((*hd) != 0xff || (*(hd + 1) != 0x92)) { | ||||||
|  |       printf("Error : expected EPH marker\n"); | ||||||
|  |     } else { | ||||||
|  |       hd += 2; | ||||||
|     } |     } | ||||||
|     c += 2; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* PPT Step 2 : see above for details */ |   if (cp->ppm==1) { | ||||||
|   if (cp->ppm == 1) { |     cp->ppm_len+=cp->ppm_data-hd; | ||||||
|     cp->ppm_data = c;		/* Update pointer */ |     cp->ppm_data = hd; | ||||||
|  |   } else if (tcp->ppt == 1) { | ||||||
|     c = src; |     tcp->ppt_len+=tcp->ppt_data-hd; | ||||||
|     if (tcp->csty & J2K_CP_CSTY_SOP) { |     tcp->ppt_data = hd; | ||||||
|       if ((*c) != 255 || (*(c + 1) != 145)) { |  | ||||||
| 	printf("Error : expected SOP marker [2] !!!\n"); |  | ||||||
|       } |  | ||||||
|       c += 6; |  | ||||||
|     } |  | ||||||
|     bio_init_dec(c, src + len - c); |  | ||||||
|   } else { |   } else { | ||||||
|     if (tcp->ppt == 1) { |     c=hd; | ||||||
|       tcp->ppt_data = c;	/* Update pointer */ |  | ||||||
|       c = src; |  | ||||||
|       if (tcp->csty & J2K_CP_CSTY_SOP) {	/* SOP marker */ |  | ||||||
| 	if ((*c) != 255 || (*(c + 1) != 145)) { |  | ||||||
| 	  printf("Error : expected SOP marker [2] !!!\n"); |  | ||||||
| 	} |  | ||||||
| 	c += 6; |  | ||||||
|       } |  | ||||||
|       bio_init_dec(c, src + len - c); |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   //bio_init_dec(c, src + len - c); | ||||||
|  |  | ||||||
|   for (bandno = 0; bandno < res->numbands; bandno++) { |   for (bandno = 0; bandno < res->numbands; bandno++) { | ||||||
|     tcd_band_t *band = &res->bands[bandno]; |     tcd_band_t *band = &res->bands[bandno]; | ||||||
|     tcd_precinct_t *prc = &band->precincts[precno]; |     tcd_precinct_t *prc = &band->precincts[precno]; | ||||||
|  |  | ||||||
|  |     //Add Antonin : sizebug1 | ||||||
|  |     if ((band->x1-band->x0 == 0)||(band->y1-band->y0 == 0)) continue; | ||||||
|  |     //ddA | ||||||
|  |  | ||||||
|     for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { |     for (cblkno = 0; cblkno < prc->cw * prc->ch; cblkno++) { | ||||||
|       tcd_cblk_t *cblk = &prc->cblks[cblkno]; |       tcd_cblk_t *cblk = &prc->cblks[cblkno]; | ||||||
|       tcd_seg_t *seg; |       tcd_seg_t *seg; | ||||||
|   | |||||||
| @@ -658,8 +658,8 @@ void tcd_init(j2k_image_t * img, j2k_cp_t * cp) | |||||||
| 	tlprcystart = int_floordivpow2(res->y0, pdy) << pdy; | 	tlprcystart = int_floordivpow2(res->y0, pdy) << pdy; | ||||||
| 	brprcxend = int_ceildivpow2(res->x1, pdx) << pdx; | 	brprcxend = int_ceildivpow2(res->x1, pdx) << pdx; | ||||||
| 	brprcyend = int_ceildivpow2(res->y1, pdy) << pdy; | 	brprcyend = int_ceildivpow2(res->y1, pdy) << pdy; | ||||||
| 	res->pw = (brprcxend - tlprcxstart) >> pdx; | 	res->pw = (res->x0==res->x1)?0:((brprcxend - tlprcxstart) >> pdx); // Mod Antonin : sizebug1 | ||||||
| 	res->ph = (brprcyend - tlprcystart) >> pdy; | 	res->ph = (res->y0==res->y1)?0:((brprcyend - tlprcystart) >> pdy); // Mod Antonin : sizebug1 | ||||||
|  |  | ||||||
| 	if (resno == 0) { | 	if (resno == 0) { | ||||||
| 	  tlcbgxstart = tlprcxstart; | 	  tlcbgxstart = tlprcxstart; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Antonin Descampe
					Antonin Descampe