Changeset 24c207f for src


Ignore:
Timestamp:
Mar 23, 2017, 3:46:07 PM (8 years ago)
Author:
Paul Brossier <piem@piem.org>
Branches:
feature/autosink, feature/cnn, feature/cnn_org, feature/constantq, feature/crepe, feature/crepe_org, feature/pitchshift, feature/pydocstrings, feature/timestretch, fix/ffmpeg5, master, sampler
Children:
ecf7572
Parents:
59be50d (diff), 91fa88d (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'master' into gitshaversion

Location:
src
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • src/io/source_avcodec.c

    r59be50d r24c207f  
    2525#include <libavcodec/avcodec.h>
    2626#include <libavformat/avformat.h>
     27#if defined(HAVE_SWRESAMPLE)
     28#include <libswresample/swresample.h>
     29#elif defined(HAVE_AVRESAMPLE)
    2730#include <libavresample/avresample.h>
     31#endif
    2832#include <libavutil/opt.h>
    2933#include <stdlib.h>
     
    6973  AVFrame *avFrame;
    7074  AVPacket avPacket;
     75#ifdef HAVE_AVRESAMPLE
    7176  AVAudioResampleContext *avr;
     77#elif defined(HAVE_SWRESAMPLE)
     78  SwrContext *avr;
     79#endif
    7280  smpl_t *output;
    7381  uint_t read_samples;
     
    277285    uint_t output_channels = multi ? s->input_channels : 1;
    278286    int64_t output_layout = av_get_default_channel_layout(output_channels);
     287#ifdef HAVE_AVRESAMPLE
    279288    AVAudioResampleContext *avr = avresample_alloc_context();
    280289    AVAudioResampleContext *oldavr = s->avr;
     290#elif defined(HAVE_SWRESAMPLE)
     291    SwrContext *avr = swr_alloc();
     292    SwrContext *oldavr = s->avr;
     293#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    281294
    282295    av_opt_set_int(avr, "in_channel_layout",  input_layout,           0);
     
    293306    //av_opt_set_int(avr, "out_sample_fmt",     AV_SAMPLE_FMT_FLTP,      0);
    294307    int err;
     308#ifdef HAVE_AVRESAMPLE
    295309    if ( ( err = avresample_open(avr) ) < 0) {
     310#elif defined(HAVE_SWRESAMPLE)
     311    if ( ( err = swr_init(avr) ) < 0) {
     312#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    296313      char errorstr[256];
    297314      av_strerror (err, errorstr, sizeof(errorstr));
     
    303320    s->avr = avr;
    304321    if (oldavr != NULL) {
     322#ifdef HAVE_AVRESAMPLE
    305323      avresample_close( oldavr );
     324#elif defined(HAVE_SWRESAMPLE)
     325      swr_close ( oldavr );
     326#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    306327      av_free ( oldavr );
    307328      oldavr = NULL;
     
    317338  AVPacket avPacket = s->avPacket;
    318339  av_init_packet (&avPacket);
     340#ifdef HAVE_AVRESAMPLE
    319341  AVAudioResampleContext *avr = s->avr;
     342#elif defined(HAVE_SWRESAMPLE)
     343  SwrContext *avr = s->avr;
     344#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    320345  smpl_t *output = s->output;
    321346  *read_samples = 0;
     
    332357      av_strerror (err, errorstr, sizeof(errorstr));
    333358      AUBIO_ERR("source_avcodec: could not read frame in %s (%s)\n", s->path, errorstr);
     359      s->eof = 1;
    334360      goto beach;
    335361    }
     
    370396  }
    371397
     398#ifdef HAVE_AVRESAMPLE
    372399  int in_linesize = 0;
    373400  av_samples_get_buffer_size(&in_linesize, avCodecCtx->channels,
     
    379406        (uint8_t **)&output, out_linesize, max_out_samples,
    380407        (uint8_t **)avFrame->data, in_linesize, in_samples);
     408#elif defined(HAVE_SWRESAMPLE)
     409  int in_samples = avFrame->nb_samples;
     410  int max_out_samples = AUBIO_AVCODEC_MAX_BUFFER_SIZE / avCodecCtx->channels;
     411  int out_samples = swr_convert( avr,
     412      (uint8_t **)&output, max_out_samples,
     413      (const uint8_t **)avFrame->data, in_samples);
     414#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    381415  if (out_samples <= 0) {
    382416    AUBIO_WRN("source_avcodec: no sample found while converting frame (%s)\n", s->path);
     
    390424  s->avCodecCtx = avCodecCtx;
    391425  s->avFrame = avFrame;
     426#if defined(HAVE_AVRESAMPLE) || defined(HAVE_SWRESAMPLE)
    392427  s->avr = avr;
     428#endif /* HAVE_AVRESAMPLE || HAVE_SWRESAMPLE */
    393429  s->output = output;
    394430
     
    499535  s->read_index = 0;
    500536  s->read_samples = 0;
     537#ifdef HAVE_AVRESAMPLE
    501538  // reset the AVAudioResampleContext
    502539  avresample_close(s->avr);
    503540  avresample_open(s->avr);
     541#elif defined(HAVE_SWRESAMPLE)
     542  swr_close(s->avr);
     543  swr_init(s->avr);
     544#endif
    504545  return ret;
    505546}
     
    515556uint_t aubio_source_avcodec_close(aubio_source_avcodec_t * s) {
    516557  if (s->avr != NULL) {
     558#ifdef HAVE_AVRESAMPLE
    517559    avresample_close( s->avr );
     560#elif defined(HAVE_SWRESAMPLE)
     561    swr_close ( s->avr );
     562#endif
    518563    av_free ( s->avr );
    519564  }
    520565  s->avr = NULL;
    521566  if (s->avCodecCtx != NULL) {
     567#ifndef HAVE_AUBIO_LIBAVCODEC_DEPRECATED
     568    avcodec_free_context( &s->avCodecCtx );
     569#else
    522570    avcodec_close ( s->avCodecCtx );
     571#endif
    523572  }
    524573  s->avCodecCtx = NULL;
  • src/utils/windll.c

    r59be50d r24c207f  
    4242#include "aubio.h"
    4343
    44 BOOL APIENTRY DllMain( HMODULE hModule,
     44BOOL APIENTRY DllMain( HMODULE hModule UNUSED,
    4545                       DWORD  ul_reason_for_call,
    46                        LPVOID lpReserved )
     46                       LPVOID lpReserved UNUSED)
    4747{
    4848  switch (ul_reason_for_call)
  • src/wscript_build

    r59be50d r24c207f  
    88uselib += ['AVCODEC']
    99uselib += ['AVFORMAT']
     10uselib += ['SWRESAMPLE']
    1011uselib += ['AVRESAMPLE']
    1112uselib += ['AVUTIL']
Note: See TracChangeset for help on using the changeset viewer.