diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c
index f9f4fbe40bfcb11178ed4bea4e8090f11efbfeaa..ba024aec388fa9878e34db305560024c58aeb0c2 100644
--- a/libavformat/flvdec.c
+++ b/libavformat/flvdec.c
@@ -132,6 +132,7 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
     		av_log(s, AV_LOG_INFO, "Unsupported audio codec (%x)\n", flags >> 4);
                 st->codec.codec_tag= (flags >> 4);
             }
+	    st->codec.bits_per_sample = (flags & 2) ? 16 : 8;
         }
     }else{
             st->codec.codec_type = CODEC_TYPE_VIDEO;
diff --git a/libavformat/flvenc.c b/libavformat/flvenc.c
index 500d4220d7c8313506d560dd09c1ce2acb3969f5..a9a8730ee7344a582543609dcecda50f75b6b148 100644
--- a/libavformat/flvenc.c
+++ b/libavformat/flvenc.c
@@ -35,7 +35,7 @@ static void put_be24(ByteIOContext *pb, int value)
 }
 
 static int get_audio_flags(AVCodecContext *enc){
-    int flags = 0;
+    int flags = (enc->bits_per_sample == 16) ? 0x2 : 0x0;
 
     switch (enc->sample_rate) {
         case    44100: