xref: /aosp_15_r20/external/pdfium/third_party/libopenjpeg/t2.h (revision 3ac0a46f773bac49fa9476ec2b1cf3f8da5ec3a4)
1*3ac0a46fSAndroid Build Coastguard Worker /*
2*3ac0a46fSAndroid Build Coastguard Worker  * The copyright in this software is being made available under the 2-clauses
3*3ac0a46fSAndroid Build Coastguard Worker  * BSD License, included below. This software may be subject to other third
4*3ac0a46fSAndroid Build Coastguard Worker  * party and contributor rights, including patent rights, and no such rights
5*3ac0a46fSAndroid Build Coastguard Worker  * are granted under this license.
6*3ac0a46fSAndroid Build Coastguard Worker  *
7*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2002-2014, Universite catholique de Louvain (UCL), Belgium
8*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2002-2014, Professor Benoit Macq
9*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2001-2003, David Janssens
10*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2002-2003, Yannick Verschueren
11*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2003-2007, Francois-Olivier Devaux
12*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2003-2014, Antonin Descampe
13*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2005, Herve Drolon, FreeImage Team
14*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2008, 2011-2012, Centre National d'Etudes Spatiales (CNES), FR
15*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2012, CS Systemes d'Information, France
16*3ac0a46fSAndroid Build Coastguard Worker  * Copyright (c) 2017, IntoPIX SA <[email protected]>
17*3ac0a46fSAndroid Build Coastguard Worker  * All rights reserved.
18*3ac0a46fSAndroid Build Coastguard Worker  *
19*3ac0a46fSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
20*3ac0a46fSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
21*3ac0a46fSAndroid Build Coastguard Worker  * are met:
22*3ac0a46fSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
23*3ac0a46fSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
24*3ac0a46fSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
25*3ac0a46fSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
26*3ac0a46fSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
27*3ac0a46fSAndroid Build Coastguard Worker  *
28*3ac0a46fSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
29*3ac0a46fSAndroid Build Coastguard Worker  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30*3ac0a46fSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31*3ac0a46fSAndroid Build Coastguard Worker  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
32*3ac0a46fSAndroid Build Coastguard Worker  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
33*3ac0a46fSAndroid Build Coastguard Worker  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
34*3ac0a46fSAndroid Build Coastguard Worker  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
35*3ac0a46fSAndroid Build Coastguard Worker  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
36*3ac0a46fSAndroid Build Coastguard Worker  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
37*3ac0a46fSAndroid Build Coastguard Worker  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
38*3ac0a46fSAndroid Build Coastguard Worker  * POSSIBILITY OF SUCH DAMAGE.
39*3ac0a46fSAndroid Build Coastguard Worker  */
40*3ac0a46fSAndroid Build Coastguard Worker #ifndef OPJ_T2_H
41*3ac0a46fSAndroid Build Coastguard Worker #define OPJ_T2_H
42*3ac0a46fSAndroid Build Coastguard Worker /**
43*3ac0a46fSAndroid Build Coastguard Worker @file t2.h
44*3ac0a46fSAndroid Build Coastguard Worker @brief Implementation of a tier-2 coding (packetization of code-block data) (T2)
45*3ac0a46fSAndroid Build Coastguard Worker 
46*3ac0a46fSAndroid Build Coastguard Worker */
47*3ac0a46fSAndroid Build Coastguard Worker 
48*3ac0a46fSAndroid Build Coastguard Worker /** @defgroup T2 T2 - Implementation of a tier-2 coding */
49*3ac0a46fSAndroid Build Coastguard Worker /*@{*/
50*3ac0a46fSAndroid Build Coastguard Worker 
51*3ac0a46fSAndroid Build Coastguard Worker /**
52*3ac0a46fSAndroid Build Coastguard Worker Tier-2 coding
53*3ac0a46fSAndroid Build Coastguard Worker */
54*3ac0a46fSAndroid Build Coastguard Worker typedef struct opj_t2 {
55*3ac0a46fSAndroid Build Coastguard Worker 
56*3ac0a46fSAndroid Build Coastguard Worker     /** Encoding: pointer to the src image. Decoding: pointer to the dst image. */
57*3ac0a46fSAndroid Build Coastguard Worker     opj_image_t *image;
58*3ac0a46fSAndroid Build Coastguard Worker     /** pointer to the image coding parameters */
59*3ac0a46fSAndroid Build Coastguard Worker     opj_cp_t *cp;
60*3ac0a46fSAndroid Build Coastguard Worker } opj_t2_t;
61*3ac0a46fSAndroid Build Coastguard Worker 
62*3ac0a46fSAndroid Build Coastguard Worker /** @name Exported functions */
63*3ac0a46fSAndroid Build Coastguard Worker /*@{*/
64*3ac0a46fSAndroid Build Coastguard Worker /* ----------------------------------------------------------------------- */
65*3ac0a46fSAndroid Build Coastguard Worker 
66*3ac0a46fSAndroid Build Coastguard Worker /**
67*3ac0a46fSAndroid Build Coastguard Worker Encode the packets of a tile to a destination buffer
68*3ac0a46fSAndroid Build Coastguard Worker @param t2               T2 handle
69*3ac0a46fSAndroid Build Coastguard Worker @param tileno           number of the tile encoded
70*3ac0a46fSAndroid Build Coastguard Worker @param tile             the tile for which to write the packets
71*3ac0a46fSAndroid Build Coastguard Worker @param maxlayers        maximum number of layers
72*3ac0a46fSAndroid Build Coastguard Worker @param dest             the destination buffer
73*3ac0a46fSAndroid Build Coastguard Worker @param p_data_written   FIXME DOC
74*3ac0a46fSAndroid Build Coastguard Worker @param len              the length of the destination buffer
75*3ac0a46fSAndroid Build Coastguard Worker @param cstr_info        Codestream information structure
76*3ac0a46fSAndroid Build Coastguard Worker @param p_marker_info    Marker information structure
77*3ac0a46fSAndroid Build Coastguard Worker @param tpnum            Tile part number of the current tile
78*3ac0a46fSAndroid Build Coastguard Worker @param tppos            The position of the tile part flag in the progression order
79*3ac0a46fSAndroid Build Coastguard Worker @param pino             FIXME DOC
80*3ac0a46fSAndroid Build Coastguard Worker @param t2_mode          If == THRESH_CALC In Threshold calculation ,If == FINAL_PASS Final pass
81*3ac0a46fSAndroid Build Coastguard Worker @param p_manager        the user event manager
82*3ac0a46fSAndroid Build Coastguard Worker */
83*3ac0a46fSAndroid Build Coastguard Worker OPJ_BOOL opj_t2_encode_packets(opj_t2_t* t2,
84*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 tileno,
85*3ac0a46fSAndroid Build Coastguard Worker                                opj_tcd_tile_t *tile,
86*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 maxlayers,
87*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_BYTE *dest,
88*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 * p_data_written,
89*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 len,
90*3ac0a46fSAndroid Build Coastguard Worker                                opj_codestream_info_t *cstr_info,
91*3ac0a46fSAndroid Build Coastguard Worker                                opj_tcd_marker_info_t* p_marker_info,
92*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 tpnum,
93*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_INT32 tppos,
94*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 pino,
95*3ac0a46fSAndroid Build Coastguard Worker                                J2K_T2_MODE t2_mode,
96*3ac0a46fSAndroid Build Coastguard Worker                                opj_event_mgr_t *p_manager);
97*3ac0a46fSAndroid Build Coastguard Worker 
98*3ac0a46fSAndroid Build Coastguard Worker /**
99*3ac0a46fSAndroid Build Coastguard Worker Decode the packets of a tile from a source buffer
100*3ac0a46fSAndroid Build Coastguard Worker @param tcd TCD handle
101*3ac0a46fSAndroid Build Coastguard Worker @param t2 T2 handle
102*3ac0a46fSAndroid Build Coastguard Worker @param tileno number that identifies the tile for which to decode the packets
103*3ac0a46fSAndroid Build Coastguard Worker @param tile tile for which to decode the packets
104*3ac0a46fSAndroid Build Coastguard Worker @param src         FIXME DOC
105*3ac0a46fSAndroid Build Coastguard Worker @param p_data_read the source buffer
106*3ac0a46fSAndroid Build Coastguard Worker @param len length of the source buffer
107*3ac0a46fSAndroid Build Coastguard Worker @param cstr_info   FIXME DOC
108*3ac0a46fSAndroid Build Coastguard Worker @param p_manager the user event manager
109*3ac0a46fSAndroid Build Coastguard Worker 
110*3ac0a46fSAndroid Build Coastguard Worker @return FIXME DOC
111*3ac0a46fSAndroid Build Coastguard Worker  */
112*3ac0a46fSAndroid Build Coastguard Worker OPJ_BOOL opj_t2_decode_packets(opj_tcd_t* tcd,
113*3ac0a46fSAndroid Build Coastguard Worker                                opj_t2_t *t2,
114*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 tileno,
115*3ac0a46fSAndroid Build Coastguard Worker                                opj_tcd_tile_t *tile,
116*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_BYTE *src,
117*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 * p_data_read,
118*3ac0a46fSAndroid Build Coastguard Worker                                OPJ_UINT32 len,
119*3ac0a46fSAndroid Build Coastguard Worker                                opj_codestream_index_t *cstr_info,
120*3ac0a46fSAndroid Build Coastguard Worker                                opj_event_mgr_t *p_manager);
121*3ac0a46fSAndroid Build Coastguard Worker 
122*3ac0a46fSAndroid Build Coastguard Worker /**
123*3ac0a46fSAndroid Build Coastguard Worker  * Creates a Tier 2 handle
124*3ac0a46fSAndroid Build Coastguard Worker  *
125*3ac0a46fSAndroid Build Coastguard Worker  * @param   p_image     Source or destination image
126*3ac0a46fSAndroid Build Coastguard Worker  * @param   p_cp        Image coding parameters.
127*3ac0a46fSAndroid Build Coastguard Worker  * @return      a new T2 handle if successful, NULL otherwise.
128*3ac0a46fSAndroid Build Coastguard Worker */
129*3ac0a46fSAndroid Build Coastguard Worker opj_t2_t* opj_t2_create(opj_image_t *p_image, opj_cp_t *p_cp);
130*3ac0a46fSAndroid Build Coastguard Worker 
131*3ac0a46fSAndroid Build Coastguard Worker /**
132*3ac0a46fSAndroid Build Coastguard Worker Destroy a T2 handle
133*3ac0a46fSAndroid Build Coastguard Worker @param t2 T2 handle to destroy
134*3ac0a46fSAndroid Build Coastguard Worker */
135*3ac0a46fSAndroid Build Coastguard Worker void opj_t2_destroy(opj_t2_t *t2);
136*3ac0a46fSAndroid Build Coastguard Worker 
137*3ac0a46fSAndroid Build Coastguard Worker /* ----------------------------------------------------------------------- */
138*3ac0a46fSAndroid Build Coastguard Worker /*@}*/
139*3ac0a46fSAndroid Build Coastguard Worker 
140*3ac0a46fSAndroid Build Coastguard Worker /*@}*/
141*3ac0a46fSAndroid Build Coastguard Worker 
142*3ac0a46fSAndroid Build Coastguard Worker #endif /* OPJ_T2_H */
143