summaryrefslogtreecommitdiff
path: root/libavformat/rtsp.c
diff options
context:
space:
mode:
authorHayden Myers <hmyers@skylinenet.net>2021-07-12 16:00:34 +0300
committerMartin Storsjö <martin@martin.st>2021-07-12 16:00:48 +0300
commit9b4b0df47009ebc3d26bf3f1b1eff668fd028cc6 (patch)
tree1f2b337eb58166bf2a96e55f8ec12104e6cdf468 /libavformat/rtsp.c
parenta948e47960fb16819af16d0542a203c59d8de157 (diff)
libavformat/rtsp.c: Reply to GET_PARAMETER requests
Some encoders send GET_PARAMETER requests as a keep-alive mechanism. If the client doesn't reply with an OK message, the encoder will close the session. This was encountered with the impath i5110 encoder, when the RTSP Keep-Alive checkbox is enabled under streaming settings. Alternatively one may set the X-No-Keepalive: 1 header, but this is more of a workaround. It's better practice to respond to an encoder's keep-alive request, than disable the mechanism which may be manufacturer specific. Signed-off-by: Hayden Myers <hmyers@skylinenet.net> Signed-off-by: Martin Storsjö <martin@martin.st>
Diffstat (limited to 'libavformat/rtsp.c')
-rw-r--r--libavformat/rtsp.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/libavformat/rtsp.c b/libavformat/rtsp.c
index 972cab57d7..9869e1b72e 100644
--- a/libavformat/rtsp.c
+++ b/libavformat/rtsp.c
@@ -1259,7 +1259,8 @@ start:
char base64buf[AV_BASE64_SIZE(sizeof(buf))];
const char* ptr = buf;
- if (!strcmp(reply->reason, "OPTIONS")) {
+ if (!strcmp(reply->reason, "OPTIONS") ||
+ !strcmp(reply->reason, "GET_PARAMETER")) {
snprintf(buf, sizeof(buf), "RTSP/1.0 200 OK\r\n");
if (reply->seq)
av_strlcatf(buf, sizeof(buf), "CSeq: %d\r\n", reply->seq);