aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* pcm_resample: add function pcm_resample_float()Max Kellermann2011-10-204-0/+95
| | | | | A version of the resampler that doesn't need int->float->int conversion.
* pcm_format: move "case" code to separate functionsMax Kellermann2011-10-201-95/+166
| | | | Reduce the mess with local variables inside switch{}.
* pcm_*: add "restrict" keywordsMax Kellermann2011-10-202-18/+29
| | | | Allow more compiler optimizations.
* crossfade: include cleanupMax Kellermann2011-10-201-1/+0
|
* pcm_format: pass an "end" pointer instead of a sample countMax Kellermann2011-10-191-58/+28
|
* pcm_channels: pass an "end" pointer instead of a sample countMax Kellermann2011-10-191-39/+40
|
* pcm_{channels,resample}: pass channel count as integer, not uint8_tMax Kellermann2011-10-197-27/+27
| | | | Reduces number of implicit integer conversions.
* pcm_{channels,format}: add alignment assertionsMax Kellermann2011-10-192-0/+12
|
* pcm_utils: add function pcm_end_pointer()Max Kellermann2011-10-192-1/+13
|
* pcm_byteswap: use "end" pointer instead of buffer sizeMax Kellermann2011-10-101-6/+12
|
* pcm_dither: pass an "end" pointer instead of a sample countMax Kellermann2011-10-103-19/+14
| | | | | This is easier and more efficient to loop on, because only two variables get modified (src and dest).
* pcm_pack: pass an "end" pointer instead of a sample countMax Kellermann2011-10-104-10/+11
|
* pcm_byteswap: use GLib byte swapping macrosMax Kellermann2011-10-101-15/+2
| | | | | GLib's macros are implemented with inline assembly, and probably a lot faster than our naive bit shifting implementation.
* pcm_{mix,volume}: pass only sample_format to pcm_mix()Max Kellermann2011-10-107-18/+19
| | | | The other audio_format attributes are not used.
* pcm_buffer: un-inline pcm_buffer_get()Max Kellermann2011-10-102-14/+38
| | | | This function is too complex for being inlined everywhere.
* input/cdio_paranoia: pass byte order swapping to the PCM "decoder"Max Kellermann2011-10-101-32/+11
| | | | | | Send another "magic" MIME type when the byte order must be reversed. This also fixes byte order issues when big-endian was involved (input data or host byte order) - that was completely broken.
* decoder/pcm: support reverse byte orderMax Kellermann2011-10-101-3/+21
|
* decoder_api: convert data to host byte orderMax Kellermann2011-10-101-0/+3
|
* pcm_convert: support reverse endian inputMax Kellermann2011-10-101-0/+14
|
* pcm_byteswap: add function with sample_format overloadMax Kellermann2011-10-102-0/+43
|
* audio_format: convert reverse_endian to a "bool"Max Kellermann2011-10-102-4/+4
|
* audio_format: un-inline audio_format_mask_apply()Max Kellermann2011-10-102-17/+21
| | | | | This function is not critical for performance, and the inline expansion looks too expensive.
* audio_format: add function attributesMax Kellermann2011-10-102-0/+10
| | | | For better optimization.
* audio: rename audio.[ch] to audio_config.[ch]Max Kellermann2011-10-104-5/+5
|
* Makefile.am: generate static library from pluginsMax Kellermann2011-10-091-0/+30
| | | | Compile the plugins only once with the same C flags.
* don't define WINVER in *.c filesMax Kellermann2011-10-0910-10/+0
| | | | | In a C file, that is too late, because _mingw.h defaults to 0x0502, and ours would be illegal redefintion.
* decoder/{pcm,dsdiff}: add missing stdio.h includeMax Kellermann2011-10-093-0/+3
|
* Merge commit 'release-0.16.5'Max Kellermann2011-10-092-2/+2
|\ | | | | | | | | | | Conflicts: NEWS configure.ac
| * decoder/wavpack: don't call WavpackGetMode() twiceMax Kellermann2011-10-081-1/+1
| | | | | | | | Use local variable "is_float".
| * pcm_convert: fix typo in error messageMax Kellermann2011-10-081-1/+1
| |
* | audio_format: move code to sample_format_size()Max Kellermann2011-10-081-6/+13
| | | | | | | | | | Cast to enum sample_format. Without the cast, it's just a plain integer, and gcc cannot know that a "case" statement is missing.
* | pcm_resample_lsr: move common code to lsr_process()Max Kellermann2011-10-081-32/+17
| |
* | output/roar: move code to _use_audio_format()Max Kellermann2011-10-081-27/+38
| |
* | db_print: print absolute URI of playlist entriesMax Kellermann2011-10-083-5/+21
| | | | | | | | | | | | | | The protocol mandates that playlist URIs are absolute (i.e. full URI relative to the music directory, not relative to the parent directory). This adds the parameter "directory" to the "playlist" visitor method.
* | Merge branch 'v0.16.x'Max Kellermann2011-10-082-12/+15
|\|
| * output/openal: auto-fallback to mono if channel count is unsupportedMax Kellermann2011-10-081-9/+9
| | | | | | | | .. instead of failing playback completely.
| * output/alsa: remove "default" case from switchMax Kellermann2011-10-081-3/+6
| | | | | | | | Allow gcc to warn when a new format isn't supported.
* | pcm_resample: add internal function _lsr_init()Max Kellermann2011-10-084-8/+26
| | | | | | | | Let the libsamplerate code initialize itself.
* | pcm_resample: one-time global initializationMax Kellermann2011-10-085-42/+84
| | | | | | | | | | Load the samplerate_converter on MPD startup. Fail if the converter name is invalid.
* | decoder/dsdiff: add option "lsbitfirst"Max Kellermann2011-10-071-1/+11
| | | | | | | | Defaults to "no", which fixes the noise problems.
* | decoder/dsdiff: add documentationMax Kellermann2011-10-071-0/+7
| |
* | playlist_song: allow references to songs outside the musicdirMax Kellermann2011-10-061-0/+6
| | | | | | | | | | | | When we have an absolute path that's not inside the music directory, allow loading it anyway, if we're in "secure" mode (i.e. the client is connected via UNIX socket).
* | Merge branch 'v0.16.x'Max Kellermann2011-10-068-54/+140
|\| | | | | | | | | | | | | | | Conflicts: configure.ac src/player_control.c src/player_thread.c src/playlist_song.c
| * playlist_song: fix absolute path support in playlistsJesús Bravo Álvarez2011-10-061-3/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | Right now, a playlist with absolute pathnames can only add songs that are in the same the directory of the playlist or under it. If uri is an absolute pathname and base_uri is set, playlist_check_translate_song() will check that base_uri is a prefix of uri, excluding every other song in the music directory outside base_uri. I think in this case base_uri should be completely ignored (and made NULL) and uri should just be checked against music root directory.
| * player_thread: add flag "output_open", fixes assertion failureMax Kellermann2011-10-061-5/+17
| | | | | | | | | | | | | | Previously, the condition "defined(play_audio_format)" was used to see if an output device has been opened, but if the device had failed on startup, an assertion failure could occur. This patch adds a separate flag.
| * player_thread: move code to player_open_output()Max Kellermann2011-10-061-22/+37
| | | | | | | | | | Common function that manages "player" attributes after audio_output_all_open() has returned.
| * output_control: remove unused prototype _close_locked()Max Kellermann2011-10-061-3/+0
| |
| * player_control: auto-start playback when seeking is requestedMax Kellermann2011-10-061-3/+0
| | | | | | | | | | Now that the player thread can handle SEEK commands while not (yet) playing, we can remove the "pc.state" check from pc_seek().
| * player_thread: handle SEEK while not playingMax Kellermann2011-10-061-2/+10
| |
| * decoder_api: call _prepare_initial_seek() in decoder_tag()Max Kellermann2011-10-061-1/+1
| | | | | | | | | | This checks both conditions: pending and running. Fixes yet another assertion failure!