35 #define SHL(a, n) ((n) >= 0 ? (a) << (n) : (a) >> -(n)) 
   43     while (w > 1 || h > 1) {
 
   64     while (w > 1 || h > 1) {
 
   73         for (i = 0; i < ph; i++)
 
   74             for (j = 0; j < pw; j++)
 
   75                 t[i * pw + j].parent = &t2[(i >> 1) * w + (j >> 1)];
 
   87     for (i = 0; i < siz; i++) {
 
  111         if (h == 2) 
return 8;
 
  113             if (v >= 1) 
return 7;
 
  114             if (d >= 1) 
return 6;
 
  117         if (v == 2) 
return 4;
 
  118         if (v == 1) 
return 3;
 
  119         if (d >= 2) 
return 2;
 
  120         if (d == 1) 
return 1;
 
  122         if (d >= 3) 
return 8;
 
  124             if (h+v >= 1) 
return 7;
 
  128             if (h+v >= 2) 
return 5;
 
  129             if (h+v == 1) 
return 4;
 
  132         if (h+v >= 2) 
return 2;
 
  133         if (h+v == 1) 
return 1;
 
  140 static const int contribtab[3][3] = { {  0, -1,  1 }, { -1, -1,  0 }, {  1,  0,  1 } };
 
  141 static const int  ctxlbltab[3][3] = { { 13, 12, 11 }, { 10,  9, 10 }, { 11, 12, 13 } };
 
  142 static const int  xorbittab[3][3] = { {  1,  1,  1 }, {  1,  0,  0 }, {  0,  0,  0 } };
 
  146     int vcontrib, hcontrib;
 
  160     for (i = 0; i < 256; i++)
 
  161         for (j = 0; j < 4; j++)
 
  163     for (i = 0; i < 16; i++)
 
  164         for (j = 0; j < 16; j++)
 
  197                                int cbps, 
int dx, 
int dy,
 
  200     uint8_t log2_band_prec_width, log2_band_prec_height;
 
  201     int reslevelno, bandno, gbandno = 0, ret, i, j;
 
  214     csize = (comp->
coord[0][1] - comp->
coord[0][0]) *
 
  234     for (reslevelno = 0; reslevelno < codsty->
nreslevels; reslevelno++) {
 
  241         for (i = 0; i < 2; i++)
 
  242             for (j = 0; j < 2; j++)
 
  243                 reslevel->
coord[i][j] =
 
  262         if (reslevel->
coord[0][1] == reslevel->
coord[0][0])
 
  270         if (reslevel->
coord[1][1] == reslevel->
coord[1][0])
 
  282         for (bandno = 0; bandno < reslevel->
nbands; bandno++, gbandno++) {
 
  319                 switch (bandno + (reslevelno > 0)) {
 
  345             if (reslevelno == 0) {
 
  347                 for (i = 0; i < 2; i++)
 
  348                     for (j = 0; j < 2; j++)
 
  362                 for (i = 0; i < 2; i++)
 
  363                     for (j = 0; j < 2; j++)
 
  367                                                     (((bandno + 1 >> i) & 1LL) << declvl - 1),
 
  391             for (precno = 0; precno < nb_precincts; precno++) {
 
  402                                     (1 << log2_band_prec_width);
 
  406                                     (1 << log2_band_prec_height);
 
  410                                     (1 << log2_band_prec_width);
 
  416                                     (1 << log2_band_prec_height);
 
  451                 for (cblkno = 0; cblkno < nb_codeblocks; cblkno++) {
 
  474                     if ((bandno + !!reslevelno) & 1) {
 
  480                     if ((bandno + !!reslevelno) & 2) {
 
  501     int reslevelno, bandno, cblkno, precno;
 
  502     for (reslevelno = 0; reslevelno < codsty->
nreslevels; reslevelno++) {
 
  504         for (bandno = 0; bandno < rlevel->
nbands; bandno++) {
 
  522     int reslevelno, bandno, precno;
 
  531         reslevel = comp->
reslevel + reslevelno;
 
  532         for (bandno = 0; bandno < reslevel->
nbands; bandno++) {
 
  538             band = reslevel->
band + bandno;
 
uint8_t ff_jpeg2000_sgnctxno_lut[16][16]
const struct AVCodec * codec
#define AVERROR_INVALIDDATA
Invalid data found when processing input. 
void av_cold ff_jpeg2000_init_tier1_luts(void)
void ff_jpeg2000_cleanup(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty)
Jpeg2000TgtNode * cblkincl
memory handling functions 
uint16_t mant[JPEG2000_MAX_DECLEVELS *3]
static const int contribtab[3][3]
static const int xorbittab[3][3]
static void tag_tree_zero(Jpeg2000TgtNode *t, int w, int h)
uint16_t nb_codeblocks_height
static Jpeg2000TgtNode * ff_jpeg2000_tag_tree_init(int w, int h)
Macro definitions for various function/variable attributes. 
int av_codec_is_encoder(const AVCodec *codec)
#define JPEG2000_T1_SIG_W
#define av_assert0(cond)
assert() equivalent, that is always enabled. 
Jpeg2000TgtNode * zerobits
int ff_jpeg2000_dwt_init(DWTContext *s, uint16_t border[2][2], int decomp_levels, int type)
Initialize DWT. 
#define JPEG2000_T1_SIG_NE
#define JPEG2000_T1_SIG_SE
static const int ctxlbltab[3][3]
uint8_t log2_prec_widths[JPEG2000_MAX_RESLEVELS]
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
void ff_jpeg2000_set_significance(Jpeg2000T1Context *t1, int x, int y, int negative)
uint8_t log2_prec_heights[JPEG2000_MAX_RESLEVELS]
simple assert() macros that are a bit more flexible than ISO C assert(). 
Libavcodec external API header. 
struct Jpeg2000TgtNode * parent
#define JPEG2000_T1_SGN_S
JPEG 2000 structures and defines common to encoder and decoder. 
void ff_dwt_destroy(DWTContext *s)
#define JPEG2000_T1_SIG_N
uint16_t lengthinc[JPEG2000_MAX_PASSES]
static int ff_jpeg2000_ceildivpow2(int a, int b)
main external API structure. 
uint16_t nb_codeblocks_width
#define JPEG2000_T1_SIG_S
Jpeg2000ResLevel * reslevel
void ff_jpeg2000_reinit(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty)
#define JPEG2000_T1_SGN_E
uint8_t expn[JPEG2000_MAX_DECLEVELS *3]
common internal and external API header 
uint16_t log2_cblk_height
static int32_t tag_tree_size(uint16_t w, uint16_t h)
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
int ff_jpeg2000_init_component(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty, Jpeg2000QuantStyle *qntsty, int cbps, int dx, int dy, AVCodecContext *avctx)
#define JPEG2000_T1_SIG_SW
#define JPEG2000_T1_SGN_N
static int getsgnctxno(int flag, uint8_t *xorbit)
#define JPEG2000_T1_SIG_E
static void * av_mallocz_array(size_t nmemb, size_t size)
static void comp(unsigned char *dst, int dst_stride, unsigned char *src, int src_stride, int add)
static int getsigctxno(int flag, int bandno)
#define FFSWAP(type, a, b)
uint8_t ff_jpeg2000_sigctxno_lut[256][4]
#define JPEG2000_T1_SIG_NW
#define JPEG2000_T1_SGN_W
uint8_t ff_jpeg2000_xorbit_lut[16][16]