aboutsummaryrefslogtreecommitdiffstats
path: root/src/pcm (follow)
Commit message (Collapse)AuthorAgeFilesLines
* pcm/Neon: explicit roundingMax Kellermann2014-03-191-3/+5
| | | | Convert to 31 bit first, then right-shift with rounding to 16 bit.
* pcm/Neon: make neon_x4_b() variadicMax Kellermann2014-03-161-6/+5
|
* pcm/Neon: apply bit shift during float->int conversionMax Kellermann2014-03-161-7/+2
| | | | Avoid multiplication. This is a speedup of 20%.
* pcm/PcmFormat: ARM NEON optimizations for float->s16Max Kellermann2014-03-152-1/+135
| | | | This is nearly 4 times faster than the "portable" algorithm.
* pcm/PcmFormat: don't use WritableBufferMax Kellermann2014-03-141-28/+20
| | | | The previous commit eliminated the need for that.
* pcm/PcmFormat: instantiate FloatToInteger<S32>Max Kellermann2014-03-141-6/+1
| | | | | .. instead of reusing FloatToInteger<S24> and converting from S24 to S32 in-place.
* pcm/PcmFormat: eliminate more duplicate code with templatesMax Kellermann2014-03-143-122/+233
| | | | | Refactor the conversion functions to classes and pass an instance to the new function AllocateConvert().
* pcm/PcmFormat: eliminate local variable "bits"Max Kellermann2014-03-141-3/+1
|
* pcm/PcmFormat: remove obsolete AllocateFromFloat() overloadMax Kellermann2014-03-141-15/+0
|
* util/{Const,Writable}Buffer: add operator[]Max Kellermann2014-03-011-3/+3
|
* pcm/FallbackResampler: add missing ConstBuffer<T>::ToVoid() callMax Kellermann2014-02-061-1/+1
|
* Config*: move to config/Max Kellermann2014-01-241-3/+3
|
* pcm/SoxrResampler: Add configurable quality levelsChase Geigle2014-01-213-3/+73
|
* pcm/Volume: make DSD a no-opMax Kellermann2014-01-171-2/+8
| | | | | Kludge to work around DSD playback failure because the ReplayGainFilterPlugin is always in the filter chain.
* copyright year 2014Max Kellermann2014-01-1342-42/+42
|
* pcm/Utils: remove unused function pcm_end_pointer()Max Kellermann2014-01-071-12/+0
|
* pcm/Volume: use number of samples instead of end pointerMax Kellermann2014-01-071-25/+19
|
* pcm/Format: change parameters/return values to ConstBufferMax Kellermann2014-01-063-259/+160
|
* pcm/Format: use number of samples instead of end pointerMax Kellermann2014-01-061-44/+34
|
* pcm/Volume: remove unused function pcm_volume_dither()Max Kellermann2013-12-281-16/+0
|
* pcm/PcmMix: improved ditheringMax Kellermann2013-12-282-18/+31
| | | | Use the existing PcmDither library.
* pcm/Volume: improved ditheringMax Kellermann2013-12-284-20/+54
| | | | | Instead of just adding a rectangular random value before shifting back to the normal scale, use the existing PcmDither library.
* pcm/PcmDither: inline Dither24To16() and Dither32To16()Max Kellermann2013-12-282-3/+4
|
* pcm/Volume: remove optimized i386 assemblyMax Kellermann2013-12-281-50/+0
| | | | | This code is unable to dither. Until we implement that, let's remove the code for now. i386 isn't relevant anymore anyway.
* pcm/Traits: use 32 bit integer for S8 long_typeMax Kellermann2013-12-251-1/+1
| | | | 16 bit is not enough for volume calculations.
* pcm/Dither: add API documentationMax Kellermann2013-12-241-0/+18
|
* pcm/Dither: move shift from DitherConvert() to Dither()Max Kellermann2013-12-241-2/+2
| | | | All callers need this shift, so let's move it to the basic method.
* pcm/Dither: rename DitherShift() to DitherConvert()Max Kellermann2013-12-242-11/+11
|
* pcm/Volume: convert to classMax Kellermann2013-12-232-40/+126
| | | | Prepare for adding state.
* pcm/Volume: apply volume into destination bufferMax Kellermann2013-12-231-21/+37
|
* pcm/Volume: convert i386 code to template specializationMax Kellermann2013-12-231-42/+42
|
* pcm/Volume: move code to template pcm_volume_sample()Max Kellermann2013-12-231-7/+16
|
* pcm/PcmVolume: rename to Volume.cxxMax Kellermann2013-12-233-2/+2
|
* pcm/PcmConvert: move the Domain instance to Domain.cxxMax Kellermann2013-12-236-9/+56
| | | | | Rename pcm_convert_domain to pcm_domain. Move it out so we can use it without depending on the whole PcmConvert library.
* pcm/Dither: convert remaining methods to templatesMax Kellermann2013-12-222-26/+39
| | | | | Use the SampleTraits template and let the compiler generate a special case for S32 instead of reusing S24_P32.
* pcm/Dither: generic sample dithering using templateMax Kellermann2013-12-222-13/+25
|
* pcm/Traits: include stddef.h for size_tMax Kellermann2013-12-221-0/+1
|
* pcm/Traits: add MIN and MAXMax Kellermann2013-12-222-9/+28
| | | | Move from PcmClamp().
* pcm/Volume: add constant PCM_VOLUME_BITSMax Kellermann2013-12-222-1/+6
|
* pcm/Volume: make PCM_VOLUME_1 a "constexpr"Max Kellermann2013-12-223-13/+13
|
* pcm/Prng: make pcm_prng() inlineMax Kellermann2013-12-221-1/+1
|
* util/Clamp: generic Clamp() functionMax Kellermann2013-12-221-1/+2
|
* pcm/Traits: add typedef "sum_type"Max Kellermann2013-12-023-5/+16
| | | | | Allow 32 bit platforms to use 32 bit instead of 64 bit for summing 24 bit samples.
* pcm/Traits: use int_leastX_t typesMax Kellermann2013-12-021-4/+4
|
* pcm/PcmChannels: implement fake N-to-M mappingMax Kellermann2013-12-021-1/+27
| | | | | This is really just a mono mapper, but the important part is that this library cannot fail anymore.
* pcm/PcmChannels: use the SampleTraits libraryMax Kellermann2013-12-021-182/+60
|
* pcm/Traits: add template specialization for FLOATMax Kellermann2013-12-021-0/+11
|
* pcm/PcmChannels: use struct ConstBufferMax Kellermann2013-12-023-112/+74
|
* pcm/PcmBuffer: add typed method GetT()Max Kellermann2013-12-021-0/+6
|
* pcm/PcmUtils: use the SampleTraits libraryMax Kellermann2013-12-024-17/+14
|