49 fprintf(stderr,
"Failed to create VAAPI frame context.\n");
59 fprintf(stderr,
"Failed to initialize VAAPI frame context." 82 fprintf(stderr,
"Error code: %s\n",
av_err2str(ret));
91 ret = fwrite(enc_pkt.
data, enc_pkt.
size, 1, fout);
96 ret = ((ret ==
AVERROR(EAGAIN)) ? 0 : -1);
100 int main(
int argc,
char *argv[])
107 const char *
enc_name =
"h264_vaapi";
110 fprintf(stderr,
"Usage: %s <width> <height> <input file> <output file>\n", argv[0]);
114 width = atoi(argv[1]);
118 if (!(fin = fopen(argv[3],
"r"))) {
119 fprintf(stderr,
"Fail to open input file : %s\n", strerror(errno));
122 if (!(fout = fopen(argv[4],
"w+b"))) {
123 fprintf(stderr,
"Fail to open output file : %s\n", strerror(errno));
131 fprintf(stderr,
"Failed to create a VAAPI device. Error code: %s\n",
av_err2str(err));
136 fprintf(stderr,
"Could not find encoder.\n");
155 fprintf(stderr,
"Failed to set hwframe context.\n");
160 fprintf(stderr,
"Cannot open video encoder codec. Error code: %s\n",
av_err2str(err));
175 if ((err = fread((
uint8_t*)(sw_frame->
data[0]), size, 1, fin)) <= 0)
177 if ((err = fread((
uint8_t*)(sw_frame->
data[1]), size/2, 1, fin)) <= 0)
185 fprintf(stderr,
"Error code: %s.\n",
av_err2str(err));
188 if (!hw_frame->hw_frames_ctx) {
193 fprintf(stderr,
"Error while transferring frame data to surface." 198 if ((err = (
encode_write(avctx, hw_frame, fout))) < 0) {
199 fprintf(stderr,
"Failed to encode.\n");
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it...
This structure describes decoded (raw) audio or video data.
int avcodec_receive_packet(AVCodecContext *avctx, AVPacket *avpkt)
Read encoded data from the encoder.
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown) That is the width of a pixel divided by the height of the pixel...
int width
The allocated dimensions of the frames in this pool.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
enum AVPixelFormat format
The pixel format identifying the underlying HW surface type.
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented...
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
static av_cold int end(AVCodecContext *avctx)
int main(int argc, char *argv[])
int av_hwdevice_ctx_create(AVBufferRef **pdevice_ref, enum AVHWDeviceType type, const char *device, AVDictionary *opts, int flags)
Open a device of the specified type and create an AVHWDeviceContext for it.
#define AVERROR_EOF
End of file.
AVCodec * avcodec_find_encoder_by_name(const char *name)
Find a registered encoder with the specified name.
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
planar YUV 4:2:0, 12bpp, 1 plane for Y and 1 plane for the UV components, which are interleaved (firs...
static AVBufferRef * hw_device_ctx
int av_hwframe_ctx_init(AVBufferRef *ref)
Finalize the context before use.
static int set_hwframe_ctx(AVCodecContext *ctx, AVBufferRef *hw_device_ctx)
int av_hwframe_get_buffer(AVBufferRef *hwframe_ref, AVFrame *frame, int flags)
Allocate a new frame attached to the given AVHWFramesContext.
int av_hwframe_transfer_data(AVFrame *dst, const AVFrame *src, int flags)
Copy data to or from a hw surface.
int initial_pool_size
Initial size of the frame pool.
AVCodecContext * avcodec_alloc_context3(const AVCodec *codec)
Allocate an AVCodecContext and set its fields to default values.
int width
picture width / height.
AVBufferRef * hw_frames_ctx
A reference to the AVHWFramesContext describing the input (for encoding) or output (decoding) frames...
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames...
Libavcodec external API header.
void avcodec_free_context(AVCodecContext **avctx)
Free the codec context and everything associated with it and write NULL to the provided pointer...
main external API structure.
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
uint8_t * data
The data buffer.
int avcodec_send_frame(AVCodecContext *avctx, const AVFrame *frame)
Supply a raw video or audio frame to the encoder.
Rational number (pair of numerator and denominator).
This struct describes a set or pool of "hardware" frames (i.e.
int avcodec_open2(AVCodecContext *avctx, const AVCodec *codec, AVDictionary **options)
Initialize the AVCodecContext to use the given AVCodec.
int av_frame_get_buffer(AVFrame *frame, int align)
Allocate new buffer(s) for audio or video data.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
A reference to a data buffer.
AVBufferRef * av_hwframe_ctx_alloc(AVBufferRef *device_ref_in)
Allocate an AVHWFramesContext tied to a given device context.
AVBufferRef * av_buffer_ref(AVBufferRef *buf)
Create a new reference to an AVBuffer.
static int encode_write(AVCodecContext *avctx, AVFrame *frame, FILE *fout)
void av_init_packet(AVPacket *pkt)
Initialize optional fields of a packet with default values.
enum AVPixelFormat sw_format
The pixel format identifying the actual data layout of the hardware frames.
This structure stores compressed data.