diff --git a/libavformat/Makefile b/libavformat/Makefile
index 64b2d823ed7d0a645c26d92cb838bccedb49ded6..f3f8679b421d7a1dcd9d990cd4de648c84ea8aa5 100644
--- a/libavformat/Makefile
+++ b/libavformat/Makefile
@@ -247,6 +247,7 @@ OBJS-$(CONFIG_RTPDEC)                    += rdt.o         \
                                             rtpdec.o      \
                                             rtpdec_amr.o  \
                                             rtpdec_asf.o  \
+                                            rtpdec_g726.o \
                                             rtpdec_h263.o \
                                             rtpdec_h264.o \
                                             rtpdec_latm.o \
diff --git a/libavformat/rtpdec.c b/libavformat/rtpdec.c
index 88cf15bdea4efee65cfb3cec098bab65c93f2de8..7e8b52adad50394e46986504492778329c0f23ad 100644
--- a/libavformat/rtpdec.c
+++ b/libavformat/rtpdec.c
@@ -83,6 +83,11 @@ void av_register_rtp_dynamic_payload_handlers(void)
     ff_register_dynamic_payload_handler(&ff_qt_rtp_vid_handler);
     ff_register_dynamic_payload_handler(&ff_quicktime_rtp_aud_handler);
     ff_register_dynamic_payload_handler(&ff_quicktime_rtp_vid_handler);
+
+    ff_register_dynamic_payload_handler(&ff_g726_16_dynamic_handler);
+    ff_register_dynamic_payload_handler(&ff_g726_24_dynamic_handler);
+    ff_register_dynamic_payload_handler(&ff_g726_32_dynamic_handler);
+    ff_register_dynamic_payload_handler(&ff_g726_40_dynamic_handler);
 }
 
 RTPDynamicProtocolHandler *ff_rtp_handler_find_by_name(const char *name,
diff --git a/libavformat/rtpdec_formats.h b/libavformat/rtpdec_formats.h
index 708c2996d6555d3c7cd0951679e4bece2e9ed223..3074565db74e46f6f19a205a343e28a161e1a6ff 100644
--- a/libavformat/rtpdec_formats.h
+++ b/libavformat/rtpdec_formats.h
@@ -33,6 +33,10 @@ int ff_wms_parse_sdp_a_line(AVFormatContext *s, const char *p);
 
 extern RTPDynamicProtocolHandler ff_amr_nb_dynamic_handler;
 extern RTPDynamicProtocolHandler ff_amr_wb_dynamic_handler;
+extern RTPDynamicProtocolHandler ff_g726_16_dynamic_handler;
+extern RTPDynamicProtocolHandler ff_g726_24_dynamic_handler;
+extern RTPDynamicProtocolHandler ff_g726_32_dynamic_handler;
+extern RTPDynamicProtocolHandler ff_g726_40_dynamic_handler;
 extern RTPDynamicProtocolHandler ff_h263_1998_dynamic_handler;
 extern RTPDynamicProtocolHandler ff_h263_2000_dynamic_handler;
 extern RTPDynamicProtocolHandler ff_h264_dynamic_handler;
diff --git a/libavformat/rtpdec_g726.c b/libavformat/rtpdec_g726.c
new file mode 100644
index 0000000000000000000000000000000000000000..0b7b0f0f94f8f90f8f824111b9459c13142e34ef
--- /dev/null
+++ b/libavformat/rtpdec_g726.c
@@ -0,0 +1,102 @@
+/*
+ * Copyright (c) 2011 Miroslav Slugeň <Thunder.m@seznam.cz>
+ *
+ * This file is part of Libav.
+ *
+ * Libav is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * Libav is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with Libav; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "avformat.h"
+#include "rtpdec_formats.h"
+
+static int g726_16_init(AVFormatContext *s, int st_index, PayloadContext *data)
+{
+    AVStream *stream = s->streams[st_index];
+    AVCodecContext *codec = stream->codec;
+
+    codec->bit_rate = 16000;
+    if (codec->sample_rate)
+        codec->bits_per_coded_sample =
+            av_clip((codec->bit_rate + codec->sample_rate/2) / codec->sample_rate, 2, 5);
+
+    return 0;
+}
+
+static int g726_24_init(AVFormatContext *s, int st_index, PayloadContext *data)
+{
+    AVStream *stream = s->streams[st_index];
+    AVCodecContext *codec = stream->codec;
+
+    codec->bit_rate = 24000;
+    if (codec->sample_rate)
+        codec->bits_per_coded_sample =
+            av_clip((codec->bit_rate + codec->sample_rate/2) / codec->sample_rate, 2, 5);
+
+    return 0;
+}
+
+static int g726_32_init(AVFormatContext *s, int st_index, PayloadContext *data)
+{
+    AVStream *stream = s->streams[st_index];
+    AVCodecContext *codec = stream->codec;
+
+    codec->bit_rate = 32000;
+    if (codec->sample_rate)
+        codec->bits_per_coded_sample =
+            av_clip((codec->bit_rate + codec->sample_rate/2) / codec->sample_rate, 2, 5);
+
+    return 0;
+}
+
+static int g726_40_init(AVFormatContext *s, int st_index, PayloadContext *data)
+{
+    AVStream *stream = s->streams[st_index];
+    AVCodecContext *codec = stream->codec;
+
+    codec->bit_rate = 40000;
+    if (codec->sample_rate)
+        codec->bits_per_coded_sample =
+            av_clip((codec->bit_rate + codec->sample_rate/2) / codec->sample_rate, 2, 5);
+
+    return 0;
+}
+
+RTPDynamicProtocolHandler ff_g726_16_dynamic_handler = {
+    .enc_name   = "G726-16",
+    .codec_type = AVMEDIA_TYPE_AUDIO,
+    .codec_id   = CODEC_ID_ADPCM_G726,
+    .init       = g726_16_init,
+};
+
+RTPDynamicProtocolHandler ff_g726_24_dynamic_handler = {
+    .enc_name   = "G726-24",
+    .codec_type = AVMEDIA_TYPE_AUDIO,
+    .codec_id   = CODEC_ID_ADPCM_G726,
+    .init       = g726_24_init,
+};
+
+RTPDynamicProtocolHandler ff_g726_32_dynamic_handler = {
+    .enc_name   = "G726-32",
+    .codec_type = AVMEDIA_TYPE_AUDIO,
+    .codec_id   = CODEC_ID_ADPCM_G726,
+    .init       = g726_32_init,
+};
+
+RTPDynamicProtocolHandler ff_g726_40_dynamic_handler = {
+    .enc_name   = "G726-40",
+    .codec_type = AVMEDIA_TYPE_AUDIO,
+    .codec_id   = CODEC_ID_ADPCM_G726,
+    .init       = g726_40_init,
+};