Copyright 2003-2007 Warren Dukes warren.dukes@gmail.com
Copyright 2008-2018 Max Kellermann max.kellermann@gmail.com
This is free software; see the source for copying conditions. There is NO
warranty; not even MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Database plugins:
simple proxy upnp
Storage plugins:
local smbclient udisks nfs curl
Neighbor plugins:
smbclient upnp udisks
Decoders plugins:
[mad] mp3 mp2
[mpg123] mp3
[vorbis] ogg oga
[oggflac] ogg oga
[flac] flac
[opus] opus ogg oga
[sndfile] wav aiff aif au snd paf iff svx sf voc w64 pvf xi htk caf sd2
[audiofile] wav au aiff aif
[dsdiff] dff
[dsf] dsf
[hybrid_dsd] m4a
[faad] aac
[mpcdec] mpc
[wavpack] wv
[modplug] 669 amf ams dbm dfm dsm far it med mdl mod mtm mt2 okt s3m stm ult umx xm
[mikmod] amf dsm far gdm imf it med mod mtm s3m stm stx ult uni xm
[sidplay] sid mus str prg P00
[wildmidi] mid
[fluidsynth] mid
[adplug] amd d00 hsc laa rad raw sa2
[ffmpeg] 16sv 3g2 3gp 4xm 8svx aa3 aac ac3 adx afc aif aifc aiff al alaw amr anim apc ape asf atrac au aud avi avm2 avs bap bfi c93 cak cin cmv cpk daud dct divx dts dv dvd dxa eac3 film flac flc fli fll flx flv g726 gsm gxf iss m1v m2v m2t m2ts m4a m4b m4v mad mj2 mjpeg mjpg mka mkv mlp mm mmf mov mp+ mp1 mp2 mp3 mp4 mpc mpeg mpg mpga mpp mpu mve mvi mxf nc nsv nut nuv oga ogm ogv ogx oma ogg omg opus psp pva qcp qt r3d ra ram rl2 rm rmvb roq rpl rvc shn smk snd sol son spx str swf tak tgi tgq tgv thp ts tsp tta xa xvid uv uv2 vb vid vob voc vp6 vmd wav webm wma wmv wsaud wsvga wv wve
[gme] ay gbs gym hes kss nsf nsfe sap spc vgm vgz
[pcm]
Filters:
libsamplerate soxr
Tag plugins:
id3tag
Output plugins:
shout null fifo pipe alsa ao oss openal pulse jack httpd recorder
pi@raspberrypi:~/mpd-client $ mpd --verbose
config_file: loading file /etc/mpd.conf
Dec 15 23:00 : path: SetFSCharset: fs charset is:
Dec 15 23:00 : libsamplerate: libsamplerate converter 'Fastest Sinc Interpolator'
Dec 15 23:00 : vorbis: Xiph.Org libVorbis 1.3.6
Dec 15 23:00 : opus: libopus 1.3
Dec 15 23:00 : sndfile: libsndfile-1.0.28
Dec 15 23:00 : wildmidi: configuration file does not exist: /etc/timidity/timidity.cfg
Dec 15 23:00 : adplug: adplug 2.2.1
Dec 15 23:00 : simple_db: reading DB
Dec 15 23:00 : curl: version 7.64.0
Dec 15 23:00 : curl: with GnuTLS/3.6.7
pi@raspberrypi:~ $ mpd --stderr --no-daemon --verbose
config_file: loading file /etc/mpd.conf
path: SetFSCharset: fs charset is:
libsamplerate: libsamplerate converter 'Fastest Sinc Interpolator'
vorbis: Xiph.Org libVorbis 1.3.6
opus: libopus 1.3
sndfile: libsndfile-1.0.28
wildmidi: configuration file does not exist: /etc/timidity/timidity.cfg
adplug: adplug 2.2.1
simple_db: reading DB
curl: version 7.64.0
curl: with GnuTLS/3.6.7
avahi: Initializing interface
exception: RTIOThread could not get realtime scheduling, continuing anyway: sched_setscheduler failed: Operation not permitted
avahi: Client changed to state 2
avahi: Client is RUNNING
avahi: Registering service _mpd._tcp/Music Player @ raspberrypi
avahi: Service group changed to state 0
avahi: Service group is UNCOMMITED
state_file: Loading state file /mnt/mmcblk2p1/.mpd/state
avahi: Service group changed to state 1
avahi: Service group is REGISTERING
avahi: Service group changed to state 2
avahi: Service 'Music Player @ raspberrypi' successfully established.
^Cstate_file: Saving state file /mnt/mmcblk2p1/.mpd/state
avahi: Shutting down interface
Bug report
Describe the bug
I generated an mp3 file with beats every fourth second. When playing, the sound does not match the time. What is the problam may be.
https://drive.google.com/file/d/1vVhuPIWcK4aieZiw7NpsLP9jpeHIA-jp/view?usp=sharing
Expected Behavior
sound match the time
Actual Behavior
sound does not match the time
Version
Music Player Daemon 0.21.5 (0.21.5)
Copyright 2003-2007 Warren Dukes warren.dukes@gmail.com Copyright 2008-2018 Max Kellermann max.kellermann@gmail.com This is free software; see the source for copying conditions. There is NO warranty; not even MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Database plugins: simple proxy upnp
Storage plugins: local smbclient udisks nfs curl
Neighbor plugins: smbclient upnp udisks
Decoders plugins: [mad] mp3 mp2 [mpg123] mp3 [vorbis] ogg oga [oggflac] ogg oga [flac] flac [opus] opus ogg oga [sndfile] wav aiff aif au snd paf iff svx sf voc w64 pvf xi htk caf sd2 [audiofile] wav au aiff aif [dsdiff] dff [dsf] dsf [hybrid_dsd] m4a [faad] aac [mpcdec] mpc [wavpack] wv [modplug] 669 amf ams dbm dfm dsm far it med mdl mod mtm mt2 okt s3m stm ult umx xm [mikmod] amf dsm far gdm imf it med mod mtm s3m stm stx ult uni xm [sidplay] sid mus str prg P00 [wildmidi] mid [fluidsynth] mid [adplug] amd d00 hsc laa rad raw sa2 [ffmpeg] 16sv 3g2 3gp 4xm 8svx aa3 aac ac3 adx afc aif aifc aiff al alaw amr anim apc ape asf atrac au aud avi avm2 avs bap bfi c93 cak cin cmv cpk daud dct divx dts dv dvd dxa eac3 film flac flc fli fll flx flv g726 gsm gxf iss m1v m2v m2t m2ts m4a m4b m4v mad mj2 mjpeg mjpg mka mkv mlp mm mmf mov mp+ mp1 mp2 mp3 mp4 mpc mpeg mpg mpga mpp mpu mve mvi mxf nc nsv nut nuv oga ogm ogv ogx oma ogg omg opus psp pva qcp qt r3d ra ram rl2 rm rmvb roq rpl rvc shn smk snd sol son spx str swf tak tgi tgq tgv thp ts tsp tta xa xvid uv uv2 vb vid vob voc vp6 vmd wav webm wma wmv wsaud wsvga wv wve [gme] ay gbs gym hes kss nsf nsfe sap spc vgm vgz [pcm]
Filters: libsamplerate soxr
Tag plugins: id3tag
Output plugins: shout null fifo pipe alsa ao oss openal pulse jack httpd recorder
Encoder plugins: null vorbis opus lame wave flac
Archive plugins: [bz2] bz2 [zzip] zip [iso] iso
Input plugins: file archive alsa tidal qobuz curl ffmpeg smbclient nfs mms cdio_paranoia
Playlist plugins: extm3u m3u pls xspf asx rss soundcloud flac cue embcue
Protocols: file:// alsa:// tidal:// qobuz:// http:// https:// gopher:// rtp:// rtsp:// rtmp:// rtmpt:// rtmps:// smb:// nfs:// mms:// mmsh:// mmst:// mmsu:// cdda://
Other features: avahi dbus udisks epoll icu inotify ipv6 systemd tcp un
Configuration
An example configuration file for MPD.
Read the user manual for documentation: http://www.musicpd.org/doc/user/
or /usr/share/doc/mpd/html/user.html
Files and directories
#
This setting controls the top directory which MPD will search to discover the
available audio files and add them to the daemon's online database. This
setting defaults to the XDG directory, otherwise the music directory will be
be disabled and audio files will only be accepted over ipc socket (using
file:// protocol) or streaming files over an accepted protocol.
#
music_directory "/var/lib/mpd/music"
music_directory "/mnt/mmcblk2p1/music"
#
This setting sets the MPD internal playlist directory. The purpose of this
directory is storage for playlists created by MPD. The server will use
playlist files not created by the server but only if they are in the MPD
format. This setting defaults to playlist saving being disabled.
#
playlist_directory "/var/lib/mpd/playlists"
playlist_directory "/mnt/mmcblk2p1/.mpd/playlists"
#
This setting sets the location of the MPD database. This file is used to
load the database at server start up and store the database while the
server is not up. This setting defaults to disabled which will allow
MPD to accept files over ipc socket (using file:// protocol) or streaming
files over an accepted protocol.
#
db_file "/var/lib/mpd/tag_cache"
db_file "/mnt/mmcblk2p1/.mpd/database"
#
These settings are the locations for the daemon log files for the daemon.
These logs are great for troubleshooting, depending on your log_level
settings.
#
The special value "syslog" makes MPD use the local syslog daemon. This
setting defaults to logging to syslog, or to journal if mpd was started as
a systemd service.
#
log_file "/var/log/mpd/mpd.log"
log_file "/mnt/mmcblk2p1/.mpd/mpd.log"
#
This setting sets the location of the file which stores the process ID
for use of mpd --kill and some init scripts. This setting is disabled by
default and the pid file will not be stored.
#
pid_file "/run/mpd/pid"
pid_file "/mnt/mmcblk2p1/.mpd/mpd.pid"
#
This setting sets the location of the file which contains information about
most variables to get MPD back into the same general shape it was in before
it was brought down. This setting is disabled by default and the server
state will be reset on server start up.
#
state_file "/var/lib/mpd/state"
state_file "/mnt/mmcblk2p1/.mpd/state"
#
The location of the sticker database. This is a database which
manages dynamic information attached to songs.
#
sticker_file "/var/lib/.mpd/sticker.sql"
sticker_file "/mnt/mmcblk2p1/.mpd/sticker.sql" # ###############################################################################
General music daemon options
#
This setting specifies the user that MPD will run as. MPD should never run as
root and you may use this setting to make MPD change its user ID after
initialization. This setting is disabled by default and MPD is run as the
current user.
# user "pi" #
This setting specifies the group that MPD will run as. If not specified
primary group of user specified with "user" setting will be used (if set).
This is useful if MPD needs to be a member of group such as "audio" to
have permission to use sound card.
#
group "nogroup"
#
This setting sets the address for the daemon to listen on. Careful attention
should be paid if this is assigned to anything other then the default, any.
This setting can deny access to control of the daemon. Choose any if you want
to have mpd listen on every address. Not effective if systemd socket
activation is in use.
#
For network
bind_to_address "localhost"
bind_to_address "192.168.0.2"
bind_to_address "192.168.1.160"
bind_to_address "2.93.122.180"
bind_to_address "0.0.0.0"
#
And for Unix Socket
bind_to_address "/run/mpd/socket"
#
This setting is the TCP port that is desired for the daemon to get assigned
to.
#
port "6600"
#
This setting controls the type of information which is logged. Available
setting arguments are "default", "secure" or "verbose". The "verbose" setting
argument is recommended for troubleshooting, though can quickly stretch
available resources on limited hardware storage.
#
log_level "default"
#
Setting "restore_paused" to "yes" puts MPD into pause mode instead
of starting playback after startup.
#
restore_paused "no"
#
This setting enables MPD to create playlists in a format usable by other
music players.
#
save_absolute_paths_in_playlists "no"
#
This setting defines a list of tag types that will be extracted during the
audio file discovery process. The complete list of possible values can be
found in the user manual.
metadata_to_use "artist,album,title,track,name,genre,date,composer,performer,disc"
#
This example just enables the "comment" tag without disabling all
the other supported tags:
metadata_to_use "+comment"
#
This setting enables automatic update of MPD's database when files in
music_directory are changed.
#
auto_update "yes"
#
Limit the depth of the directories being watched, 0 means only watch
the music directory itself. There is no limit by default.
#
auto_update_depth "3"
# ###############################################################################
Symbolic link behavior
#
If this setting is set to "yes", MPD will discover audio files by following
symbolic links outside of the configured music_directory.
#
follow_outside_symlinks "yes"
#
If this setting is set to "yes", MPD will discover audio files by following
symbolic links inside of the configured music_directory.
#
follow_inside_symlinks "yes"
# ###############################################################################
Zeroconf / Avahi Service Discovery
#
If this setting is set to "yes", service information will be published with
Zeroconf / Avahi.
#
zeroconf_enabled "yes"
#
The argument to this setting will be the Zeroconf / Avahi unique name for
this MPD server on the network. %h will be replaced with the hostname.
#
zeroconf_name "Music Player @ %h"
# ###############################################################################
Permissions
#
If this setting is set, MPD will require password authorization. The password
setting can be specified multiple times for different password profiles.
#
password "password@read,add,control,admin"
#
This setting specifies the permissions a user has who has not yet logged in.
#
default_permissions "read,add,control,admin"
# ###############################################################################
Database
#
database {
plugin "proxy"
host "other.mpd.host"
port "6600"
}
Input
#
input { plugin "curl"
proxy "proxy.isp.com:8080"
proxy_user "user"
proxy_password "password"
}
QOBUZ input plugin
input { enabled "no" plugin "qobuz"
app_id "ID"
app_secret "SECRET"
username "USERNAME"
password "PASSWORD"
format_id "N"
}
TIDAL input plugin
input { enabled "no" plugin "tidal"
token "TOKEN"
username "USERNAME"
password "PASSWORD"
audioquality "Q"
}
Decoder
#
decoder { plugin "hybrid_dsd" enabled "no"
gapless "no"
}
# ###############################################################################
Audio Output
#
MPD supports various audio output types, as well as playing through multiple
audio outputs at the same time, through multiple audio_output settings
blocks. Setting this block is optional, though the server will only attempt
autodetection for one sound card.
#
An example of an ALSA output:
# audio_output { type "alsa" name "My ALSA Device" mixer_type "software"
mixer_type "hardware" # optional
mixer_device "default" # optional
mixer_control "PCM" # optional
mixer_index "0" # optional
} #
An example of an OSS output:
#
audio_output {
type "oss"
name "My OSS Device"
device "/dev/dsp" # optional
mixer_type "hardware" # optional
mixer_device "/dev/mixer" # optional
mixer_control "PCM" # optional
}
#
An example of a shout output (for streaming to Icecast):
#
audio_output {
type "shout"
encoder "vorbis" # optional
name "My Shout Stream"
host "localhost"
port "8000"
mount "/mpd.ogg"
password "hackme"
quality "5.0"
bitrate "128"
format "44100:16:1"
protocol "icecast2" # optional
user "source" # optional
description "My Stream Description" # optional
url "http://example.com" # optional
genre "jazz" # optional
public "no" # optional
timeout "2" # optional
mixer_type "software" # optional
}
#
An example of a recorder output:
#
audio_output {
type "recorder"
name "My recorder"
encoder "vorbis" # optional, vorbis or lame
path "/var/lib/mpd/recorder/mpd.ogg"
quality "5.0" # do not define if bitrate is defined
bitrate "128" # do not define if quality is defined
format "44100:16:1"
}
#
An example of a httpd output (built-in HTTP streaming server):
#
audio_output {
type "httpd"
name "My HTTP Stream"
encoder "vorbis" # optional, vorbis or lame
port "8000"
bind_to_address "0.0.0.0" # optional, IPv4 or IPv6
quality "5.0" # do not define if bitrate is defined
bitrate "128" # do not define if quality is defined
format "44100:16:1"
max_clients "0" # optional 0=no limit
}
#
An example of a pulseaudio output (streaming to a remote pulseaudio server)
Please see README.Debian if you want mpd to play through the pulseaudio
daemon started as part of your graphical desktop session!
#
audio_output {
type "pulse"
name "My Pulse Output"
server "remote_server" # optional
sink "remote_server_sink" # optional
}
#
An example of a winmm output (Windows multimedia API).
#
audio_output {
type "winmm"
name "My WinMM output"
device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
or
device "0" # optional
mixer_type "hardware" # optional
}
#
An example of an openal output.
#
audio_output {
type "openal"
name "My OpenAL output"
device "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
}
#
Example "pipe" output:
#
audio_output {
type "pipe"
name "my pipe"
command "aplay -f cd 2>/dev/null"
Or if you're want to use AudioCompress
command "AudioCompress -m | aplay -f cd 2>/dev/null"
Or to send raw PCM stream through PCM:
command "nc example.org 8765"
format "44100:16:2"
}
#
An example of a null output (for no audio output):
#
audio_output {
type "null"
name "My Null Output"
mixer_type "none" # optional
}
# ###############################################################################
Normalization automatic volume adjustments
#
This setting specifies the type of ReplayGain to use. This setting can have
the argument "off", "album", "track" or "auto". "auto" is a special mode that
chooses between "track" and "album" depending on the current state of
random playback. If random playback is enabled then "track" mode is used.
See http://www.replaygain.org for more details about ReplayGain.
This setting is off by default.
#
replaygain "album"
#
This setting sets the pre-amp used for files that have ReplayGain tags. By
default this setting is disabled.
#
replaygain_preamp "0"
#
This setting sets the pre-amp used for files that do NOT have ReplayGain tags.
By default this setting is disabled.
#
replaygain_missing_preamp "0"
#
This setting enables or disables ReplayGain limiting.
MPD calculates actual amplification based on the ReplayGain tags
and replaygain_preamp / replaygain_missing_preamp setting.
If replaygain_limit is enabled MPD will never amplify audio signal
above its original level. If replaygain_limit is disabled such amplification
might occur. By default this setting is enabled.
#
replaygain_limit "yes"
#
This setting enables on-the-fly normalization volume adjustment. This will
result in the volume of all playing audio to be adjusted so the output has
equal "loudness". This setting is disabled by default.
#
volume_normalization "no"
# ###############################################################################
Character Encoding
#
If file or directory names do not display correctly for your locale then you
may need to modify this setting.
# filesystem_charset "UTF-8" # ###############################################################################
Log
pi@raspberrypi:~/mpd-client $ mpd --verbose config_file: loading file /etc/mpd.conf Dec 15 23:00 : path: SetFSCharset: fs charset is: Dec 15 23:00 : libsamplerate: libsamplerate converter 'Fastest Sinc Interpolator' Dec 15 23:00 : vorbis: Xiph.Org libVorbis 1.3.6 Dec 15 23:00 : opus: libopus 1.3 Dec 15 23:00 : sndfile: libsndfile-1.0.28 Dec 15 23:00 : wildmidi: configuration file does not exist: /etc/timidity/timidity.cfg Dec 15 23:00 : adplug: adplug 2.2.1 Dec 15 23:00 : simple_db: reading DB Dec 15 23:00 : curl: version 7.64.0 Dec 15 23:00 : curl: with GnuTLS/3.6.7
pi@raspberrypi:~ $ mpd --stderr --no-daemon --verbose config_file: loading file /etc/mpd.conf path: SetFSCharset: fs charset is: libsamplerate: libsamplerate converter 'Fastest Sinc Interpolator' vorbis: Xiph.Org libVorbis 1.3.6 opus: libopus 1.3 sndfile: libsndfile-1.0.28 wildmidi: configuration file does not exist: /etc/timidity/timidity.cfg adplug: adplug 2.2.1 simple_db: reading DB curl: version 7.64.0 curl: with GnuTLS/3.6.7 avahi: Initializing interface exception: RTIOThread could not get realtime scheduling, continuing anyway: sched_setscheduler failed: Operation not permitted avahi: Client changed to state 2 avahi: Client is RUNNING avahi: Registering service _mpd._tcp/Music Player @ raspberrypi avahi: Service group changed to state 0 avahi: Service group is UNCOMMITED state_file: Loading state file /mnt/mmcblk2p1/.mpd/state avahi: Service group changed to state 1 avahi: Service group is REGISTERING avahi: Service group changed to state 2 avahi: Service 'Music Player @ raspberrypi' successfully established. ^Cstate_file: Saving state file /mnt/mmcblk2p1/.mpd/state avahi: Shutting down interface