Improve readability and flexibility of compatibility macros
git-svn-id: svn+ssh://svn.code.sf.net/p/libjpeg-turbo/code/trunk@241 632fc199-4ca6-4c93-a231-07263d6284db
This commit is contained in:
@@ -204,7 +204,7 @@ jpeg_read_raw_data (j_decompress_ptr cinfo, JSAMPIMAGE data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Verify that at least one iMCU row can be returned. */
|
/* Verify that at least one iMCU row can be returned. */
|
||||||
lines_per_iMCU_row = cinfo->max_v_samp_factor * _min_DCT_scaled_size;
|
lines_per_iMCU_row = cinfo->max_v_samp_factor * cinfo->_min_DCT_scaled_size;
|
||||||
if (max_lines < lines_per_iMCU_row)
|
if (max_lines < lines_per_iMCU_row)
|
||||||
ERREXIT(cinfo, JERR_BUFFER_SIZE);
|
ERREXIT(cinfo, JERR_BUFFER_SIZE);
|
||||||
|
|
||||||
|
|||||||
14
jdcoefct.c
14
jdcoefct.c
@@ -192,7 +192,7 @@ decompress_onepass (j_decompress_ptr cinfo, JSAMPIMAGE output_buf)
|
|||||||
useful_width = (MCU_col_num < last_MCU_col) ? compptr->MCU_width
|
useful_width = (MCU_col_num < last_MCU_col) ? compptr->MCU_width
|
||||||
: compptr->last_col_width;
|
: compptr->last_col_width;
|
||||||
output_ptr = output_buf[compptr->component_index] +
|
output_ptr = output_buf[compptr->component_index] +
|
||||||
yoffset * _DCT_scaled_size;
|
yoffset * compptr->_DCT_scaled_size;
|
||||||
start_col = MCU_col_num * compptr->MCU_sample_width;
|
start_col = MCU_col_num * compptr->MCU_sample_width;
|
||||||
for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
|
for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
|
||||||
if (cinfo->input_iMCU_row < last_iMCU_row ||
|
if (cinfo->input_iMCU_row < last_iMCU_row ||
|
||||||
@@ -202,11 +202,11 @@ decompress_onepass (j_decompress_ptr cinfo, JSAMPIMAGE output_buf)
|
|||||||
(*inverse_DCT) (cinfo, compptr,
|
(*inverse_DCT) (cinfo, compptr,
|
||||||
(JCOEFPTR) coef->MCU_buffer[blkn+xindex],
|
(JCOEFPTR) coef->MCU_buffer[blkn+xindex],
|
||||||
output_ptr, output_col);
|
output_ptr, output_col);
|
||||||
output_col += _DCT_scaled_size;
|
output_col += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
blkn += compptr->MCU_width;
|
blkn += compptr->MCU_width;
|
||||||
output_ptr += _DCT_scaled_size;
|
output_ptr += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -367,9 +367,9 @@ decompress_data (j_decompress_ptr cinfo, JSAMPIMAGE output_buf)
|
|||||||
(*inverse_DCT) (cinfo, compptr, (JCOEFPTR) buffer_ptr,
|
(*inverse_DCT) (cinfo, compptr, (JCOEFPTR) buffer_ptr,
|
||||||
output_ptr, output_col);
|
output_ptr, output_col);
|
||||||
buffer_ptr++;
|
buffer_ptr++;
|
||||||
output_col += _DCT_scaled_size;
|
output_col += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
output_ptr += _DCT_scaled_size;
|
output_ptr += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -662,9 +662,9 @@ decompress_smooth_data (j_decompress_ptr cinfo, JSAMPIMAGE output_buf)
|
|||||||
DC4 = DC5; DC5 = DC6;
|
DC4 = DC5; DC5 = DC6;
|
||||||
DC7 = DC8; DC8 = DC9;
|
DC7 = DC8; DC8 = DC9;
|
||||||
buffer_ptr++, prev_block_row++, next_block_row++;
|
buffer_ptr++, prev_block_row++, next_block_row++;
|
||||||
output_col += _DCT_scaled_size;
|
output_col += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
output_ptr += _DCT_scaled_size;
|
output_ptr += compptr->_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -102,7 +102,7 @@ start_pass (j_decompress_ptr cinfo)
|
|||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
/* Select the proper IDCT routine for this component's scaling */
|
/* Select the proper IDCT routine for this component's scaling */
|
||||||
switch (_DCT_scaled_size) {
|
switch (compptr->_DCT_scaled_size) {
|
||||||
#ifdef IDCT_SCALING_SUPPORTED
|
#ifdef IDCT_SCALING_SUPPORTED
|
||||||
case 1:
|
case 1:
|
||||||
method_ptr = jpeg_idct_1x1;
|
method_ptr = jpeg_idct_1x1;
|
||||||
@@ -158,7 +158,7 @@ start_pass (j_decompress_ptr cinfo)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ERREXIT1(cinfo, JERR_BAD_DCTSIZE, _DCT_scaled_size);
|
ERREXIT1(cinfo, JERR_BAD_DCTSIZE, compptr->_DCT_scaled_size);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
idct->pub.inverse_DCT[ci] = method_ptr;
|
idct->pub.inverse_DCT[ci] = method_ptr;
|
||||||
|
|||||||
2
jdhuff.c
2
jdhuff.c
@@ -139,7 +139,7 @@ start_pass_huff_decoder (j_decompress_ptr cinfo)
|
|||||||
if (compptr->component_needed) {
|
if (compptr->component_needed) {
|
||||||
entropy->dc_needed[blkn] = TRUE;
|
entropy->dc_needed[blkn] = TRUE;
|
||||||
/* we don't need the ACs if producing a 1/8th-size image */
|
/* we don't need the ACs if producing a 1/8th-size image */
|
||||||
entropy->ac_needed[blkn] = (_DCT_scaled_size > 1);
|
entropy->ac_needed[blkn] = (compptr->_DCT_scaled_size > 1);
|
||||||
} else {
|
} else {
|
||||||
entropy->dc_needed[blkn] = entropy->ac_needed[blkn] = FALSE;
|
entropy->dc_needed[blkn] = entropy->ac_needed[blkn] = FALSE;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -228,7 +228,7 @@ per_scan_setup (j_decompress_ptr cinfo)
|
|||||||
compptr->MCU_width = 1;
|
compptr->MCU_width = 1;
|
||||||
compptr->MCU_height = 1;
|
compptr->MCU_height = 1;
|
||||||
compptr->MCU_blocks = 1;
|
compptr->MCU_blocks = 1;
|
||||||
compptr->MCU_sample_width = _DCT_scaled_size;
|
compptr->MCU_sample_width = compptr->_DCT_scaled_size;
|
||||||
compptr->last_col_width = 1;
|
compptr->last_col_width = 1;
|
||||||
/* For noninterleaved scans, it is convenient to define last_row_height
|
/* For noninterleaved scans, it is convenient to define last_row_height
|
||||||
* as the number of block rows present in the last iMCU row.
|
* as the number of block rows present in the last iMCU row.
|
||||||
@@ -264,7 +264,7 @@ per_scan_setup (j_decompress_ptr cinfo)
|
|||||||
compptr->MCU_width = compptr->h_samp_factor;
|
compptr->MCU_width = compptr->h_samp_factor;
|
||||||
compptr->MCU_height = compptr->v_samp_factor;
|
compptr->MCU_height = compptr->v_samp_factor;
|
||||||
compptr->MCU_blocks = compptr->MCU_width * compptr->MCU_height;
|
compptr->MCU_blocks = compptr->MCU_width * compptr->MCU_height;
|
||||||
compptr->MCU_sample_width = compptr->MCU_width * _DCT_scaled_size;
|
compptr->MCU_sample_width = compptr->MCU_width * compptr->_DCT_scaled_size;
|
||||||
/* Figure number of non-dummy blocks in last MCU column & row */
|
/* Figure number of non-dummy blocks in last MCU column & row */
|
||||||
tmp = (int) (compptr->width_in_blocks % compptr->MCU_width);
|
tmp = (int) (compptr->width_in_blocks % compptr->MCU_width);
|
||||||
if (tmp == 0) tmp = compptr->MCU_width;
|
if (tmp == 0) tmp = compptr->MCU_width;
|
||||||
|
|||||||
42
jdmainct.c
42
jdmainct.c
@@ -163,7 +163,7 @@ alloc_funny_pointers (j_decompress_ptr cinfo)
|
|||||||
{
|
{
|
||||||
my_main_ptr main = (my_main_ptr) cinfo->main;
|
my_main_ptr main = (my_main_ptr) cinfo->main;
|
||||||
int ci, rgroup;
|
int ci, rgroup;
|
||||||
int M = _min_DCT_scaled_size;
|
int M = cinfo->_min_DCT_scaled_size;
|
||||||
jpeg_component_info *compptr;
|
jpeg_component_info *compptr;
|
||||||
JSAMPARRAY xbuf;
|
JSAMPARRAY xbuf;
|
||||||
|
|
||||||
@@ -177,8 +177,8 @@ alloc_funny_pointers (j_decompress_ptr cinfo)
|
|||||||
|
|
||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
rgroup = (compptr->v_samp_factor * _DCT_scaled_size) /
|
rgroup = (compptr->v_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size; /* height of a row group of component */
|
cinfo->_min_DCT_scaled_size; /* height of a row group of component */
|
||||||
/* Get space for pointer lists --- M+4 row groups in each list.
|
/* Get space for pointer lists --- M+4 row groups in each list.
|
||||||
* We alloc both pointer lists with one call to save a few cycles.
|
* We alloc both pointer lists with one call to save a few cycles.
|
||||||
*/
|
*/
|
||||||
@@ -204,14 +204,14 @@ make_funny_pointers (j_decompress_ptr cinfo)
|
|||||||
{
|
{
|
||||||
my_main_ptr main = (my_main_ptr) cinfo->main;
|
my_main_ptr main = (my_main_ptr) cinfo->main;
|
||||||
int ci, i, rgroup;
|
int ci, i, rgroup;
|
||||||
int M = _min_DCT_scaled_size;
|
int M = cinfo->_min_DCT_scaled_size;
|
||||||
jpeg_component_info *compptr;
|
jpeg_component_info *compptr;
|
||||||
JSAMPARRAY buf, xbuf0, xbuf1;
|
JSAMPARRAY buf, xbuf0, xbuf1;
|
||||||
|
|
||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
rgroup = (compptr->v_samp_factor * _DCT_scaled_size) /
|
rgroup = (compptr->v_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size; /* height of a row group of component */
|
cinfo->_min_DCT_scaled_size; /* height of a row group of component */
|
||||||
xbuf0 = main->xbuffer[0][ci];
|
xbuf0 = main->xbuffer[0][ci];
|
||||||
xbuf1 = main->xbuffer[1][ci];
|
xbuf1 = main->xbuffer[1][ci];
|
||||||
/* First copy the workspace pointers as-is */
|
/* First copy the workspace pointers as-is */
|
||||||
@@ -244,14 +244,14 @@ set_wraparound_pointers (j_decompress_ptr cinfo)
|
|||||||
{
|
{
|
||||||
my_main_ptr main = (my_main_ptr) cinfo->main;
|
my_main_ptr main = (my_main_ptr) cinfo->main;
|
||||||
int ci, i, rgroup;
|
int ci, i, rgroup;
|
||||||
int M = _min_DCT_scaled_size;
|
int M = cinfo->_min_DCT_scaled_size;
|
||||||
jpeg_component_info *compptr;
|
jpeg_component_info *compptr;
|
||||||
JSAMPARRAY xbuf0, xbuf1;
|
JSAMPARRAY xbuf0, xbuf1;
|
||||||
|
|
||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
rgroup = (compptr->v_samp_factor * _DCT_scaled_size) /
|
rgroup = (compptr->v_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size; /* height of a row group of component */
|
cinfo->_min_DCT_scaled_size; /* height of a row group of component */
|
||||||
xbuf0 = main->xbuffer[0][ci];
|
xbuf0 = main->xbuffer[0][ci];
|
||||||
xbuf1 = main->xbuffer[1][ci];
|
xbuf1 = main->xbuffer[1][ci];
|
||||||
for (i = 0; i < rgroup; i++) {
|
for (i = 0; i < rgroup; i++) {
|
||||||
@@ -279,8 +279,8 @@ set_bottom_pointers (j_decompress_ptr cinfo)
|
|||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
/* Count sample rows in one iMCU row and in one row group */
|
/* Count sample rows in one iMCU row and in one row group */
|
||||||
iMCUheight = compptr->v_samp_factor * _DCT_scaled_size;
|
iMCUheight = compptr->v_samp_factor * compptr->_DCT_scaled_size;
|
||||||
rgroup = iMCUheight / _min_DCT_scaled_size;
|
rgroup = iMCUheight / cinfo->_min_DCT_scaled_size;
|
||||||
/* Count nondummy sample rows remaining for this component */
|
/* Count nondummy sample rows remaining for this component */
|
||||||
rows_left = (int) (compptr->downsampled_height % (JDIMENSION) iMCUheight);
|
rows_left = (int) (compptr->downsampled_height % (JDIMENSION) iMCUheight);
|
||||||
if (rows_left == 0) rows_left = iMCUheight;
|
if (rows_left == 0) rows_left = iMCUheight;
|
||||||
@@ -359,7 +359,7 @@ process_data_simple_main (j_decompress_ptr cinfo,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* There are always min_DCT_scaled_size row groups in an iMCU row. */
|
/* There are always min_DCT_scaled_size row groups in an iMCU row. */
|
||||||
rowgroups_avail = (JDIMENSION) _min_DCT_scaled_size;
|
rowgroups_avail = (JDIMENSION) cinfo->_min_DCT_scaled_size;
|
||||||
/* Note: at the bottom of the image, we may pass extra garbage row groups
|
/* Note: at the bottom of the image, we may pass extra garbage row groups
|
||||||
* to the postprocessor. The postprocessor has to check for bottom
|
* to the postprocessor. The postprocessor has to check for bottom
|
||||||
* of image anyway (at row resolution), so no point in us doing it too.
|
* of image anyway (at row resolution), so no point in us doing it too.
|
||||||
@@ -419,7 +419,7 @@ process_data_context_main (j_decompress_ptr cinfo,
|
|||||||
case CTX_PREPARE_FOR_IMCU:
|
case CTX_PREPARE_FOR_IMCU:
|
||||||
/* Prepare to process first M-1 row groups of this iMCU row */
|
/* Prepare to process first M-1 row groups of this iMCU row */
|
||||||
main->rowgroup_ctr = 0;
|
main->rowgroup_ctr = 0;
|
||||||
main->rowgroups_avail = (JDIMENSION) (_min_DCT_scaled_size - 1);
|
main->rowgroups_avail = (JDIMENSION) (cinfo->_min_DCT_scaled_size - 1);
|
||||||
/* Check for bottom of image: if so, tweak pointers to "duplicate"
|
/* Check for bottom of image: if so, tweak pointers to "duplicate"
|
||||||
* the last sample row, and adjust rowgroups_avail to ignore padding rows.
|
* the last sample row, and adjust rowgroups_avail to ignore padding rows.
|
||||||
*/
|
*/
|
||||||
@@ -442,8 +442,8 @@ process_data_context_main (j_decompress_ptr cinfo,
|
|||||||
main->buffer_full = FALSE;
|
main->buffer_full = FALSE;
|
||||||
/* Still need to process last row group of this iMCU row, */
|
/* Still need to process last row group of this iMCU row, */
|
||||||
/* which is saved at index M+1 of the other xbuffer */
|
/* which is saved at index M+1 of the other xbuffer */
|
||||||
main->rowgroup_ctr = (JDIMENSION) (_min_DCT_scaled_size + 1);
|
main->rowgroup_ctr = (JDIMENSION) (cinfo->_min_DCT_scaled_size + 1);
|
||||||
main->rowgroups_avail = (JDIMENSION) (_min_DCT_scaled_size + 2);
|
main->rowgroups_avail = (JDIMENSION) (cinfo->_min_DCT_scaled_size + 2);
|
||||||
main->context_state = CTX_POSTPONED_ROW;
|
main->context_state = CTX_POSTPONED_ROW;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -494,21 +494,21 @@ jinit_d_main_controller (j_decompress_ptr cinfo, boolean need_full_buffer)
|
|||||||
* ngroups is the number of row groups we need.
|
* ngroups is the number of row groups we need.
|
||||||
*/
|
*/
|
||||||
if (cinfo->upsample->need_context_rows) {
|
if (cinfo->upsample->need_context_rows) {
|
||||||
if (_min_DCT_scaled_size < 2) /* unsupported, see comments above */
|
if (cinfo->_min_DCT_scaled_size < 2) /* unsupported, see comments above */
|
||||||
ERREXIT(cinfo, JERR_NOTIMPL);
|
ERREXIT(cinfo, JERR_NOTIMPL);
|
||||||
alloc_funny_pointers(cinfo); /* Alloc space for xbuffer[] lists */
|
alloc_funny_pointers(cinfo); /* Alloc space for xbuffer[] lists */
|
||||||
ngroups = _min_DCT_scaled_size + 2;
|
ngroups = cinfo->_min_DCT_scaled_size + 2;
|
||||||
} else {
|
} else {
|
||||||
ngroups = _min_DCT_scaled_size;
|
ngroups = cinfo->_min_DCT_scaled_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
rgroup = (compptr->v_samp_factor * _DCT_scaled_size) /
|
rgroup = (compptr->v_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size; /* height of a row group of component */
|
cinfo->_min_DCT_scaled_size; /* height of a row group of component */
|
||||||
main->buffer[ci] = (*cinfo->mem->alloc_sarray)
|
main->buffer[ci] = (*cinfo->mem->alloc_sarray)
|
||||||
((j_common_ptr) cinfo, JPOOL_IMAGE,
|
((j_common_ptr) cinfo, JPOOL_IMAGE,
|
||||||
compptr->width_in_blocks * _DCT_scaled_size,
|
compptr->width_in_blocks * compptr->_DCT_scaled_size,
|
||||||
(JDIMENSION) (rgroup * ngroups));
|
(JDIMENSION) (rgroup * ngroups));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
23
jdmaster.c
23
jdmaster.c
@@ -69,17 +69,10 @@ use_merged_upsample (j_decompress_ptr cinfo)
|
|||||||
cinfo->comp_info[2].v_samp_factor != 1)
|
cinfo->comp_info[2].v_samp_factor != 1)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
/* furthermore, it doesn't work if we've scaled the IDCTs differently */
|
/* furthermore, it doesn't work if we've scaled the IDCTs differently */
|
||||||
#if JPEG_LIB_VERSION >= 70
|
if (cinfo->comp_info[0]._DCT_scaled_size != cinfo->_min_DCT_scaled_size ||
|
||||||
if (cinfo->comp_info[0].DCT_h_scaled_size != cinfo->min_DCT_h_scaled_size ||
|
cinfo->comp_info[1]._DCT_scaled_size != cinfo->_min_DCT_scaled_size ||
|
||||||
cinfo->comp_info[1].DCT_h_scaled_size != cinfo->min_DCT_h_scaled_size ||
|
cinfo->comp_info[2]._DCT_scaled_size != cinfo->_min_DCT_scaled_size)
|
||||||
cinfo->comp_info[2].DCT_h_scaled_size != cinfo->min_DCT_h_scaled_size)
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
#else
|
|
||||||
if (cinfo->comp_info[0].DCT_scaled_size != cinfo->min_DCT_scaled_size ||
|
|
||||||
cinfo->comp_info[1].DCT_scaled_size != cinfo->min_DCT_scaled_size ||
|
|
||||||
cinfo->comp_info[2].DCT_scaled_size != cinfo->min_DCT_scaled_size)
|
|
||||||
return FALSE;
|
|
||||||
#endif
|
|
||||||
/* ??? also need to test for upsample-time rescaling, when & if supported */
|
/* ??? also need to test for upsample-time rescaling, when & if supported */
|
||||||
return TRUE; /* by golly, it'll work... */
|
return TRUE; /* by golly, it'll work... */
|
||||||
#else
|
#else
|
||||||
@@ -161,12 +154,12 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
|
|||||||
*/
|
*/
|
||||||
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
|
||||||
ci++, compptr++) {
|
ci++, compptr++) {
|
||||||
int ssize = _min_DCT_scaled_size;
|
int ssize = cinfo->_min_DCT_scaled_size;
|
||||||
while (ssize < DCTSIZE &&
|
while (ssize < DCTSIZE &&
|
||||||
(compptr->h_samp_factor * ssize * 2 <=
|
(compptr->h_samp_factor * ssize * 2 <=
|
||||||
cinfo->max_h_samp_factor * _min_DCT_scaled_size) &&
|
cinfo->max_h_samp_factor * cinfo->_min_DCT_scaled_size) &&
|
||||||
(compptr->v_samp_factor * ssize * 2 <=
|
(compptr->v_samp_factor * ssize * 2 <=
|
||||||
cinfo->max_v_samp_factor * _min_DCT_scaled_size)) {
|
cinfo->max_v_samp_factor * cinfo->_min_DCT_scaled_size)) {
|
||||||
ssize = ssize * 2;
|
ssize = ssize * 2;
|
||||||
}
|
}
|
||||||
#if JPEG_LIB_VERSION >= 70
|
#if JPEG_LIB_VERSION >= 70
|
||||||
@@ -184,11 +177,11 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
|
|||||||
/* Size in samples, after IDCT scaling */
|
/* Size in samples, after IDCT scaling */
|
||||||
compptr->downsampled_width = (JDIMENSION)
|
compptr->downsampled_width = (JDIMENSION)
|
||||||
jdiv_round_up((long) cinfo->image_width *
|
jdiv_round_up((long) cinfo->image_width *
|
||||||
(long) (compptr->h_samp_factor * _DCT_scaled_size),
|
(long) (compptr->h_samp_factor * compptr->_DCT_scaled_size),
|
||||||
(long) (cinfo->max_h_samp_factor * DCTSIZE));
|
(long) (cinfo->max_h_samp_factor * DCTSIZE));
|
||||||
compptr->downsampled_height = (JDIMENSION)
|
compptr->downsampled_height = (JDIMENSION)
|
||||||
jdiv_round_up((long) cinfo->image_height *
|
jdiv_round_up((long) cinfo->image_height *
|
||||||
(long) (compptr->v_samp_factor * _DCT_scaled_size),
|
(long) (compptr->v_samp_factor * compptr->_DCT_scaled_size),
|
||||||
(long) (cinfo->max_v_samp_factor * DCTSIZE));
|
(long) (cinfo->max_v_samp_factor * DCTSIZE));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
10
jdsample.c
10
jdsample.c
@@ -422,7 +422,7 @@ jinit_upsampler (j_decompress_ptr cinfo)
|
|||||||
/* jdmainct.c doesn't support context rows when min_DCT_scaled_size = 1,
|
/* jdmainct.c doesn't support context rows when min_DCT_scaled_size = 1,
|
||||||
* so don't ask for it.
|
* so don't ask for it.
|
||||||
*/
|
*/
|
||||||
do_fancy = cinfo->do_fancy_upsampling && _min_DCT_scaled_size > 1;
|
do_fancy = cinfo->do_fancy_upsampling && cinfo->_min_DCT_scaled_size > 1;
|
||||||
|
|
||||||
/* Verify we can handle the sampling factors, select per-component methods,
|
/* Verify we can handle the sampling factors, select per-component methods,
|
||||||
* and create storage as needed.
|
* and create storage as needed.
|
||||||
@@ -432,10 +432,10 @@ jinit_upsampler (j_decompress_ptr cinfo)
|
|||||||
/* Compute size of an "input group" after IDCT scaling. This many samples
|
/* Compute size of an "input group" after IDCT scaling. This many samples
|
||||||
* are to be converted to max_h_samp_factor * max_v_samp_factor pixels.
|
* are to be converted to max_h_samp_factor * max_v_samp_factor pixels.
|
||||||
*/
|
*/
|
||||||
h_in_group = (compptr->h_samp_factor * _DCT_scaled_size) /
|
h_in_group = (compptr->h_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size;
|
cinfo->_min_DCT_scaled_size;
|
||||||
v_in_group = (compptr->v_samp_factor * _DCT_scaled_size) /
|
v_in_group = (compptr->v_samp_factor * compptr->_DCT_scaled_size) /
|
||||||
_min_DCT_scaled_size;
|
cinfo->_min_DCT_scaled_size;
|
||||||
h_out_group = cinfo->max_h_samp_factor;
|
h_out_group = cinfo->max_h_samp_factor;
|
||||||
v_out_group = cinfo->max_v_samp_factor;
|
v_out_group = cinfo->max_v_samp_factor;
|
||||||
upsample->rowgroup_height[ci] = v_in_group; /* save for use later */
|
upsample->rowgroup_height[ci] = v_in_group; /* save for use later */
|
||||||
|
|||||||
@@ -10,9 +10,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#if JPEG_LIB_VERSION >= 70
|
#if JPEG_LIB_VERSION >= 70
|
||||||
#define _DCT_scaled_size compptr->DCT_h_scaled_size
|
#define _DCT_scaled_size DCT_h_scaled_size
|
||||||
#define _min_DCT_scaled_size cinfo->min_DCT_h_scaled_size
|
#define _min_DCT_scaled_size min_DCT_h_scaled_size
|
||||||
#else
|
#else
|
||||||
#define _DCT_scaled_size compptr->DCT_scaled_size
|
#define _DCT_scaled_size DCT_scaled_size
|
||||||
#define _min_DCT_scaled_size cinfo->min_DCT_scaled_size
|
#define _min_DCT_scaled_size min_DCT_scaled_size
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user