29 #define CLIP(v) av_clip(v, 4, 1019) 30 #define CLIP8(v) av_clip(v, 1, 254) 32 #define WRITE_PIXELS(a, b, c) \ 35 val |= (CLIP(*b++) << 10) | \ 41 #define WRITE_PIXELS8(a, b, c) \ 43 val = (CLIP8(*a++) << 2); \ 44 val |= (CLIP8(*b++) << 12) | \ 45 (CLIP8(*c++) << 22); \ 58 for (i = 0; i < width - 11; i += 12) {
71 const uint16_t *v,
uint8_t *dst,
77 for (i = 0; i < width - 5; i += 6) {
100 if (avctx->
width & 1) {
105 #if FF_API_CODED_FRAME 120 const AVFrame *pic,
int *got_packet)
123 int aligned_width = ((avctx->
width + 47) / 48) * 48;
124 int stride = aligned_width * 8 / 3;
125 int line_padding = stride - ((avctx->
width * 8 + 11) / 12) * 4;
137 const uint16_t *y = (
const uint16_t *)pic->
data[0];
138 const uint16_t *
u = (
const uint16_t *)pic->
data[1];
139 const uint16_t *v = (
const uint16_t *)pic->
data[2];
142 const int sample_w = avctx->
width / sample_size;
146 w = sample_w * sample_size;
154 for (; w < avctx->
width - 5; w += 6) {
160 if (w < avctx->
width - 1) {
164 if (w == avctx->
width - 2) {
169 if (w < avctx->
width - 3) {
170 val |= (
CLIP(*
u++) << 10) | (
CLIP(*y++) << 20);
174 val =
CLIP(*v++) | (
CLIP(*y++) << 10);
179 memset(dst, 0, line_padding);
191 const int sample_w = avctx->
width / sample_size;
193 for (h = 0; h < avctx->
height; h++) {
195 w = sample_w * sample_size;
203 for (; w < avctx->
width - 5; w += 6) {
209 if (w < avctx->
width - 1) {
212 val =
CLIP8(*y++) << 2;
213 if (w == avctx->
width - 2) {
218 if (w < avctx->
width - 3) {
219 val |= (
CLIP8(*u++) << 12) | (
CLIP8(*y++) << 22);
223 val = (
CLIP8(*v++) << 2) | (
CLIP8(*y++) << 12);
227 memset(dst, 0, line_padding);
#define WRITE_PIXELS(a, b, c)
const char const char void * val
This structure describes decoded (raw) audio or video data.
static void v210_planar_pack_8_c(const uint8_t *y, const uint8_t *u, const uint8_t *v, uint8_t *dst, ptrdiff_t width)
int64_t bit_rate
the average bitrate
static av_cold int init(AVCodecContext *avctx)
void(* pack_line_10)(const uint16_t *y, const uint16_t *u, const uint16_t *v, uint8_t *dst, ptrdiff_t width)
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int64_t min_size)
Check AVPacket size and/or allocate data.
void(* pack_line_8)(const uint8_t *y, const uint8_t *u, const uint8_t *v, uint8_t *dst, ptrdiff_t width)
#define u(width, name, range_min, range_max)
int bits_per_coded_sample
bits per sample/pixel from the demuxer (needed for huffyuv).
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
const char * name
Name of the codec implementation.
av_cold void ff_v210enc_init(V210EncContext *s)
int flags
A combination of AV_PKT_FLAG values.
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
int64_t ff_guess_coded_bitrate(AVCodecContext *avctx)
Get an estimated video bitrate based on frame size, frame rate and coded bits per pixel...
enum AVPictureType pict_type
Picture type of the frame.
int width
picture width / height.
static int encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pic, int *got_packet)
static av_cold int encode_init(AVCodecContext *avctx)
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames...
Libavcodec external API header.
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
void ff_v210enc_init_x86(V210EncContext *s)
static enum AVPixelFormat pix_fmts[]
#define AV_PIX_FMT_YUV422P10
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
#define WRITE_PIXELS8(a, b, c)
#define FF_DISABLE_DEPRECATION_WARNINGS
common internal api header.
static void v210_planar_pack_10_c(const uint16_t *y, const uint16_t *u, const uint16_t *v, uint8_t *dst, ptrdiff_t width)
attribute_deprecated AVFrame * coded_frame
the picture in the bitstream
#define FF_ENABLE_DEPRECATION_WARNINGS
AVPixelFormat
Pixel format.
This structure stores compressed data.