Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | pcm_format: pass an "end" pointer instead of a sample count | Max Kellermann | 2011-10-19 | 1 | -58/+28 |
| | |||||
* | pcm_channels: pass an "end" pointer instead of a sample count | Max Kellermann | 2011-10-19 | 1 | -39/+40 |
| | |||||
* | pcm_{channels,resample}: pass channel count as integer, not uint8_t | Max Kellermann | 2011-10-19 | 7 | -27/+27 |
| | | | | Reduces number of implicit integer conversions. | ||||
* | pcm_{channels,format}: add alignment assertions | Max Kellermann | 2011-10-19 | 2 | -0/+12 |
| | |||||
* | pcm_utils: add function pcm_end_pointer() | Max Kellermann | 2011-10-19 | 2 | -1/+13 |
| | |||||
* | pcm_byteswap: use "end" pointer instead of buffer size | Max Kellermann | 2011-10-10 | 1 | -6/+12 |
| | |||||
* | pcm_dither: pass an "end" pointer instead of a sample count | Max Kellermann | 2011-10-10 | 3 | -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 count | Max Kellermann | 2011-10-10 | 4 | -10/+11 |
| | |||||
* | pcm_byteswap: use GLib byte swapping macros | Max Kellermann | 2011-10-10 | 1 | -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 Kellermann | 2011-10-10 | 7 | -18/+19 |
| | | | | The other audio_format attributes are not used. | ||||
* | pcm_buffer: un-inline pcm_buffer_get() | Max Kellermann | 2011-10-10 | 2 | -14/+38 |
| | | | | This function is too complex for being inlined everywhere. | ||||
* | input/cdio_paranoia: pass byte order swapping to the PCM "decoder" | Max Kellermann | 2011-10-10 | 1 | -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 order | Max Kellermann | 2011-10-10 | 1 | -3/+21 |
| | |||||
* | decoder_api: convert data to host byte order | Max Kellermann | 2011-10-10 | 1 | -0/+3 |
| | |||||
* | pcm_convert: support reverse endian input | Max Kellermann | 2011-10-10 | 1 | -0/+14 |
| | |||||
* | pcm_byteswap: add function with sample_format overload | Max Kellermann | 2011-10-10 | 2 | -0/+43 |
| | |||||
* | audio_format: convert reverse_endian to a "bool" | Max Kellermann | 2011-10-10 | 2 | -4/+4 |
| | |||||
* | audio_format: un-inline audio_format_mask_apply() | Max Kellermann | 2011-10-10 | 2 | -17/+21 |
| | | | | | This function is not critical for performance, and the inline expansion looks too expensive. | ||||
* | audio_format: add function attributes | Max Kellermann | 2011-10-10 | 2 | -0/+10 |
| | | | | For better optimization. | ||||
* | audio: rename audio.[ch] to audio_config.[ch] | Max Kellermann | 2011-10-10 | 4 | -5/+5 |
| | |||||
* | Makefile.am: generate static library from plugins | Max Kellermann | 2011-10-09 | 1 | -0/+30 |
| | | | | Compile the plugins only once with the same C flags. | ||||
* | don't define WINVER in *.c files | Max Kellermann | 2011-10-09 | 10 | -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 include | Max Kellermann | 2011-10-09 | 3 | -0/+3 |
| | |||||
* | Merge commit 'release-0.16.5' | Max Kellermann | 2011-10-09 | 2 | -2/+2 |
|\ | | | | | | | | | | | Conflicts: NEWS configure.ac | ||||
| * | decoder/wavpack: don't call WavpackGetMode() twice | Max Kellermann | 2011-10-08 | 1 | -1/+1 |
| | | | | | | | | Use local variable "is_float". | ||||
| * | pcm_convert: fix typo in error message | Max Kellermann | 2011-10-08 | 1 | -1/+1 |
| | | |||||
* | | audio_format: move code to sample_format_size() | Max Kellermann | 2011-10-08 | 1 | -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 Kellermann | 2011-10-08 | 1 | -32/+17 |
| | | |||||
* | | output/roar: move code to _use_audio_format() | Max Kellermann | 2011-10-08 | 1 | -27/+38 |
| | | |||||
* | | db_print: print absolute URI of playlist entries | Max Kellermann | 2011-10-08 | 3 | -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 Kellermann | 2011-10-08 | 2 | -12/+15 |
|\| | |||||
| * | output/openal: auto-fallback to mono if channel count is unsupported | Max Kellermann | 2011-10-08 | 1 | -9/+9 |
| | | | | | | | | .. instead of failing playback completely. | ||||
| * | output/alsa: remove "default" case from switch | Max Kellermann | 2011-10-08 | 1 | -3/+6 |
| | | | | | | | | Allow gcc to warn when a new format isn't supported. | ||||
* | | pcm_resample: add internal function _lsr_init() | Max Kellermann | 2011-10-08 | 4 | -8/+26 |
| | | | | | | | | Let the libsamplerate code initialize itself. | ||||
* | | pcm_resample: one-time global initialization | Max Kellermann | 2011-10-08 | 5 | -42/+84 |
| | | | | | | | | | | Load the samplerate_converter on MPD startup. Fail if the converter name is invalid. | ||||
* | | decoder/dsdiff: add option "lsbitfirst" | Max Kellermann | 2011-10-07 | 1 | -1/+11 |
| | | | | | | | | Defaults to "no", which fixes the noise problems. | ||||
* | | decoder/dsdiff: add documentation | Max Kellermann | 2011-10-07 | 1 | -0/+7 |
| | | |||||
* | | playlist_song: allow references to songs outside the musicdir | Max Kellermann | 2011-10-06 | 1 | -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 Kellermann | 2011-10-06 | 8 | -54/+140 |
|\| | | | | | | | | | | | | | | | Conflicts: configure.ac src/player_control.c src/player_thread.c src/playlist_song.c | ||||
| * | playlist_song: fix absolute path support in playlists | Jesús Bravo Álvarez | 2011-10-06 | 1 | -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 failure | Max Kellermann | 2011-10-06 | 1 | -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 Kellermann | 2011-10-06 | 1 | -22/+37 |
| | | | | | | | | | | Common function that manages "player" attributes after audio_output_all_open() has returned. | ||||
| * | output_control: remove unused prototype _close_locked() | Max Kellermann | 2011-10-06 | 1 | -3/+0 |
| | | |||||
| * | player_control: auto-start playback when seeking is requested | Max Kellermann | 2011-10-06 | 1 | -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 playing | Max Kellermann | 2011-10-06 | 1 | -2/+10 |
| | | |||||
| * | decoder_api: call _prepare_initial_seek() in decoder_tag() | Max Kellermann | 2011-10-06 | 1 | -1/+1 |
| | | | | | | | | | | This checks both conditions: pending and running. Fixes yet another assertion failure! | ||||
| * | decoder_api: move code to _prepare_initial_seek() | Max Kellermann | 2011-10-06 | 1 | -7/+31 |
| | | | | | | | | .. and add a few code comments. | ||||
| * | decoder_control: add attributes start_ms, end_ms | Max Kellermann | 2011-10-05 | 5 | -6/+31 |
| | | | | | | | | | | Don't read song.start_ms and song.end_ms, let the player thread manage this logic instead. | ||||
| * | decoder_api: don't copy tag to pipe during initial seek | Max Kellermann | 2011-10-05 | 1 | -3/+8 |
| | | | | | | | | Fixes one more assertion failure. | ||||
| * | decoder_api: clear initial_seek_running on error | Max Kellermann | 2011-10-04 | 1 | -1/+3 |
| | | | | | | | | Fixes possible assertion failure. |