Recherche avancée

Médias (39)

Mot : - Tags -/audio

Autres articles (13)

  • Librairies et logiciels spécifiques aux médias

    10 décembre 2010, par

    Pour un fonctionnement correct et optimal, plusieurs choses sont à prendre en considération.
    Il est important, après avoir installé apache2, mysql et php5, d’installer d’autres logiciels nécessaires dont les installations sont décrites dans les liens afférants. Un ensemble de librairies multimedias (x264, libtheora, libvpx) utilisées pour l’encodage et le décodage des vidéos et sons afin de supporter le plus grand nombre de fichiers possibles. Cf. : ce tutoriel ; FFMpeg avec le maximum de décodeurs et (...)

  • L’espace de configuration de MediaSPIP

    29 novembre 2010, par

    L’espace de configuration de MediaSPIP est réservé aux administrateurs. Un lien de menu "administrer" est généralement affiché en haut de la page [1].
    Il permet de configurer finement votre site.
    La navigation de cet espace de configuration est divisé en trois parties : la configuration générale du site qui permet notamment de modifier : les informations principales concernant le site (...)

  • Other interesting software

    13 avril 2011, par

    We don’t claim to be the only ones doing what we do ... and especially not to assert claims to be the best either ... What we do, we just try to do it well and getting better ...
    The following list represents softwares that tend to be more or less as MediaSPIP or that MediaSPIP tries more or less to do the same, whatever ...
    We don’t know them, we didn’t try them, but you can take a peek.
    Videopress
    Website : http://videopress.com/
    License : GNU/GPL v2
    Source code : (...)

Sur d’autres sites (2404)

  • rtpdec : Don’t free the payload context in the .free function

    24 février 2015, par Martin Storsjö
    rtpdec : Don’t free the payload context in the .free function
    

    This makes it more consistent with depacketizers that don’t have any
    .free function at all, where the payload context is freed by the
    surrounding framework. Always free the context in the surrounding
    framework, having the individual depacketizers only free any data
    they’ve specifically allocated themselves.

    This is similar to how this works for demuxer/muxers/codecs - a
    component shouldn’t free the priv_data that the framework has
    allocated for it.

    Signed-off-by : Martin Storsjö <martin@martin.st>

    • [DH] libavformat/rdt.c
    • [DH] libavformat/rtpdec.h
    • [DH] libavformat/rtpdec_ac3.c
    • [DH] libavformat/rtpdec_dv.c
    • [DH] libavformat/rtpdec_h261.c
    • [DH] libavformat/rtpdec_h263_rfc2190.c
    • [DH] libavformat/rtpdec_h264.c
    • [DH] libavformat/rtpdec_jpeg.c
    • [DH] libavformat/rtpdec_latm.c
    • [DH] libavformat/rtpdec_mpa_robust.c
    • [DH] libavformat/rtpdec_mpeg4.c
    • [DH] libavformat/rtpdec_mpegts.c
    • [DH] libavformat/rtpdec_qt.c
    • [DH] libavformat/rtpdec_svq3.c
    • [DH] libavformat/rtpdec_vp8.c
    • [DH] libavformat/rtpdec_xiph.c
    • [DH] libavformat/rtsp.c
  • rtpdec : Don’t free the payload context in the .free function

    24 février 2015, par Martin Storsjö
    rtpdec : Don’t free the payload context in the .free function
    

    This makes it more consistent with depacketizers that don’t have any
    .free function at all, where the payload context is freed by the
    surrounding framework. Always free the context in the surrounding
    framework, having the individual depacketizers only free any data
    they’ve specifically allocated themselves.

    This is similar to how this works for demuxer/muxers/codecs - a
    component shouldn’t free the priv_data that the framework has
    allocated for it.

    Signed-off-by : Martin Storsjö <martin@martin.st>

    • [DBH] libavformat/rdt.c
    • [DBH] libavformat/rtpdec.h
    • [DBH] libavformat/rtpdec_ac3.c
    • [DBH] libavformat/rtpdec_dv.c
    • [DBH] libavformat/rtpdec_h261.c
    • [DBH] libavformat/rtpdec_h263_rfc2190.c
    • [DBH] libavformat/rtpdec_h264.c
    • [DBH] libavformat/rtpdec_jpeg.c
    • [DBH] libavformat/rtpdec_latm.c
    • [DBH] libavformat/rtpdec_mpa_robust.c
    • [DBH] libavformat/rtpdec_mpeg4.c
    • [DBH] libavformat/rtpdec_mpegts.c
    • [DBH] libavformat/rtpdec_qt.c
    • [DBH] libavformat/rtpdec_svq3.c
    • [DBH] libavformat/rtpdec_vp8.c
    • [DBH] libavformat/rtpdec_xiph.c
    • [DBH] libavformat/rtsp.c
  • How do you properly free a BitStreamFilter (bsf) without getting a double free error ?

    19 janvier 2021, par Alexis Wilke

    I'm trying to write a C++ class handling MP4 movies via ffmpeg.

    &#xA;

    First I created a couple of functions to use with std::unique&lt;>() so that way things get released even on exceptions.

    &#xA;

    However, I get a double free when I try to free the BitStreamFilter object, yet the documentation clearly says that each av_bsf_alloc() must be paired with an av_bsf_free() call.

    &#xA;

    &#xA;

    @param ctx a pointer into which the pointer to the newly-allocated context&#xA;will be written. It must be freed with av_bsf_free() after the&#xA;filtering is done.

    &#xA;

    &#xA;

    Note : emphasis mine.

    &#xA;

    However, at the time I call the avformat_close_input() I get a double free error, even if I haven't used the two contexts for anything !? I'm thinking that there may be a packet that both allocate and both try to free. But since these two contexts are not directly connected, I really don't understand how they end up freeing something twice.

    &#xA;

    Below is code which reproduce the error (at least on an amd64 platform). Once compiled, you can just execute it. Make sure to specify a filename as in :

    &#xA;

    ./ffmpeg_demuxer_test mymovie.mp4&#xA;

    &#xA;

    I used the following command to compile & link the code :

    &#xA;

    $ /usr/bin/c&#x2B;&#x2B; -std=c&#x2B;&#x2B;17 -DDEBUG -D_DEBUG -D_GLIBCXX_ASSERTIONS -g -O0 \&#xA;    -fsanitize=address -fsanitize=enum -fsanitize=unreachable \&#xA;    -o ffmpeg_demuxer_test ffmpeg_demuxer_test.cpp \&#xA;    -lavformat -lavcodec&#xA;

    &#xA;

    Notice the -fsanitize=... options to capture errors such as a double free error.

    &#xA;

    Here is the code :

    &#xA;

    extern "C" {&#xA;#include    <libavformat></libavformat>avformat.h>&#xA;#include    <libavformat></libavformat>avio.h>&#xA;#include    <libavcodec></libavcodec>avcodec.h>&#xA;}&#xA;#include    <iostream>&#xA;#include    <memory>&#xA;&#xA;&#xA;void ffmpeg_demuxer_avformat_context_free(AVFormatContext * context)&#xA;{&#xA;    if(context != nullptr) avformat_close_input(&amp;context);&#xA;}&#xA;&#xA;void ffmpeg_demuxer_av_bsf_free(AVBSFContext * context)&#xA;{&#xA;    if(context != nullptr) av_bsf_free(&amp;context);&#xA;}&#xA;&#xA;&#xA;int main(int argc, char * argv [])&#xA;{&#xA;    if(argc != 2)&#xA;    {&#xA;        std::cout &lt;&lt; "Usage: " &lt;&lt; argv[0] &lt;&lt; " movie.mp4" &lt;&lt; std::endl;&#xA;        exit(1);&#xA;    }&#xA;&#xA;    // init the AV libraries&#xA;    //&#xA;    av_register_all();&#xA;    avformat_network_init();&#xA;&#xA;    // allocate the AVFormatContext&#xA;    //&#xA;    AVFormatContext * format_context(nullptr);&#xA;    int const r1(avformat_open_input(&#xA;                  &amp;format_context&#xA;                , argv[1]&#xA;                , nullptr           // input format&#xA;                , nullptr));        // options&#xA;    if(r1 != 0&#xA;    || format_context == nullptr)&#xA;    {&#xA;        throw std::bad_alloc();&#xA;    }&#xA;&#xA;    auto f_format_context = std::unique_ptr&lt;&#xA;              AVFormatContext&#xA;            , decltype(&amp;ffmpeg_demuxer_avformat_context_free)>(&#xA;                      format_context&#xA;                    , &amp;ffmpeg_demuxer_avformat_context_free);&#xA;&#xA;&#xA;    // now allocate a stream&#xA;    //&#xA;    if(avformat_find_stream_info(f_format_context.get(), nullptr) &lt; 0)&#xA;    {&#xA;        throw std::runtime_error("ffmpeg: Could not find stream info");&#xA;    }&#xA;&#xA;    auto f_video_stream_index = av_find_best_stream(&#xA;              f_format_context.get()&#xA;            , AVMEDIA_TYPE_VIDEO&#xA;            , -1            // wanted stream (any)&#xA;            , -1            // related stream (none)&#xA;            , nullptr       // AVCodec *&#xA;            , 0);           // flags&#xA;    if(f_video_stream_index &lt; 0)&#xA;    {&#xA;        throw std::runtime_error("ffmpeg: Could not find stream in input file");&#xA;    }&#xA;    if(static_cast<unsigned int="int">(f_video_stream_index) >= f_format_context->nb_streams)&#xA;    {&#xA;        throw std::range_error("ffmpeg: Stream index out of range");&#xA;    }&#xA;&#xA;    auto f_stream = f_format_context->streams[f_video_stream_index];&#xA;&#xA;    auto f_video_codec = f_stream->codecpar->codec_id;&#xA;&#xA;    int f_bit_depth(0);&#xA;    switch(f_stream->codecpar->format)&#xA;    {&#xA;    case AV_PIX_FMT_YUV420P10LE:&#xA;        f_bit_depth = 10;&#xA;        break;&#xA;&#xA;    case AV_PIX_FMT_YUV420P12LE:&#xA;        f_bit_depth = 12;&#xA;        break;&#xA;&#xA;    default:&#xA;        f_bit_depth = 8;&#xA;        break;&#xA;&#xA;    }&#xA;&#xA;    bool f_mp4_h264 = f_video_codec == AV_CODEC_ID_H264 &amp;&amp; (&#xA;               strcmp(f_format_context->iformat->long_name, "QuickTime / MOV") == 0&#xA;            || strcmp(f_format_context->iformat->long_name, "FLV (Flash Video)") == 0&#xA;            || strcmp(f_format_context->iformat->long_name, "Matroska / WebM") == 0&#xA;        );&#xA;&#xA;    if(f_mp4_h264)&#xA;    {&#xA;        AVBitStreamFilter const * bsf_stream_filter(av_bsf_get_by_name("h264_mp4toannexb"));&#xA;        if(bsf_stream_filter == nullptr)&#xA;        {&#xA;            throw std::runtime_error("av_bsf_get_by_name(\"h264_mp4toannexb\") failed");&#xA;        }&#xA;        AVBSFContext * bsf_context(nullptr);&#xA;        int const r2(av_bsf_alloc(bsf_stream_filter, &amp;bsf_context));&#xA;        if(r2 &lt; 0&#xA;        || bsf_context == nullptr)&#xA;        {&#xA;            throw std::bad_alloc();&#xA;        }&#xA;        auto f_bsf_context = std::unique_ptr&lt;&#xA;                  AVBSFContext&#xA;                , decltype(&amp;ffmpeg_demuxer_av_bsf_free)>(&#xA;                          bsf_context&#xA;                        , &amp;ffmpeg_demuxer_av_bsf_free);&#xA;        f_bsf_context->par_in = f_stream->codecpar;&#xA;        if(av_bsf_init(f_bsf_context.get()) &lt; 0)&#xA;        {&#xA;            throw std::runtime_error("av_bsf_init() failed");&#xA;        }&#xA;    }&#xA;&#xA;    return 0;&#xA;}&#xA;</unsigned></memory></iostream>

    &#xA;

    So. Am I misreading the documentation or misusing one of the free/close function ? I don't think that the AVBSFContext itself gets released when I close the AVFormatContext, but I may be mistaken ?

    &#xA;

    I won't put "C" as a tag since it will get removed even though this applies to C. It's not because I use C++ that I get a double free (i.e. it happens in the ffmpeg C library).

    &#xA;