mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-02 04:52:09 +00:00
rtsp: add allowed_media_types option
Streams from RTSP or SDP that do not match an allowed type will be skipped entirely, which allows video-only or audio-only streaming from servers that provide both. Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
20e081dddc
commit
f011fcd67e
@ -65,6 +65,12 @@
|
|||||||
{ name, longname, OFFSET(rtsp_flags), AV_OPT_TYPE_FLAGS, {0}, INT_MIN, INT_MAX, DEC, "rtsp_flags" }, \
|
{ name, longname, OFFSET(rtsp_flags), AV_OPT_TYPE_FLAGS, {0}, INT_MIN, INT_MAX, DEC, "rtsp_flags" }, \
|
||||||
{ "filter_src", "Only receive packets from the negotiated peer IP", 0, AV_OPT_TYPE_CONST, {RTSP_FLAG_FILTER_SRC}, 0, 0, DEC, "rtsp_flags" }
|
{ "filter_src", "Only receive packets from the negotiated peer IP", 0, AV_OPT_TYPE_CONST, {RTSP_FLAG_FILTER_SRC}, 0, 0, DEC, "rtsp_flags" }
|
||||||
|
|
||||||
|
#define RTSP_MEDIATYPE_OPTS(name, longname) \
|
||||||
|
{ name, longname, OFFSET(media_type_mask), AV_OPT_TYPE_FLAGS, { (1 << (AVMEDIA_TYPE_DATA+1)) - 1 }, INT_MIN, INT_MAX, DEC, "allowed_media_types" }, \
|
||||||
|
{ "video", "Video", 0, AV_OPT_TYPE_CONST, {1 << AVMEDIA_TYPE_VIDEO}, 0, 0, DEC, "allowed_media_types" }, \
|
||||||
|
{ "audio", "Audio", 0, AV_OPT_TYPE_CONST, {1 << AVMEDIA_TYPE_AUDIO}, 0, 0, DEC, "allowed_media_types" }, \
|
||||||
|
{ "data", "Data", 0, AV_OPT_TYPE_CONST, {1 << AVMEDIA_TYPE_DATA}, 0, 0, DEC, "allowed_media_types" }
|
||||||
|
|
||||||
const AVOption ff_rtsp_options[] = {
|
const AVOption ff_rtsp_options[] = {
|
||||||
{ "initial_pause", "Don't start playing the stream immediately", OFFSET(initial_pause), AV_OPT_TYPE_INT, {0}, 0, 1, DEC },
|
{ "initial_pause", "Don't start playing the stream immediately", OFFSET(initial_pause), AV_OPT_TYPE_INT, {0}, 0, 1, DEC },
|
||||||
FF_RTP_FLAG_OPTS(RTSPState, rtp_muxer_flags),
|
FF_RTP_FLAG_OPTS(RTSPState, rtp_muxer_flags),
|
||||||
@ -74,11 +80,13 @@ const AVOption ff_rtsp_options[] = {
|
|||||||
{ "udp_multicast", "UDP multicast", 0, AV_OPT_TYPE_CONST, {1 << RTSP_LOWER_TRANSPORT_UDP_MULTICAST}, 0, 0, DEC, "rtsp_transport" },
|
{ "udp_multicast", "UDP multicast", 0, AV_OPT_TYPE_CONST, {1 << RTSP_LOWER_TRANSPORT_UDP_MULTICAST}, 0, 0, DEC, "rtsp_transport" },
|
||||||
{ "http", "HTTP tunneling", 0, AV_OPT_TYPE_CONST, {(1 << RTSP_LOWER_TRANSPORT_HTTP)}, 0, 0, DEC, "rtsp_transport" },
|
{ "http", "HTTP tunneling", 0, AV_OPT_TYPE_CONST, {(1 << RTSP_LOWER_TRANSPORT_HTTP)}, 0, 0, DEC, "rtsp_transport" },
|
||||||
RTSP_FLAG_OPTS("rtsp_flags", "RTSP flags"),
|
RTSP_FLAG_OPTS("rtsp_flags", "RTSP flags"),
|
||||||
|
RTSP_MEDIATYPE_OPTS("allowed_media_types", "Media types to accept from the server"),
|
||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
static const AVOption sdp_options[] = {
|
static const AVOption sdp_options[] = {
|
||||||
RTSP_FLAG_OPTS("sdp_flags", "SDP flags"),
|
RTSP_FLAG_OPTS("sdp_flags", "SDP flags"),
|
||||||
|
RTSP_MEDIATYPE_OPTS("allowed_media_types", "Media types to accept from the server"),
|
||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -325,6 +333,7 @@ static void sdp_parse_line(AVFormatContext *s, SDPParseState *s1,
|
|||||||
case 'm':
|
case 'm':
|
||||||
/* new stream */
|
/* new stream */
|
||||||
s1->skip_media = 0;
|
s1->skip_media = 0;
|
||||||
|
codec_type = AVMEDIA_TYPE_UNKNOWN;
|
||||||
get_word(st_type, sizeof(st_type), &p);
|
get_word(st_type, sizeof(st_type), &p);
|
||||||
if (!strcmp(st_type, "audio")) {
|
if (!strcmp(st_type, "audio")) {
|
||||||
codec_type = AVMEDIA_TYPE_AUDIO;
|
codec_type = AVMEDIA_TYPE_AUDIO;
|
||||||
@ -332,7 +341,8 @@ static void sdp_parse_line(AVFormatContext *s, SDPParseState *s1,
|
|||||||
codec_type = AVMEDIA_TYPE_VIDEO;
|
codec_type = AVMEDIA_TYPE_VIDEO;
|
||||||
} else if (!strcmp(st_type, "application")) {
|
} else if (!strcmp(st_type, "application")) {
|
||||||
codec_type = AVMEDIA_TYPE_DATA;
|
codec_type = AVMEDIA_TYPE_DATA;
|
||||||
} else {
|
}
|
||||||
|
if (codec_type == AVMEDIA_TYPE_UNKNOWN || !(rt->media_type_mask & (1 << codec_type))) {
|
||||||
s1->skip_media = 1;
|
s1->skip_media = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -354,6 +354,11 @@ typedef struct RTSPState {
|
|||||||
* Various option flags for the RTSP muxer/demuxer.
|
* Various option flags for the RTSP muxer/demuxer.
|
||||||
*/
|
*/
|
||||||
int rtsp_flags;
|
int rtsp_flags;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mask of all requested media types
|
||||||
|
*/
|
||||||
|
int media_type_mask;
|
||||||
} RTSPState;
|
} RTSPState;
|
||||||
|
|
||||||
#define RTSP_FLAG_FILTER_SRC 0x1 /**< Filter incoming UDP packets -
|
#define RTSP_FLAG_FILTER_SRC 0x1 /**< Filter incoming UDP packets -
|
||||||
|
Loading…
Reference in New Issue
Block a user