|
|
|
--- a/configure
|
|
|
|
+++ b/configure
|
|
|
|
@@ -3353,10 +3353,8 @@ xv_outdev_deps="xlib"
|
|
|
|
# protocols
|
|
|
|
async_protocol_deps="threads"
|
|
|
|
bluray_protocol_deps="libbluray"
|
|
|
|
-ffrtmpcrypt_protocol_conflict="librtmp_protocol"
|
|
|
|
ffrtmpcrypt_protocol_deps_any="gcrypt gmp openssl mbedtls"
|
|
|
|
ffrtmpcrypt_protocol_select="tcp_protocol"
|
|
|
|
-ffrtmphttp_protocol_conflict="librtmp_protocol"
|
|
|
|
ffrtmphttp_protocol_select="http_protocol"
|
|
|
|
ftp_protocol_select="tcp_protocol"
|
|
|
|
gopher_protocol_select="network"
|
|
|
|
@@ -3369,20 +3367,18 @@ https_protocol_suggest="zlib"
|
|
|
|
icecast_protocol_select="http_protocol"
|
|
|
|
mmsh_protocol_select="http_protocol"
|
|
|
|
mmst_protocol_select="network"
|
|
|
|
-rtmp_protocol_conflict="librtmp_protocol"
|
|
|
|
-rtmp_protocol_select="tcp_protocol"
|
|
|
|
-rtmp_protocol_suggest="zlib"
|
|
|
|
-rtmpe_protocol_select="ffrtmpcrypt_protocol"
|
|
|
|
-rtmpe_protocol_suggest="zlib"
|
|
|
|
-rtmps_protocol_conflict="librtmp_protocol"
|
|
|
|
-rtmps_protocol_select="tls_protocol"
|
|
|
|
-rtmps_protocol_suggest="zlib"
|
|
|
|
-rtmpt_protocol_select="ffrtmphttp_protocol"
|
|
|
|
-rtmpt_protocol_suggest="zlib"
|
|
|
|
-rtmpte_protocol_select="ffrtmpcrypt_protocol ffrtmphttp_protocol"
|
|
|
|
-rtmpte_protocol_suggest="zlib"
|
|
|
|
-rtmpts_protocol_select="ffrtmphttp_protocol https_protocol"
|
|
|
|
-rtmpts_protocol_suggest="zlib"
|
|
|
|
+ffrtmp_protocol_select="tcp_protocol"
|
|
|
|
+ffrtmp_protocol_suggest="zlib"
|
|
|
|
+ffrtmpe_protocol_select="ffrtmpcrypt_protocol"
|
|
|
|
+ffrtmpe_protocol_suggest="zlib"
|
|
|
|
+ffrtmps_protocol_select="tls_protocol"
|
|
|
|
+ffrtmps_protocol_suggest="zlib"
|
|
|
|
+ffrtmpt_protocol_select="ffrtmphttp_protocol"
|
|
|
|
+ffrtmpt_protocol_suggest="zlib"
|
|
|
|
+ffrtmpte_protocol_select="ffrtmpcrypt_protocol ffrtmphttp_protocol"
|
|
|
|
+ffrtmpte_protocol_suggest="zlib"
|
|
|
|
+ffrtmpts_protocol_select="ffrtmphttp_protocol https_protocol"
|
|
|
|
+ffrtmpts_protocol_suggest="zlib"
|
|
|
|
rtp_protocol_select="udp_protocol"
|
|
|
|
schannel_conflict="openssl gnutls libtls mbedtls"
|
|
|
|
sctp_protocol_deps="struct_sctp_event_subscribe struct_msghdr_msg_flags"
|
|
|
|
--- a/libavformat/Makefile
|
|
|
|
+++ b/libavformat/Makefile
|
|
|
|
@@ -599,12 +599,12 @@ OBJS-$(CONFIG_MMSH_PROTOCOL) += mmsh.o mms.o asf.o
|
|
|
|
OBJS-$(CONFIG_MMST_PROTOCOL) += mmst.o mms.o asf.o
|
|
|
|
OBJS-$(CONFIG_PIPE_PROTOCOL) += file.o
|
|
|
|
OBJS-$(CONFIG_PROMPEG_PROTOCOL) += prompeg.o
|
|
|
|
-OBJS-$(CONFIG_RTMP_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
-OBJS-$(CONFIG_RTMPE_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
-OBJS-$(CONFIG_RTMPS_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
-OBJS-$(CONFIG_RTMPT_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
-OBJS-$(CONFIG_RTMPTE_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
-OBJS-$(CONFIG_RTMPTS_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMP_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMPE_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMPS_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMPT_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMPTE_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
+OBJS-$(CONFIG_FFRTMPTS_PROTOCOL) += rtmpproto.o rtmpdigest.o rtmppkt.o
|
|
|
|
OBJS-$(CONFIG_RTP_PROTOCOL) += rtpproto.o ip.o
|
|
|
|
OBJS-$(CONFIG_SCTP_PROTOCOL) += sctp.o
|
|
|
|
OBJS-$(CONFIG_SRTP_PROTOCOL) += srtpproto.o srtp.o
|
|
|
|
--- a/libavformat/protocols.c
|
|
|
|
+++ b/libavformat/protocols.c
|
|
|
|
@@ -44,12 +44,12 @@ extern const URLProtocol ff_mmst_protocol;
|
|
|
|
extern const URLProtocol ff_md5_protocol;
|
|
|
|
extern const URLProtocol ff_pipe_protocol;
|
|
|
|
extern const URLProtocol ff_prompeg_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmp_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmpe_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmps_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmpt_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmpte_protocol;
|
|
|
|
-extern const URLProtocol ff_rtmpts_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmp_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmpe_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmps_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmpt_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmpte_protocol;
|
|
|
|
+extern const URLProtocol ff_ffrtmpts_protocol;
|
|
|
|
extern const URLProtocol ff_rtp_protocol;
|
|
|
|
extern const URLProtocol ff_sctp_protocol;
|
|
|
|
extern const URLProtocol ff_srtp_protocol;
|
|
|
|
--- a/libavformat/rtmpproto.c
|
|
|
|
+++ b/libavformat/rtmpproto.c
|
|
|
|
@@ -2592,7 +2592,7 @@ static int inject_fake_duration_metadata(RTMPContext *rt)
|
|
|
|
static int rtmp_open(URLContext *s, const char *uri, int flags, AVDictionary **opts)
|
|
|
|
{
|
|
|
|
RTMPContext *rt = s->priv_data;
|
|
|
|
- char proto[8], hostname[256], path[1024], auth[100], *fname;
|
|
|
|
+ char *proto, tmpProto[10], hostname[256], path[1024], auth[100], *fname;
|
|
|
|
char *old_app, *qmark, *n, fname_buffer[1024];
|
|
|
|
uint8_t buf[2048];
|
|
|
|
int port;
|
|
|
|
@@ -2603,7 +2603,9 @@ static int rtmp_open(URLContext *s, const char *uri, int flags, AVDictionary **o
|
|
|
|
|
|
|
|
rt->is_input = !(flags & AVIO_FLAG_WRITE);
|
|
|
|
|
|
|
|
- av_url_split(proto, sizeof(proto), auth, sizeof(auth),
|
|
|
|
+ memset(tmpProto, 0, sizeof(tmpProto));
|
|
|
|
+ proto = &tmpProto[2];
|
|
|
|
+ av_url_split(tmpProto, sizeof(tmpProto), auth, sizeof(auth),
|
|
|
|
hostname, sizeof(hostname), &port,
|
|
|
|
path, sizeof(path), s->filename);
|
|
|
|
|
|
|
|
@@ -3137,9 +3139,9 @@ const URLProtocol ff_##flavor##_protocol = { \
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
-RTMP_PROTOCOL(rtmp)
|
|
|
|
-RTMP_PROTOCOL(rtmpe)
|
|
|
|
-RTMP_PROTOCOL(rtmps)
|
|
|
|
-RTMP_PROTOCOL(rtmpt)
|
|
|
|
-RTMP_PROTOCOL(rtmpte)
|
|
|
|
-RTMP_PROTOCOL(rtmpts)
|
|
|
|
+RTMP_PROTOCOL(ffrtmp)
|
|
|
|
+RTMP_PROTOCOL(ffrtmpe)
|
|
|
|
+RTMP_PROTOCOL(ffrtmps)
|
|
|
|
+RTMP_PROTOCOL(ffrtmpt)
|
|
|
|
+RTMP_PROTOCOL(ffrtmpte)
|
|
|
|
+RTMP_PROTOCOL(ffrtmpts)
|