51 int buf_size = avpkt->
size;
57 int i, j, x, y,
stride, vect_w = 3, vect_h = 3;
73 if (buf_end - buf < 4)
84 last = first +
AV_RL16(buf + 2);
85 if (first >= 256 || last > 256 || buf_end - buf < 4 + 4 + 3 * (last - first))
88 for (i=first; i<last; i++, buf+=3) {
89 pal[i] = (buf[0] << 18) | (buf[1] << 10) | (buf[2] << 2);
90 pal[i] |= 0xFFU << 24 | (pal[i] >> 6) & 0x30303;
124 if (buf_end - buf < 256 * vect_w * vect_h)
126 table = buf + (256 * vect_w * vect_h);
128 int map_size = ((318 / vect_w + 7) / 8) * (198 / vect_h);
129 if (buf_end - table < map_size)
135 for (y=0; y<198; y+=vect_h) {
136 for (x=0; x<318; x+=vect_w) {
138 if (buf_end - table < 1)
140 vect = &buf[*table++ * (vect_w * vect_h)];
141 for (j=0; j<vect_w; j++) {
142 out[(y + 0) * stride + x + j] = vect[(0 * vect_w) + j];
143 out[(y + 1) * stride + x + j] = vect[(1 * vect_w) + j];
145 out[(y + 2) * stride + x + j] =
146 vect[(2 * vect_w) + j];