diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2012-07-18 01:27:19 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2012-07-18 01:27:19 +0200 |
commit | 56ae5926f739bd26a5aa4add98604b7cd3c2d6ca (patch) | |
tree | bd21824c32a6018f28d2e3c2c1d810ad77a3d1c5 | |
parent | d4838675253513504c4e0d0ed92489b3c4e6cf8d (diff) | |
parent | 453c02f971fc7865dea396731accbcd7ab6d3728 (diff) | |
download | ffmpeg-56ae5926f739bd26a5aa4add98604b7cd3c2d6ca.tar.gz |
Merge remote-tracking branch 'qatar/master'
* qatar/master:
libopenjpeg: introduce encoding support
libopenjpeg: rename decoder source file.
RTMPTS protocol support
RTMPS protocol support
avconv: print an error message when demuxing fails.
tscc2: DCT output should not be clipped
rtmp: Rename rtmphttp to ffrtmphttp
Conflicts:
Changelog
configure
doc/general.texi
libavcodec/libopenjpegenc.c
libavcodec/version.h
libavformat/version.h
Merged-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | Changelog | 2 | ||||
-rwxr-xr-x | configure | 12 | ||||
-rw-r--r-- | doc/general.texi | 5 | ||||
-rw-r--r-- | doc/protocols.texi | 15 | ||||
-rw-r--r-- | ffmpeg.c | 5 | ||||
-rw-r--r-- | libavcodec/libopenjpegenc.c | 46 | ||||
-rw-r--r-- | libavcodec/tscc2.c | 2 | ||||
-rw-r--r-- | libavcodec/version.h | 2 | ||||
-rw-r--r-- | libavformat/Makefile | 4 | ||||
-rw-r--r-- | libavformat/allformats.c | 4 | ||||
-rw-r--r-- | libavformat/rtmp.h | 1 | ||||
-rw-r--r-- | libavformat/rtmphttp.c | 37 | ||||
-rw-r--r-- | libavformat/rtmpproto.c | 52 | ||||
-rw-r--r-- | libavformat/version.h | 4 |
14 files changed, 155 insertions, 36 deletions
@@ -19,6 +19,8 @@ version next: - TechSmith Screen Codec 2 decoder - AAC encoding via libfdk-aac - Microsoft Expression Encoder Screen decoder +- RTMPS protocol support +- RTMPTS protocol support - showwaves filter - LucasArts SMUSH playback support - SAMI demuxer and decoder @@ -190,7 +190,7 @@ External library support: --enable-libopencore-amrnb enable AMR-NB de/encoding via libopencore-amrnb [no] --enable-libopencore-amrwb enable AMR-WB decoding via libopencore-amrwb [no] --enable-libopencv enable video filtering via libopencv [no] - --enable-libopenjpeg enable JPEG 2000 encoding/decoding via OpenJPEG [no] + --enable-libopenjpeg enable JPEG 2000 de/encoding via OpenJPEG [no] --enable-libpulse enable Pulseaudio input via libpulse [no] --enable-librtmp enable RTMP[E] support via librtmp [no] --enable-libschroedinger enable Dirac support via libschroedinger [no] @@ -1712,6 +1712,8 @@ x11_grab_device_indev_deps="x11grab XShmCreateImage" # protocols bluray_protocol_deps="libbluray" +ffrtmphttp_protocol_deps="!librtmp_protocol" +ffrtmphttp_protocol_select="http_protocol" gopher_protocol_deps="network" httpproxy_protocol_deps="network" httpproxy_protocol_select="tcp_protocol" @@ -1727,10 +1729,12 @@ mmsh_protocol_select="http_protocol" mmst_protocol_deps="network" rtmp_protocol_deps="!librtmp_protocol" rtmp_protocol_select="tcp_protocol" -rtmphttp_protocol_deps="!librtmp_protocol" -rtmphttp_protocol_select="http_protocol" +rtmps_protocol_deps="!librtmp_protocol" +rtmps_protocol_select="tls_protocol" rtmpt_protocol_deps="!librtmp_protocol" -rtmpt_protocol_select="rtmphttp_protocol" +rtmpt_protocol_select="ffrtmphttp_protocol" +rtmpts_protocol_deps="!librtmp_protocol" +rtmpts_protocol_select="ffrtmphttp_protocol" rtp_protocol_select="udp_protocol" sctp_protocol_deps="network netinet_sctp_h" tcp_protocol_deps="network" diff --git a/doc/general.texi b/doc/general.texi index f390cb7a2f..370765e9b2 100644 --- a/doc/general.texi +++ b/doc/general.texi @@ -905,9 +905,10 @@ performance on systems without hardware floating point support). @item pipe @tab X @item RTMP @tab X @item RTMPE @tab E -@item RTMPS @tab E -@item RTMPT @tab E +@item RTMPS @tab X +@item RTMPT @tab X @item RTMPTE @tab E +@item RTMPTS @tab X @item RTP @tab X @item SCTP @tab X @item TCP @tab X diff --git a/doc/protocols.texi b/doc/protocols.texi index 75a5976270..dc5d5eb052 100644 --- a/doc/protocols.texi +++ b/doc/protocols.texi @@ -277,6 +277,13 @@ For example to read with @command{ffplay} a multimedia resource named ffplay rtmp://myserver/vod/sample @end example +@section rtmps + +Real-Time Messaging Protocol over a secure SSL connection. + +The Real-Time Messaging Protocol (RTMPS) is used for streaming +multimedia content across an encrypted connection. + @section rtmpt Real-Time Messaging Protocol tunneled through HTTP. @@ -285,6 +292,14 @@ The Real-Time Messaging Protocol tunneled through HTTP (RTMPT) is used for streaming multimedia content within HTTP requests to traverse firewalls. +@section rtmpts + +Real-Time Messaging Protocol tunneled through HTTPS. + +The Real-Time Messaging Protocol tunneled through HTTPS (RTMPTS) is used +for streaming multimedia content within HTTPS requests to traverse +firewalls. + @section rtmp, rtmpe, rtmps, rtmpt, rtmpte Real-Time Messaging Protocol and its variants supported through @@ -3645,6 +3645,11 @@ static int transcode(void) continue; } if (ret < 0) { + if (ret != AVERROR_EOF) { + print_error(is->filename, ret); + if (exit_on_error) + exit_program(1); + } input_files[file_index]->eof_reached = 1; for (i = 0; i < input_files[file_index]->nb_streams; i++) { diff --git a/libavcodec/libopenjpegenc.c b/libavcodec/libopenjpegenc.c index 96cca283b8..bd741df985 100644 --- a/libavcodec/libopenjpegenc.c +++ b/libavcodec/libopenjpegenc.c @@ -24,14 +24,15 @@ * JPEG 2000 encoder using libopenjpeg */ +#define OPJ_STATIC +#include <openjpeg.h> + #include "libavutil/opt.h" #include "libavutil/imgutils.h" #include "libavutil/avassert.h" #include "avcodec.h" #include "libavutil/intreadwrite.h" #include "internal.h" -#define OPJ_STATIC -#include <openjpeg.h> typedef struct { AVClass *avclass; @@ -41,8 +42,8 @@ typedef struct { opj_event_mgr_t event_mgr; int format; int profile; - int cinema_mode; int prog_order; + int cinema_mode; int numresolution; int numlayers; int disto_alloc; @@ -52,12 +53,17 @@ typedef struct { static void error_callback(const char *msg, void *data) { - av_log((AVCodecContext*)data, AV_LOG_ERROR, "libopenjpeg: %s\n", msg); + av_log(data, AV_LOG_ERROR, "%s\n", msg); } static void warning_callback(const char *msg, void *data) { - av_log((AVCodecContext*)data, AV_LOG_WARNING, "libopenjpeg: %s\n", msg); + av_log(data, AV_LOG_WARNING, "%s\n", msg); +} + +static void info_callback(const char *msg, void *data) +{ + av_log(data, AV_LOG_DEBUG, "%s\n", msg); } static opj_image_t *mj2_create_image(AVCodecContext *avctx, opj_cparameters_t *parameters) @@ -116,11 +122,13 @@ static opj_image_t *mj2_create_image(AVCodecContext *avctx, opj_cparameters_t *p color_space = CLRSPC_SYCC; break; default: - av_log(avctx, AV_LOG_ERROR, "The requested pixel format '%s' is not supported\n", av_get_pix_fmt_name(avctx->pix_fmt)); + av_log(avctx, AV_LOG_ERROR, + "The requested pixel format '%s' is not supported\n", + av_get_pix_fmt_name(avctx->pix_fmt)); return NULL; } - cmptparm = av_mallocz(numcomps * sizeof(opj_image_cmptparm_t)); + cmptparm = av_mallocz(numcomps * sizeof(*cmptparm)); if (!cmptparm) { av_log(avctx, AV_LOG_ERROR, "Not enough memory"); return NULL; @@ -143,8 +151,10 @@ static opj_image_t *mj2_create_image(AVCodecContext *avctx, opj_cparameters_t *p static av_cold int libopenjpeg_encode_init(AVCodecContext *avctx) { LibOpenJPEGContext *ctx = avctx->priv_data; + int err = AVERROR(ENOMEM); opj_set_default_encoder_parameters(&ctx->enc_params); + ctx->enc_params.cp_rsiz = ctx->profile; ctx->enc_params.mode = !!avctx->global_quality; ctx->enc_params.cp_cinema = ctx->cinema_mode; @@ -164,26 +174,29 @@ static av_cold int libopenjpeg_encode_init(AVCodecContext *avctx) avctx->coded_frame = avcodec_alloc_frame(); if (!avctx->coded_frame) { - av_freep(&ctx->compress); av_log(avctx, AV_LOG_ERROR, "Error allocating coded frame\n"); - return AVERROR(ENOMEM); + goto fail; } ctx->image = mj2_create_image(avctx, &ctx->enc_params); if (!ctx->image) { - av_freep(&ctx->compress); - av_freep(&avctx->coded_frame); av_log(avctx, AV_LOG_ERROR, "Error creating the mj2 image\n"); - return AVERROR(EINVAL); + err = AVERROR(EINVAL); + goto fail; } memset(&ctx->event_mgr, 0, sizeof(opj_event_mgr_t)); + ctx->event_mgr.info_handler = info_callback; ctx->event_mgr.error_handler = error_callback; ctx->event_mgr.warning_handler = warning_callback; - ctx->event_mgr.info_handler = NULL; opj_set_event_mgr((opj_common_ptr)ctx->compress, &ctx->event_mgr, avctx); return 0; + +fail: + av_freep(&ctx->compress); + av_freep(&avctx->coded_frame); + return err; } static int libopenjpeg_copy_packed8(AVCodecContext *avctx, const AVFrame *frame, opj_image_t *image) @@ -373,13 +386,16 @@ static int libopenjpeg_encode_frame(AVCodecContext *avctx, AVPacket *pkt, cpyresult = libopenjpeg_copy_unpacked16(avctx, frame, image); break; default: - av_log(avctx, AV_LOG_ERROR, "The frame's pixel format '%s' is not supported\n", av_get_pix_fmt_name(avctx->pix_fmt)); + av_log(avctx, AV_LOG_ERROR, + "The frame's pixel format '%s' is not supported\n", + av_get_pix_fmt_name(avctx->pix_fmt)); return AVERROR(EINVAL); break; } if (!cpyresult) { - av_log(avctx, AV_LOG_ERROR, "Could not copy the frame data to the internal image buffer\n"); + av_log(avctx, AV_LOG_ERROR, + "Could not copy the frame data to the internal image buffer\n"); return -1; } diff --git a/libavcodec/tscc2.c b/libavcodec/tscc2.c index 5e36a0e307..9c8d2341ce 100644 --- a/libavcodec/tscc2.c +++ b/libavcodec/tscc2.c @@ -95,7 +95,7 @@ static av_cold int init_vlcs(TSCC2Context *c) OP(d3, 5 * ((s0) - (s1) + (s2)) - 2 * (s3)); \ #define COL_OP(a, b) a = b -#define ROW_OP(a, b) a = av_clip_uint8((((b) + 0x20) >> 6) + 0x80) +#define ROW_OP(a, b) a = (((b) + 0x20) >> 6) + 0x80 static void tscc2_idct4_put(int *in, int q[3], uint8_t *dst, int stride) { diff --git a/libavcodec/version.h b/libavcodec/version.h index b146635f84..7538125714 100644 --- a/libavcodec/version.h +++ b/libavcodec/version.h @@ -27,7 +27,7 @@ */ #define LIBAVCODEC_VERSION_MAJOR 54 -#define LIBAVCODEC_VERSION_MINOR 40 +#define LIBAVCODEC_VERSION_MINOR 41 #define LIBAVCODEC_VERSION_MICRO 100 #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ diff --git a/libavformat/Makefile b/libavformat/Makefile index a3ddcad405..45ae6ea562 100644 --- a/libavformat/Makefile +++ b/libavformat/Makefile @@ -373,6 +373,7 @@ OBJS-$(CONFIG_BLURAY_PROTOCOL) += bluray.o OBJS-$(CONFIG_CACHE_PROTOCOL) += cache.o OBJS-$(CONFIG_CONCAT_PROTOCOL) += concat.o OBJS-$(CONFIG_CRYPTO_PROTOCOL) += crypto.o +OBJS-$(CONFIG_FFRTMPHTTP_PROTOCOL) += rtmphttp.o OBJS-$(CONFIG_FILE_PROTOCOL) += file.o OBJS-$(CONFIG_GOPHER_PROTOCOL) += gopher.o OBJS-$(CONFIG_HLS_PROTOCOL) += hlsproto.o @@ -384,8 +385,9 @@ OBJS-$(CONFIG_MMST_PROTOCOL) += mmst.o mms.o asf.o OBJS-$(CONFIG_MD5_PROTOCOL) += md5proto.o OBJS-$(CONFIG_PIPE_PROTOCOL) += file.o OBJS-$(CONFIG_RTMP_PROTOCOL) += rtmpproto.o rtmppkt.o -OBJS-$(CONFIG_RTMPHTTP_PROTOCOL) += rtmphttp.o +OBJS-$(CONFIG_RTMPS_PROTOCOL) += rtmpproto.o rtmppkt.o OBJS-$(CONFIG_RTMPT_PROTOCOL) += rtmpproto.o rtmppkt.o +OBJS-$(CONFIG_RTMPTS_PROTOCOL) += rtmpproto.o rtmppkt.o OBJS-$(CONFIG_RTP_PROTOCOL) += rtpproto.o OBJS-$(CONFIG_SCTP_PROTOCOL) += sctp.o OBJS-$(CONFIG_TCP_PROTOCOL) += tcp.o diff --git a/libavformat/allformats.c b/libavformat/allformats.c index 7ea4ebb378..94dc347cfe 100644 --- a/libavformat/allformats.c +++ b/libavformat/allformats.c @@ -272,6 +272,7 @@ void av_register_all(void) REGISTER_PROTOCOL (CACHE, cache); REGISTER_PROTOCOL (CONCAT, concat); REGISTER_PROTOCOL (CRYPTO, crypto); + REGISTER_PROTOCOL (FFRTMPHTTP, ffrtmphttp); REGISTER_PROTOCOL (FILE, file); REGISTER_PROTOCOL (GOPHER, gopher); REGISTER_PROTOCOL (HLS, hls); @@ -283,8 +284,9 @@ void av_register_all(void) REGISTER_PROTOCOL (MD5, md5); REGISTER_PROTOCOL (PIPE, pipe); REGISTER_PROTOCOL (RTMP, rtmp); - REGISTER_PROTOCOL (RTMPHTTP, rtmphttp); + REGISTER_PROTOCOL (RTMPS, rtmps); REGISTER_PROTOCOL (RTMPT, rtmpt); + REGISTER_PROTOCOL (RTMPTS, rtmpts); REGISTER_PROTOCOL (RTP, rtp); REGISTER_PROTOCOL (SCTP, sctp); REGISTER_PROTOCOL (TCP, tcp); diff --git a/libavformat/rtmp.h b/libavformat/rtmp.h index b0436c0391..9982d467f3 100644 --- a/libavformat/rtmp.h +++ b/libavformat/rtmp.h @@ -25,6 +25,7 @@ #include "avformat.h" #define RTMP_DEFAULT_PORT 1935 +#define RTMPS_DEFAULT_PORT 443 #define RTMP_HANDSHAKE_PACKET_SIZE 1536 diff --git a/libavformat/rtmphttp.c b/libavformat/rtmphttp.c index 4f94859c5e..2a8922ee74 100644 --- a/libavformat/rtmphttp.c +++ b/libavformat/rtmphttp.c @@ -30,11 +30,14 @@ #include "libavutil/time.h" #include "internal.h" #include "http.h" +#include "rtmp.h" #define RTMPT_DEFAULT_PORT 80 +#define RTMPTS_DEFAULT_PORT RTMPS_DEFAULT_PORT /* protocol handler context */ typedef struct RTMP_HTTPContext { + const AVClass *class; URLContext *stream; ///< HTTP stream char host[256]; ///< hostname of the server int port; ///< port to connect (default is 80) @@ -46,6 +49,7 @@ typedef struct RTMP_HTTPContext { int initialized; ///< flag indicating when the http context is initialized int finishing; ///< flag indicating when the client closes the connection int nb_bytes_read; ///< number of bytes read since the last request + int tls; ///< use Transport Security Layer (RTMPTS) } RTMP_HTTPContext; static int rtmp_http_send_cmd(URLContext *h, const char *cmd) @@ -185,9 +189,6 @@ static int rtmp_http_open(URLContext *h, const char *uri, int flags) av_url_split(NULL, 0, NULL, 0, rt->host, sizeof(rt->host), &rt->port, NULL, 0, uri); - if (rt->port < 0) - rt->port = RTMPT_DEFAULT_PORT; - /* This is the first request that is sent to the server in order to * register a client on the server and start a new session. The server * replies with a unique id (usually a number) that is used by the client @@ -195,7 +196,15 @@ static int rtmp_http_open(URLContext *h, const char *uri, int flags) * Note: the reply doesn't contain a value for the polling interval. * A successful connect resets the consecutive index that is used * in the URLs. */ - ff_url_join(url, sizeof(url), "http", NULL, rt->host, rt->port, "/open/1"); + if (rt->tls) { + if (rt->port < 0) + rt->port = RTMPTS_DEFAULT_PORT; + ff_url_join(url, sizeof(url), "https", NULL, rt->host, rt->port, "/open/1"); + } else { + if (rt->port < 0) + rt->port = RTMPT_DEFAULT_PORT; + ff_url_join(url, sizeof(url), "http", NULL, rt->host, rt->port, "/open/1"); + } /* alloc the http context */ if ((ret = ffurl_alloc(&rt->stream, url, AVIO_FLAG_READ_WRITE, NULL)) < 0) @@ -240,12 +249,28 @@ fail: return ret; } -URLProtocol ff_rtmphttp_protocol = { - .name = "rtmphttp", +#define OFFSET(x) offsetof(RTMP_HTTPContext, x) +#define DEC AV_OPT_FLAG_DECODING_PARAM + +static const AVOption ffrtmphttp_options[] = { + {"ffrtmphttp_tls", "Use a HTTPS tunneling connection (RTMPTS).", OFFSET(tls), AV_OPT_TYPE_INT, {0}, 0, 1, DEC}, + { NULL }, +}; + +static const AVClass ffrtmphttp_class = { + .class_name = "ffrtmphttp", + .item_name = av_default_item_name, + .option = ffrtmphttp_options, + .version = LIBAVUTIL_VERSION_INT, +}; + +URLProtocol ff_ffrtmphttp_protocol = { + .name = "ffrtmphttp", .url_open = rtmp_http_open, .url_read = rtmp_http_read, .url_write = rtmp_http_write, .url_close = rtmp_http_close, .priv_data_size = sizeof(RTMP_HTTPContext), .flags = URL_PROTOCOL_FLAG_NETWORK, + .priv_data_class= &ffrtmphttp_class, }; diff --git a/libavformat/rtmpproto.c b/libavformat/rtmpproto.c index 1290b7e5cf..272dde8e67 100644 --- a/libavformat/rtmpproto.c +++ b/libavformat/rtmpproto.c @@ -1111,6 +1111,7 @@ static int rtmp_open(URLContext *s, const char *uri, int flags) char *old_app; uint8_t buf[2048]; int port; + AVDictionary *opts = NULL; int ret; rt->is_input = !(flags & AVIO_FLAG_WRITE); @@ -1118,9 +1119,17 @@ static int rtmp_open(URLContext *s, const char *uri, int flags) av_url_split(proto, sizeof(proto), NULL, 0, hostname, sizeof(hostname), &port, path, sizeof(path), s->filename); - if (!strcmp(proto, "rtmpt")) { + if (!strcmp(proto, "rtmpt") || !strcmp(proto, "rtmpts")) { + if (!strcmp(proto, "rtmpts")) + av_dict_set(&opts, "ffrtmphttp_tls", "1", 1); + /* open the http tunneling connection */ - ff_url_join(buf, sizeof(buf), "rtmphttp", NULL, hostname, port, NULL); + ff_url_join(buf, sizeof(buf), "ffrtmphttp", NULL, hostname, port, NULL); + } else if (!strcmp(proto, "rtmps")) { + /* open the tls connection */ + if (port < 0) + port = RTMPS_DEFAULT_PORT; + ff_url_join(buf, sizeof(buf), "tls", NULL, hostname, port, NULL); } else { /* open the tcp connection */ if (port < 0) @@ -1129,7 +1138,7 @@ static int rtmp_open(URLContext *s, const char *uri, int flags) } if ((ret = ffurl_open(&rt->stream, buf, AVIO_FLAG_READ_WRITE, - &s->interrupt_callback, NULL)) < 0) { + &s->interrupt_callback, &opts)) < 0) { av_log(s , AV_LOG_ERROR, "Cannot open connection %s\n", buf); goto fail; } @@ -1261,6 +1270,7 @@ static int rtmp_open(URLContext *s, const char *uri, int flags) return 0; fail: + av_dict_free(&opts); rtmp_close(s); return ret; } @@ -1444,6 +1454,24 @@ URLProtocol ff_rtmp_protocol = { .priv_data_class= &rtmp_class, }; +static const AVClass rtmps_class = { + .class_name = "rtmps", + .item_name = av_default_item_name, + .option = rtmp_options, + .version = LIBAVUTIL_VERSION_INT, +}; + +URLProtocol ff_rtmps_protocol = { + .name = "rtmps", + .url_open = rtmp_open, + .url_read = rtmp_read, + .url_write = rtmp_write, + .url_close = rtmp_close, + .priv_data_size = sizeof(RTMPContext), + .flags = URL_PROTOCOL_FLAG_NETWORK, + .priv_data_class = &rtmps_class, +}; + static const AVClass rtmpt_class = { .class_name = "rtmpt", .item_name = av_default_item_name, @@ -1461,3 +1489,21 @@ URLProtocol ff_rtmpt_protocol = { .flags = URL_PROTOCOL_FLAG_NETWORK, .priv_data_class = &rtmpt_class, }; + +static const AVClass rtmpts_class = { + .class_name = "rtmpts", + .item_name = av_default_item_name, + .option = rtmp_options, + .version = LIBAVUTIL_VERSION_INT, +}; + +URLProtocol ff_rtmpts_protocol = { + .name = "rtmpts", + .url_open = rtmp_open, + .url_read = rtmp_read, + .url_write = rtmp_write, + .url_close = rtmp_close, + .priv_data_size = sizeof(RTMPContext), + .flags = URL_PROTOCOL_FLAG_NETWORK, + .priv_data_class = &rtmpts_class, +}; diff --git a/libavformat/version.h b/libavformat/version.h index 215ce13e33..96270bfdc9 100644 --- a/libavformat/version.h +++ b/libavformat/version.h @@ -30,8 +30,8 @@ #include "libavutil/avutil.h" #define LIBAVFORMAT_VERSION_MAJOR 54 -#define LIBAVFORMAT_VERSION_MINOR 16 -#define LIBAVFORMAT_VERSION_MICRO 104 +#define LIBAVFORMAT_VERSION_MINOR 17 +#define LIBAVFORMAT_VERSION_MICRO 100 #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \ LIBAVFORMAT_VERSION_MINOR, \ |