#pragma once /* * Copyright (C) 2005-2013 Team XBMC * http://xbmc.org * * This Program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This Program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with XBMC; see the file COPYING. If not, see * . * */ #if (defined HAVE_CONFIG_H) && (!defined WIN32) #include "config.h" #endif #include "DynamicDll.h" #include "utils/log.h" extern "C" { #ifndef HAVE_MMX #define HAVE_MMX #endif #ifndef __STDC_CONSTANT_MACROS #define __STDC_CONSTANT_MACROS #endif #ifndef __GNUC__ #pragma warning(disable:4244) #endif #if (defined USE_EXTERNAL_FFMPEG) #if (defined USE_LIBAV_HACKS) #include "xbmc-libav-hacks/libav_hacks.h" #else #include #endif #else #include "libswresample/swresample.h" #endif } class DllSwResampleInterface { public: virtual ~DllSwResampleInterface() {} virtual struct SwrContext *swr_alloc_set_opts(struct SwrContext *s, int64_t out_ch_layout, enum AVSampleFormat out_sample_fmt, int out_sample_rate, int64_t in_ch_layout, enum AVSampleFormat in_sample_fmt, int in_sample_rate, int log_offset, void *log_ctx)=0; virtual int swr_init(struct SwrContext *s)=0; virtual void swr_free(struct SwrContext **s)=0; virtual int swr_convert(struct SwrContext *s, uint8_t **out, int out_count, const uint8_t **in , int in_count)=0; virtual int64_t swr_get_delay(struct SwrContext *s, int64_t base) = 0; virtual int swr_set_channel_mapping(struct SwrContext *s, const int *channel_map) = 0; virtual int swr_set_matrix(struct SwrContext *s, const double *matrix, int stride) = 0; virtual int swr_set_compensation(struct SwrContext *s, int sample_delta, int compensation_distance) = 0; }; #if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) // Use direct mapping class DllSwResample : public DllDynamic, DllSwResampleInterface { public: virtual ~DllSwResample() {} // DLL faking. virtual bool ResolveExports() { return true; } virtual bool Load() { #if !defined(TARGET_DARWIN) CLog::Log(LOGDEBUG, "DllAvFormat: Using libswresample system library"); #endif return true; } virtual void Unload() {} virtual struct SwrContext *swr_alloc_set_opts(struct SwrContext *s, int64_t out_ch_layout, enum AVSampleFormat out_sample_fmt, int out_sample_rate, int64_t in_ch_layout, enum AVSampleFormat in_sample_fmt, int in_sample_rate, int log_offset, void *log_ctx) { return ::swr_alloc_set_opts(s, out_ch_layout, out_sample_fmt, out_sample_rate, in_ch_layout, in_sample_fmt, in_sample_rate, log_offset, log_ctx); } virtual int swr_init(struct SwrContext *s) { return ::swr_init(s); } virtual void swr_free(struct SwrContext **s){ return ::swr_free(s); } virtual int swr_convert(struct SwrContext *s, uint8_t **out, int out_count, const uint8_t **in , int in_count){ return ::swr_convert(s, out, out_count, in, in_count); } virtual int64_t swr_get_delay(struct SwrContext *s, int64_t base) { return ::swr_get_delay(s, base); } virtual int swr_set_channel_mapping (struct SwrContext *s, const int *channel_map) { return ::swr_set_channel_mapping(s, channel_map); } virtual int swr_set_matrix(struct SwrContext *s, const double *matrix, int stride) { return ::swr_set_matrix(s, matrix, stride); } virtual int swr_set_compensation(struct SwrContext *s, int sample_delta, int compensation_distance) { return ::swr_set_compensation(s, sample_delta, compensation_distance); } }; #else class DllSwResample : public DllDynamic, DllSwResampleInterface { DECLARE_DLL_WRAPPER(DllSwResample, DLL_PATH_LIBSWRESAMPLE) LOAD_SYMBOLS() DEFINE_METHOD9(SwrContext*, swr_alloc_set_opts, (struct SwrContext *p1, int64_t p2, enum AVSampleFormat p3, int p4, int64_t p5, enum AVSampleFormat p6, int p7, int p8, void * p9)); DEFINE_METHOD1(int, swr_init, (struct SwrContext *p1)) DEFINE_METHOD1(void, swr_free, (struct SwrContext **p1)) DEFINE_METHOD5(int, swr_convert, (struct SwrContext *p1, uint8_t **p2, int p3, const uint8_t **p4, int p5)) DEFINE_METHOD2(int64_t, swr_get_delay, (struct SwrContext *p1, int64_t p2)) DEFINE_METHOD2(int, swr_set_channel_mapping, (struct SwrContext *p1, const int *p2)) DEFINE_METHOD3(int, swr_set_matrix, (struct SwrContext *p1, const double *p2, int p3)) DEFINE_METHOD3(int, swr_set_compensation, (struct SwrContext *p1, int p2, int p3)) BEGIN_METHOD_RESOLVE() RESOLVE_METHOD(swr_alloc_set_opts) RESOLVE_METHOD(swr_init) RESOLVE_METHOD(swr_free) RESOLVE_METHOD(swr_convert) RESOLVE_METHOD(swr_get_delay) RESOLVE_METHOD(swr_set_channel_mapping) RESOLVE_METHOD(swr_set_matrix) RESOLVE_METHOD(swr_set_compensation) END_METHOD_RESOLVE() /* dependencies of libavformat */ DllAvUtil m_dllAvUtil; public: virtual bool Load() { if (!m_dllAvUtil.Load()) return false; return DllDynamic::Load(); } }; #endif