33                            unsigned int bytes_per_scanline,
 
   42             value = bytestream2_get_byte(gb);
 
   45                 value = bytestream2_get_byte(gb);
 
   47             while (i < bytes_per_scanline && run--)
 
   60     for (i = 0; i < pallen; i++)
 
   61         *dst++ = 0xFF000000 | bytestream2_get_be24u(gb);
 
   63         memset(dst, 0, (256 - pallen) * 
sizeof(*dst));
 
   71     int compressed, xmin, ymin, xmax, ymax;
 
   73     unsigned int w, 
h, bits_per_pixel, bytes_per_line, nplanes, 
stride, 
y, x,
 
   77     if (avpkt->
size < 128)
 
   82     if (bytestream2_get_byteu(&gb) != 0x0a || bytestream2_get_byteu(&gb) > 5) {
 
   87     compressed                     = bytestream2_get_byteu(&gb);
 
   88     bits_per_pixel                 = bytestream2_get_byteu(&gb);
 
   89     xmin                           = bytestream2_get_le16u(&gb);
 
   90     ymin                           = bytestream2_get_le16u(&gb);
 
   91     xmax                           = bytestream2_get_le16u(&gb);
 
   92     ymax                           = bytestream2_get_le16u(&gb);
 
   96     if (xmax < xmin || ymax < ymin) {
 
  105     nplanes            = bytestream2_get_byteu(&gb);
 
  106     bytes_per_line     = bytestream2_get_le16u(&gb);
 
  107     bytes_per_scanline = nplanes * bytes_per_line;
 
  109     if (bytes_per_scanline < (w * bits_per_pixel * nplanes + 7) / 8 ||
 
  115     switch ((nplanes << 8) + bits_per_pixel) {
 
  150     if (nplanes == 3 && bits_per_pixel == 8) {
 
  151         for (y = 0; y < 
h; y++) {
 
  154             for (x = 0; x < w; x++) {
 
  155                 ptr[3 * x]     = scanline[x];
 
  156                 ptr[3 * x + 1] = scanline[x + bytes_per_line];
 
  157                 ptr[3 * x + 2] = scanline[x + (bytes_per_line << 1)];
 
  162     } 
else if (nplanes == 1 && bits_per_pixel == 8) {
 
  163         int palstart = avpkt->
size - 769;
 
  165         if (avpkt->
size < 769) {
 
  172         for (y = 0; y < 
h; y++, ptr += 
stride) {
 
  174             memcpy(ptr, scanline, w);
 
  181         if (bytestream2_get_byte(&gb) != 12) {
 
  187     } 
else if (nplanes == 1) {   
 
  190         for (y = 0; y < 
h; y++) {
 
  195             for (x = 0; x < w; x++)
 
  196                 ptr[x] = 
get_bits(&s, bits_per_pixel);
 
  202         for (y = 0; y < 
h; y++) {
 
  205             for (x = 0; x < w; x++) {
 
  206                 int m = 0x80 >> (x & 7), 
v = 0;
 
  207                 for (i = nplanes - 1; i >= 0; i--) {
 
  209                     v  += !!(scanline[i * bytes_per_line + (x >> 3)] & m);
 
  218     if (nplanes == 1 && bits_per_pixel == 8) {
 
  221     } 
else if (bits_per_pixel * nplanes == 1) {
 
  224     } 
else if (bits_per_pixel < 8) {
 
#define AVERROR_INVALIDDATA
Invalid data found when processing input. 
 
This structure describes decoded (raw) audio or video data. 
 
ptrdiff_t const GLvoid * data
 
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits. 
 
#define AV_LOG_WARNING
Something somehow does not look correct. 
 
packed RGB 8:8:8, 24bpp, RGBRGB... 
 
int ff_set_dimensions(AVCodecContext *s, int width, int height)
Check that the provided frame dimensions are valid and set them on the codec context. 
 
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown) That is the width of a pixel divided by the height of the pixel...
 
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx. 
 
static av_always_inline void bytestream2_init(GetByteContext *g, const uint8_t *buf, int buf_size)
 
8 bit with AV_PIX_FMT_RGB32 palette 
 
static av_cold int end(AVCodecContext *avctx)
 
#define CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators. 
 
static av_always_inline void bytestream2_skipu(GetByteContext *g, unsigned int size)
 
bitstream reader API header. 
 
static int pcx_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
 
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
 
#define AV_EF_EXPLODE
abort decoding on minor error detection 
 
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
 
static av_always_inline unsigned int bytestream2_get_buffer(GetByteContext *g, uint8_t *dst, unsigned int size)
 
static av_always_inline unsigned int bytestream2_get_bytes_left(GetByteContext *g)
 
const char * name
Name of the codec implementation. 
 
Libavcodec external API header. 
 
#define FF_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
 
enum AVPictureType pict_type
Picture type of the frame. 
 
int err_recognition
Error recognition; may misdetect some more or less valid parts as errors. 
 
static void pcx_palette(GetByteContext *gb, uint32_t *dst, int pallen)
 
GLsizei GLboolean const GLfloat * value
 
static av_always_inline int bytestream2_tell(GetByteContext *g)
 
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line. 
 
static int init_get_bits8(GetBitContext *s, const uint8_t *buffer, int byte_size)
Initialize GetBitContext. 
 
main external API structure. 
 
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame. 
 
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes. 
 
static void pcx_rle_decode(GetByteContext *gb, uint8_t *dst, unsigned int bytes_per_scanline, int compressed)
 
common internal api header. 
 
static av_always_inline int bytestream2_seek(GetByteContext *g, int offset, int whence)
 
This structure stores compressed data.