aarch64: Add assembly support for -fsanitize=hwaddress tagged globals.
[libav.git] / libavcodec / huffyuv.c
blobda5c52f9a6beb686fde32725579403924a663222
1 /*
2 * huffyuv codec for libavcodec
4 * Copyright (c) 2002-2003 Michael Niedermayer <michaelni@gmx.at>
6 * see http://www.pcisys.net/~melanson/codecs/huffyuv.txt for a description of
7 * the algorithm used
9 * This file is part of Libav.
11 * Libav is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU Lesser General Public
13 * License as published by the Free Software Foundation; either
14 * version 2.1 of the License, or (at your option) any later version.
16 * Libav is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 * Lesser General Public License for more details.
21 * You should have received a copy of the GNU Lesser General Public
22 * License along with Libav; if not, write to the Free Software
23 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
26 /**
27 * @file
28 * huffyuv codec for libavcodec.
31 #include <stdint.h>
33 #include "libavutil/mem.h"
35 #include "avcodec.h"
36 #include "bswapdsp.h"
37 #include "huffyuv.h"
39 int ff_huffyuv_generate_bits_table(uint32_t *dst, const uint8_t *len_table)
41 int len, index;
42 uint32_t bits = 0;
44 for (len = 32; len > 0; len--) {
45 for (index = 0; index < 256; index++) {
46 if (len_table[index] == len)
47 dst[index] = bits++;
49 if (bits & 1) {
50 av_log(NULL, AV_LOG_ERROR, "Error generating huffman table\n");
51 return -1;
53 bits >>= 1;
55 return 0;
58 av_cold int ff_huffyuv_alloc_temp(HYuvContext *s)
60 int i;
62 if (s->bitstream_bpp<24) {
63 for (i=0; i<3; i++) {
64 s->temp[i]= av_malloc(s->width + 16);
65 if (!s->temp[i])
66 return AVERROR(ENOMEM);
68 } else {
69 s->temp[0]= av_mallocz(4*s->width + 16);
70 if (!s->temp[0])
71 return AVERROR(ENOMEM);
73 return 0;
76 av_cold void ff_huffyuv_common_init(AVCodecContext *avctx)
78 HYuvContext *s = avctx->priv_data;
80 s->avctx = avctx;
81 s->flags = avctx->flags;
83 ff_bswapdsp_init(&s->bdsp);
85 s->width = avctx->width;
86 s->height = avctx->height;
87 assert(s->width>0 && s->height>0);
90 void ff_huffyuv_common_end(HYuvContext *s)
92 int i;
94 for(i = 0; i < 3; i++) {
95 av_freep(&s->temp[i]);