56 0, 0, 0, 0, 0, 0, 0, 0,
57 0, 0, 0, 0, 0, 0, 0, 0,
58 0, 0, 0, -30210, -27853, -25680, -23677, -21829,
59 -20126, -18556, -17108, -15774, -14543, -13408, -12362, -11398,
60 -10508, -9689, -8933, -8236, -7593, -7001, -6455, -5951,
61 -5487, -5059, -4664, -4300, -3964, -3655, -3370, -3107,
62 -2865, -2641, -2435, -2245, -2070, -1908, -1759, -1622,
63 -1495, -1379, -1271, -1172, -1080, -996, -918, -847,
64 -781, -720, -663, -612, -564, -520, -479, -442,
65 -407, -376, -346, -319, -294, -271, -250, -230,
66 -212, -196, -181, -166, -153, -141, -130, -120,
67 -111, -102, -94, -87, -80, -74, -68, -62,
68 -58, -53, -49, -45, -41, -38, -35, -32,
69 -30, -27, -25, -23, -21, -20, -18, -17,
70 -15, -14, -13, -12, -11, -10, -9, -8,
71 -7, -6, -5, -4, -3, -2, -1, 0,
72 0, 1, 2, 3, 4, 5, 6, 7,
73 8, 9, 10, 11, 12, 13, 14, 15,
74 17, 18, 20, 21, 23, 25, 27, 30,
75 32, 35, 38, 41, 45, 49, 53, 58,
76 62, 68, 74, 80, 87, 94, 102, 111,
77 120, 130, 141, 153, 166, 181, 196, 212,
78 230, 250, 271, 294, 319, 346, 376, 407,
79 442, 479, 520, 564, 612, 663, 720, 781,
80 847, 918, 996, 1080, 1172, 1271, 1379, 1495,
81 1622, 1759, 1908, 2070, 2245, 2435, 2641, 2865,
82 3107, 3370, 3655, 3964, 4300, 4664, 5059, 5487,
83 5951, 6455, 7001, 7593, 8236, 8933, 9689, 10508,
84 11398, 12362, 13408, 14543, 15774, 17108, 18556, 20126,
85 21829, 23677, 25680, 27853, 30210, 0, 0, 0,
86 0, 0, 0, 0, 0, 0, 0, 0,
87 0, 0, 0, 0, 0, 0, 0, 0
104 for (i = 0; i < 3; ++i) {
121 unsigned char *dst,
int dst_size)
123 int b, huff_code = 0;
124 unsigned char huff_code_table[15];
125 unsigned char *dst_cur = dst;
126 unsigned char *dst_end = dst + dst_size;
127 const unsigned char *src_end = src + src_size;
129 memcpy(huff_code_table, src, 15);
132 while (src < src_end) {
134 if ((huff_code >> 4) == 15) {
137 *dst_cur++ = b | (huff_code >> 4);
139 *dst_cur++ = huff_code_table[huff_code >> 4];
140 if (dst_cur >= dst_end)
144 if (huff_code == 15) {
147 *dst_cur++ = huff_code_table[huff_code];
148 if (dst_cur >= dst_end)
152 return dst_cur - dst;
156 unsigned char *dst,
int dst_size)
159 int i, sz, offset, code;
160 unsigned char *dst_end = dst + dst_size, *dst_start = dst;
161 const unsigned char *src_end = src + src_size;
163 while (src < src_end && dst < dst_end) {
165 for (i = 0; i < 8 && src < src_end && dst < dst_end; ++i) {
166 if (code & (1 << i)) {
172 if ((
int)(dst - dst_start) < offset + 1)
174 sz = (cmd & 0xF) + 2;
178 sz =
FFMIN(sz, dst_end - dst);
180 *dst = *(dst - offset - 1);
191 unsigned char *dst,
int dst_size)
194 unsigned char *dst_end = dst + dst_size;
195 const unsigned char *src_end = src + src_size;
197 while (src < src_end && dst < dst_end) {
203 memset(dst, *src++,
FFMIN(len, dst_end - dst));
206 memcpy(dst, src,
FFMIN3(len, dst_end - dst, src_end - src));
214 void *
data,
int *got_frame,
218 int buf_size = avpkt->
size;
220 int i, y, palette_type, palette_colors_count,
221 bitmap_frame_type, bitmap_frame_size, res = 0;
223 palette_type = buf[0];
224 palette_colors_count =
AV_RL16(buf + 1);
225 bitmap_frame_type = buf[3];
228 bitmap_frame_size = buf_size - 4;
231 if (bitmap_frame_size < palette_colors_count * (3 + (palette_type != 0)))
233 if (palette_type == 0) {
234 if (palette_colors_count > 256)
236 for (i = 0; i < palette_colors_count; ++i) {
237 cin->
palette[i] = bytestream_get_le24(&buf);
238 bitmap_frame_size -= 3;
241 for (i = 0; i < palette_colors_count; ++i) {
244 bitmap_frame_size -= 4;
252 switch (bitmap_frame_type) {
302 "delphinecinvideo: reget_buffer() failed to allocate a frame\n");
331 for (i = 0; i < 3; ++i)
351 int *got_frame_ptr,
AVPacket *avpkt)
366 samples = (int16_t *)frame->
data[0];
375 while (buf < buf_end) {
377 delta = av_clip_int16(delta);
388 .
name =
"dsicinvideo",
400 .
name =
"dsicinaudio",
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
This structure describes decoded (raw) audio or video data.
static av_cold int cinvideo_decode_init(AVCodecContext *avctx)
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
static int cinaudio_decode_frame(AVCodecContext *avctx, void *data, int *got_frame_ptr, AVPacket *avpkt)
static int decode(MimicContext *ctx, int quality, int num_coeffs, int is_iframe)
static int cin_decode_lzss(const unsigned char *src, int src_size, unsigned char *dst, int dst_size)
enum AVSampleFormat sample_fmt
audio sample format
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
8 bit with PIX_FMT_RGB32 palette
static void cin_decode_rle(const unsigned char *src, int src_size, unsigned char *dst, int dst_size)
int av_frame_ref(AVFrame *dst, const AVFrame *src)
Set up a new reference to the data described by the source frame.
#define CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
void av_free(void *ptr)
Free a memory block which has been allocated with av_malloc(z)() or av_realloc(). ...
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
uint8_t * bitmap_table[3]
void av_log(void *avcl, int level, const char *fmt,...)
const char * name
Name of the codec implementation.
uint64_t channel_layout
Audio channel layout.
static const int16_t cinaudio_delta16_table[256]
int ff_reget_buffer(AVCodecContext *avctx, AVFrame *frame)
Identical in function to av_frame_make_writable(), except it uses ff_get_buffer() to allocate the buf...
audio channel layout utility functions
AVCodec ff_dsicinaudio_decoder
int width
picture width / height.
if(ac->has_optimized_func)
static av_cold int cinvideo_decode_end(AVCodecContext *avctx)
Libavcodec external API header.
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
static void close(AVCodecParserContext *s)
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame.
int palette_has_changed
Tell user application that palette has changed from previous frame.
static av_const int sign_extend(int val, unsigned bits)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static void cin_apply_delta_data(const unsigned char *src, unsigned char *dst, int size)
common internal api header.
static av_cold int init(AVCodecParserContext *s)
static int cin_decode_huffman(const unsigned char *src, int src_size, unsigned char *dst, int dst_size)
int channels
number of audio channels
static int cinvideo_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
static av_cold int cinaudio_decode_init(AVCodecContext *avctx)
AVCodec ff_dsicinvideo_decoder
#define FFSWAP(type, a, b)
#define AV_CH_LAYOUT_MONO
This structure stores compressed data.
int nb_samples
number of audio samples (per channel) described by this frame
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...