CDDA2WAV(1) CDDA2WAV(1)
NNAAMMEE
cdda2wav - a sampling utility that dumps CD audio data
into wav sound files
SSYYNNOOPPSSIISS
ccddddaa22wwaavv [--cc _c_h_a_n_s] [--ss] [--mm] [--bb _b_i_t_s] [--rr _r_a_t_e] [--aa
_d_i_v_i_d_e_r] [--tt _t_r_a_c_k[_+_e_n_d_t_r_a_c_k]] [--ii _i_n_d_e_x] [--oo _o_f_f_s_e_t] [--dd
_d_u_r_a_t_i_o_n] [--xx] [--qq] [--ww] [--vv _o_p_t_l_i_s_t] [--VV] [--QQ] [--JJ] [--LL
_c_d_d_b_m_o_d_e] [--RR] [--PP _s_e_c_t_o_r_s] [--FF] [--GG] [--TT] [--ee] [--pp _p_e_r_-
_c_e_n_t_a_g_e] [--nn _s_e_c_t_o_r_s] [--ll _b_u_f_f_e_r_s] [--NN] [--JJ] [--HH] [--gg]
[--BB] [--DD _d_e_v_i_c_e] [--AA _a_u_x_d_e_v_i_c_e] [--II _i_n_t_e_r_f_a_c_e] [--OO _a_u_d_i_o_-
_t_y_p_e] [--CC _i_n_p_u_t_-_e_n_d_i_a_n_e_s_s] [--EE _o_u_t_p_u_t_-_e_n_d_i_a_n_e_s_s] [--MM
_c_o_u_n_t] [--SS _s_p_e_e_d] [--ppaarraannooiiaa] [ccddddbbpp--sseerrvveerr==sseerrvveerrnnaammee]
[ccddddbbpp--ppoorrtt==ppoorrttnnuummbbeerr] [_f_i_l_e_n_a_m_e_(_s_) or _d_i_r_e_c_t_o_r_i_e_s]
DDEESSCCRRIIPPTTIIOONN
ccddddaa22wwaavv can retrieve audio tracks from CDROM drives (see
README for a list of drives) that are capable of reading
audio data digitally to the host (CCDDDDAA).
OOPPTTIIOONNSS
--DD _d_e_v_i_c_e _-_-_d_e_v _-_-_d_e_v_i_c_e
uses ddeevviiccee as the source for CDDA reading. For
example /dev/cdrom for the ccooookkeedd__iiooccttll interface
and Bus,ID,Lun for the ggeenneerriicc__ssccssii interface. The
ddeevviiccee has to correspond with the interface setting
(see below). The setting of the environment vari-
able CCDDDDAA__DDEEVVIICCEE is overridden by this option.
--AA _a_u_x_d_e_v_i_c_e _-_-_a_u_x_d_e_v_i_c_e
uses aauuxxddeevviiccee as CDROM drive for ioctl usage.
--II _i_n_t_e_r_f_a_c_e _-_-_i_n_t_e_r_f_a_c_e
specifies the interface for CDROM access:
ggeenneerriicc__ssccssii or (on Linux, and FreeBSD systems)
ccooookkeedd__iiooccttll.
--cc _c_h_a_n_n_e_l_s _-_-_c_h_a_n_n_e_l_s
uses 11 for mono, or 22 for stereo recording, or ss
for stereo recording with both channels swapped.
--ss ----sstteerreeoo
sets to stereo recording.
--mm ----mmoonnoo
sets to mono recording.
--xx ----mmaaxx
sets maximum (CD) quality.
--bb _b_i_t_s _-_-_b_i_t_s_-_p_e_r_-_s_a_m_p_l_e
sets bits per sample per channel: 88, 1122 or 1166.
--rr _r_a_t_e _-_-_r_a_t_e
sets rate in samples per second. Possible values
are listed with the --RR option.
--aa _d_i_v_i_d_e_r _-_-_d_i_v_i_d_e_r
sets rate to 44100Hz / divider. Possible values
are listed with the --RR option.
--RR ----dduummpp--rraatteess
shows a list of all sample rates and their
dividers.
--PP sseeccttoorrss ----sseett--oovveerrllaapp
sets the initial number of overlap _s_e_c_t_o_r_s for jit-
ter correction.
--nn _s_e_c_t_o_r_s _-_-_s_e_c_t_o_r_s_-_p_e_r_-_r_e_q_u_e_s_t
reads _s_e_c_t_o_r_s per request.
--ll _b_u_f_f_e_r_s _-_-_b_u_f_f_e_r_s_-_i_n_-_r_i_n_g
uses a ring buffer with _b_u_f_f_e_r_s total.
--tt _t_r_a_c_k_+_e_n_d_t_r_a_c_k _-_-_t_r_a_c_k
selects the start track and optionally the end
track.
--ii _i_n_d_e_x _-_-_i_n_d_e_x
selects the start index.
--oo _o_f_f_s_e_t _-_-_o_f_f_s_e_t
starts _o_f_f_s_e_t sectors behind start track (one sec-
tor equivalents 1/75 seconds).
--OO aauuddiioottyyppee ----oouuttppuutt--ffoorrmmaatt
can be _w_a_v (for wav files) or _a_i_f_f (for apple/sgi
aiff files) or _a_i_f_c (for apple/sgi aifc files) or
_a_u or _s_u_n (for sun .au PCM files) or _c_d_r or _r_a_w
(for headerless files to be used for cd writers).
--CC _e_n_d_i_a_n_e_s_s _-_-_c_d_r_o_m_-_e_n_d_i_a_n_e_s_s
sets endianess of the input samples to 'little',
'big' or 'guess' to override defaults.
--EE _e_n_d_i_a_n_e_s_s _-_-_o_u_t_p_u_t_-_e_n_d_i_a_n_e_s_s
sets endianess of the output samples to 'little' or
'big' to override defaults.
--dd _d_u_r_a_t_i_o_n _-_-_d_u_r_a_t_i_o_n
sets recording time in seconds or frames. Frames
(sectors) are indicated by a 'f' suffix (like 75f
for 75 sectors). 00 sets the time for whole track.
--BB ----bbuullkk ----aallllttrraacckkss
copies each track into a seperate file.
--ww ----wwaaiitt
waits for signal, then start recording.
--FF ----ffiinndd--eexxttrreemmeess
finds extrem amplitudes in samples.
--GG ----ffiinndd--mmoonnoo
finds if input samples are in mono.
--TT ----ddeeeemmpphhaassiizzee
undo the effect of pre-emphasis in the input sam-
ples.
--ee ----eecchhoo
copies audio data to sound device e.g. //ddeevv//ddsspp.
--pp ppeerrcceennttaaggee ----sseett--ppiittcchh
changes pitch of audio data copied to sound device.
--vv iitteemmlliisstt ----vveerrbboossee--lleevveell
prints verbose information about the CD. LLeevveell is
a list of comma seperated suboptions. Each subop-
tion controls the type of information to be
reported.
+----------+----------------------------------------------------------------+
|Suboption | Description |
+----------+----------------------------------------------------------------+
| disable | no information is given, warnings appear however |
| all | all information is given |
| toc | show table of contents |
| summary | show a summary of the recording parameters |
| indices | determine and display index offsets |
| catalog | retrieve and display the media catalog number MCN |
| trackid | retrieve and display all Intern. Standard Recording Codes ISRC |
| sectors | show the table of contents in start sector notation |
| titles | show the table of contents with track titles (when available) |
+----------+----------------------------------------------------------------+
--NN ----nnoo--wwrriittee
does not write to a file, it just reads (for debug-
ging purposes).
--JJ ----iinnffoo--oonnllyy
does not write to a file, it just gives information
about the disc.
--LL ccddddbb mmooddee ----ccddddbb
does a cddbp album- and track title lookup based on
the cddb id. The parameter cddb mode defines how
multiple entries shall be handled.
ccddddbbpp--sseerrvveerr==sseerrvveerrnnaammee
sets the server to be contacted for title lookups.
ccddddbbpp--ppoorrtt==ppoorrttnnuummbbeerr
sets the port number to be used for title lookups.
--HH ----nnoo--iinnffooffiillee
does not write an info file and a cddb file.
--gg ----gguuii
formats the output to be better parsable by gui
frontends.
--MM ccoouunntt ----mmdd55
enables calculation of MD-5 checksum for 'count'
bytes from a beginning of a track.
--SS ssppeeeedd ----ssppeeeedd
sets the cdrom device to one of the selectable
speeds for reading.
--qq ----qquuiieett
quiet operation, no screen output.
--VV ----vveerrbboossee--SSCCSSII
enable SCSI command logging to the console. This is
mainly used for debugging.
--QQ ----ssiilleenntt--SSCCSSII
suppress SCSI command error reports to the console.
This is mainly used for guis.
--ppaarraannooiiaa
use the paranoia library instead of cdda2wav's rou-
tines for reading.
--hh ----hheellpp
display version of cdda2wav on standard output.
Defaults depend on the
MMaakkeeffiillee and eennvviirroonnmmeenntt vvaarriiaabbllee settings (cur-
rently CCDDDDAA__DDEEVVIICCEE ).
EENNVVIIRROONNMMEENNTT VVAARRIIAABBLLEESS
CCDDDDAA__DDEEVVIICCEE is used to set the device name. The device
naming is compatible with Jörg Schilling's cdrecord pack-
age.
CCDDDDBBPP__SSEERRVVEERR
is used for cddbp title lookups when supplied.
CCDDDDBBPP__PPOORRTT
is used for cddbp title lookups when supplied.
RRSSHH If the RRSSHH environment variable is present, the
remote connection will not be created via rrccmmdd(3)
but by calling the program pointed to by RRSSHH. Use
e.g. RRSSHH==/usr/bin/ssh to create a secure shell
connection.
Note that this forces ccddddaa22wwaavv to create a pipe to
the rrsshh((11)) program and disallows ccddddaa22wwaavv to
directly access the network socket to the remote
server. This makes it impossible to set up perfor-
mance parameters and slows down the connection com-
pared to a rroooott initiated rrccmmdd((33)) connection.
RRSSCCSSII If the RRSSCCSSII environment variable is present, the
remote SCSI server will not be the program
//oopptt//sscchhiillyy//ssbbiinn//rrssccssii but the program pointed to
by RRSSCCSSII. Note that the remote SCSI server program
name will be ignored if you log in using an account
that has been created with a remote SCSI server
program as login shell.
RREETTUURRNN VVAALLUUEESS
ccddddaa22wwaavv uses the following exit codes to indicate various
degress of success:
+---------+--------------------------------------------------------------------+
|Exitcode | Description |
+---------+--------------------------------------------------------------------+
| 0 | no errors encountered, successful operation. |
| 1 | usage or syntax error. cdda2wav got inconsistent arguments. |
| 2 | permission (un)set errors. permission changes failed. |
| 3 | read errors on the cdrom/burner device encountered. |
| 4 | write errors while writing one of the output files encountered. |
| 5 | errors with soundcard handling (initialization/write). |
| 6 | errors with stat() system call on the read device (cooked ioctl). |
| 7 | pipe communication errors encountered (in forked mode). |
| 8 | signal handler installation errors encountered. |
| 9 | allocation of shared memory failed (in forked mode). |
| 10 | dynamic heap memory allocation failed. |
| 11 | errors on the audio cd medium encountered. |
| 12 | device open error in ioctl handling detected. |
| 13 | race condition in ioctl interface handling detected. |
| 14 | error in ioctl() operation encountered. |
| 15 | internal error encountered. Please report back!!! |
| 16 | error in semaphore operation encountered (install / request). |
| 17 | could not get the scsi transfer buffer. |
| 18 | could not create pipes for process communication (in forked mode). |
+---------+--------------------------------------------------------------------+
DDIISSCCUUSSSSIIOONN
ccddddaa22wwaavv is able to read parts of an aauuddiioo CD or mmuullttiimmee--
ddiiaa CDROM (containing audio parts) directly digitally.
These parts can be written to a file, a pipe, or to a
sound device.
ccddddaa22wwaavv stands for CCDDDDAA to WWAAVV (where CCDDDDAA stands for
compact disc digital audio and WWAAVV is a sound sample for-
mat introduced by MS Windows). It allows copying CCDDDDAA
audio data from the CDROM drive into a file in WWAAVV or
other formats.
The latest versions try to get higher real-time scheduling
priorities to ensure smooth (uninterrupted) operation.
These priorities are available for super users and are
higher than those of 'normal' processes. Thus delays are
minimized.
If your CDROM is on device DDEEVV and it is loaded with an
audio CD, you may simply invoke ccddddaa22wwaavv ddeevv==DDEEVV and it
will create the sound file aauuddiioo..wwaavv recording the whole
track beginning with track 1 in stereo at 16 bit at 44100
Hz sample rate, if your file system has enough space free.
Otherwise recording time will be limited. For details see
files RREEAADDMMEE and RREEAADDMMEE..IINNSSTTAALLLL
HHIINNTTSS OONN OOPPTTIIOONNSS
Options
Most of the options are used to control the format
of the WAV file. In the following text all of them
are described.
Select Device
--DD _d_e_v_i_c_e selects the CDROM drive device to be
used. The specifier given should correspond to the
selected interface (see below). CCHHAANNGGEE!! For the
cooked_ioctl interface this is the cdrom device
descriptor as before. TThhee SSCCSSII ddeevviicceess uusseedd wwiitthh
tthhee ggeenneerriicc SSCCSSII iinntteerrffaaccee hhoowweevveerr aarree nnooww
aaddddrreesssseedd wwiitthh tthheeiirr SSCCSSII--BBuuss,, SSCCSSII--IIdd,, aanndd SSCCSSII--
LLuunn iinnsstteeaadd ooff tthhee ggeenneerriicc SSCCSSII ddeevviiccee ddeessccrriipp--
ttoorr!!!!!! One example for a SCSI CDROM drive on bus 0
with SCSI ID 3 and lun 0 is -D0,3,0.
Select Auxiliary device
--AA _a_u_x_d_e_v_i_c_e is necessary for CD-Extra handling.
For Non-SCSI-CDROM drives this is the same device
as given by -D (see above). For SCSI-CDROM drives
it is the CDROM drive (SCSI) device (i.e. //ddeevv//ssrr00
) corresponding to the SCSI device (i.e. 00,,33,,00 ).
It has to match the device used for sampling.
Select Interface
--II _i_n_t_e_r_f_a_c_e selects the CDROM drive interface. For
SCSI drives use generic_scsi (cooked_ioctl may not
yet be available for all devices): ggeenneerriicc__ssccssii and
ccooookkeedd__iiooccttll. The first uses the generic SCSI
interface, the latter uses the ioctl of the CDROM
driver. The latter variant works only when the ker-
nel driver supports CCDDDDAA reading. This entry has to
match the selected CDROM device (see above).
Enable echo to soundcard
--ee copies audio data to the sound card while
recording, so you hear it nearly simultaneously.
The soundcard gets the same data that is recorded.
This is time critical, so it works best with the --qq
option. To use ccddddaa22wwaavv as a pseudo CD player
without recording in a file you could use ccddddaa22wwaavv
--qq --ee --tt22 --dd00 --NN to play the whole second track.
This feature reduces the recording speed to at most
onefold speed. You cannot make better recordings
than your sound card can play (since the same data
is used).
Change pitch of echoed audio
--pp ppeerrcceennttaaggee changes the pitch of all audio echoed
to a sound card. Only the copy to the soundcard is
affected, the recorded audio samples in a file
remain the same. Normal pitch, which is the
default, is given by 100%. Lower percentages cor-
respond to lower pitches, i.e. -p 50 transposes
the audio output one octave lower. See also the
script ppiittcchhppllaayy as an example. This option was
contributed by Raul Sobon.
Select mono or stereo recording
--mm or --cc 11 selects mono recording (both stereo
channels are mixed), --ss or --cc 22 or --cc ss selects
stereo recording. Parameter s will swap both sound
channels.
Select maximum quality
--xx will set stereo, 16 bits per sample at 44.1 KHz
(full CD quality). Note that other format options
given later can change this setting.
Select sample quality
--bb 88 specifies 8 bit (1 Byte) for each sample in
each channel; --bb 1122 specifies 12 bit (2 Byte) for
each sample in each channel; --bb 1166 specifies 16 bit
(2 Byte) for each sample in each channel (Ensure
that your sample player or sound card is capable of
playing 12-bit or 16-bit samples). Selecting 12 or
16 bits doubles file size. 12-bit samples are
aligned to 16-bit samples, so they waste some disk
space.
Select sample rate
--rr _s_a_m_p_l_e_r_a_t_e selects a sample rate. _s_a_m_p_l_e_r_a_t_e
can be in a range between 44100 and 900. Option --RR
lists all available rates.
Select sample rate divider
--aa _d_i_v_i_d_e_r selects a sample rate divider. _d_i_v_i_d_e_r
can be minimally 1 and maximally 50.5 and every-
thing between in steps of 0.5. Option --RR lists all
available rates.
To make the sound smoother at lower sampling rates,
ccddddaa22wwaavv sums over _n samples (where _n is the spe-
cific dividend). So for 22050 Hertz output we have
to sum over 2 samples, for 900 Hertz we have to sum
over 49 samples. This cancels higher frequencies.
Standard sector size of an audio CD (ignoring addi-
tional information) is 2352 Bytes. In order to fin-
ish summing for an output sample at sector bound-
aries the rates above have to be choosen. Arbi-
trary sampling rates in high quality would require
some interpolation scheme, which needs much more
sophisticated programming.
List a table of all sampling rates
--RR shows a list of all sample rates and their
dividers. Dividers can range from 1 to 50.5 in
steps of 0.5.
Select start track and optionally end track
--tt _n_+_m selects nn as the start track and optionally
mm as the last track of a range to be recorded.
These tracks must be from the table of contents.
This sets the track where recording begins. Record-
ing can advance through the following tracks as
well (limited by the optional end track or other-
wise depending on recording time). Whether one file
or different files are then created depends on the
--BB option (see below).
Select start index
--ii _n selects the index to start recording with.
Indices other than 1 will invoke the index scanner,
which will take some time to find the correct start
position. An offset may be given additionally (see
below).
Set recording time
--dd nn sets recording time to _n seconds or set
recording time for whole track if _n is zero. In
order to specify the duration in frames (sectors)
also, the argument can have an appended 'f'. Then
the numerical argument is to be taken as frames
(sectors) rather than seconds. Please note that if
track ranges are being used they define the record-
ing time as well thus overriding any --dd option
specified times.
Recording time is defined as the time the generated
sample will play (at the defined sample rate).
Since it's related to the amount of generated sam-
ples, it's not the time of the sampling process
itself (which can be less or more). It's neither
strictly coupled with the time information on the
audio CD (shown by your hifi CD player). Differ-
ences can occur by the usage of the --oo option (see
below). Notice that recording time will be short-
ened, unless enough disk space exists. Recording
can be aborted at anytime by pressing the break
character (signal SIGQUIT).
Record all tracks of a complete audio CD in seperate files
--BB copies each track into a seperate file. A base
name can be given. File names have an appended
track number and an extension corresponding to the
audio format. To record all audio tracks of a CD,
use a sufficient high duration (i.e. -d99999).
Set start sector offset
--oo _s_e_c_t_o_r_s increments start sector of the track by
_s_e_c_t_o_r_s. By this option you are able to skip a
certain amount at the beginning of a track so you
can pick exactly the part you want. Each sector
runs for 1/75 seconds, so you have very fine con-
trol. If your offset is so high that it would not
fit into the current track, a warning message is
issued and the offset is ignored. Recording time
is not reduced. (To skip introductory quiet pas-
sages automagically, use the --ww option see below.)
Wait for signal option
--ww Turning on this option will suppress all silent
output at startup, reducing possibly file size.
ccddddaa22wwaavv will watch for any signal in the output
signal and switches on writing to file.
Find extrem samples
--FF Turning on this option will display the most
negative and the most positive sample value found
during recording for both channels. This can be
useful for readjusting the volume. The values shown
are not reset at track boundaries, they cover the
complete sampling process. They are taken from the
original samples and have the same format (i.e.
they are independent of the selected output for-
mat).
Find if input samples are in mono
--GG If this option is given, input samples for both
channels will be compared. At the end of the pro-
gram the result is printed. Differences in the
channels indicate stereo, otherwise when both chan-
nels are equal it will indicate mono.
Undo the pre-emphasis in the input samples
--TT Some older audio CDs are recorded with a modi-
fied frequency response called pre-emphasis. This
is found mostly in classical recordings. The cor-
rection can be seen in the flags of the Table Of
Contents often. But there are recordings, that show
this setting only in the subchannels. If this
option is given, the index scanner will be started,
which reads the q-subchannel of each track. If pre-
emphasis is indicated in the q-subchannel of a
track, but not in the TOC, pre-emphasis will be
assumed to be present, and subsequently a reverse
filtering is done for this track before the samples
are written into the audio file.
Set audio format
--OO aauuddiioottyyppee can be _w_a_v (for wav files) or _a_u or
_s_u_n (for sun PCM files) or _c_d_r or _r_a_w (for header-
less files to be used for cd writers). All file
samples are coded in linear pulse code modulation
(as done in the audio compact disc format). This
holds for all audio formats. Wav files are compat-
ible to Wind*ws sound files, they have lsb,msb byte
order as being used on the audio cd. The default
filename extension is '.wav'. Sun type files are
not like the older common logarithmically coded .au
files, but instead as mentioned above linear PCM is
used. The byte order is msb,lsb to be compatible.
The default filename extension is '.au'. The AIFF
and the newer variant AIFC from the Apple/SGI world
store their samples in bigendian format (msb,lsb).
In AIFC no compression is used. Finally the easi-
est 'format', the cdr aka raw format. It is done
per default in msb,lsb byte order to satisfy the
order wanted by most cd writers. Since there is no
header information in this format, the sample
parameters can only be identified by playing the
samples on a soundcard or similiar. The default
filename extension is '.cdr' or '.raw'.
Select cdrom drive reading speed
--SS ssppeeeedd allows to switch the cdrom drive to a
certain level of speed in order to reduce read
errors. The argument is transfered verbatim to the
drive. Details depend very much on the cdrom
drives. An argument of 0 for example is often the
default speed of the drive, a value of 1 often
selects single speed.
Enable MD5 checksums
--MM ccoouunntt enables calculation of MD-5 checksum for
'count' bytes from the beginning of a track. This
was introduced for quick comparisons of tracks.
Use Monty's libparanoia for reading of sectors
--ppaarraannooiiaa selects an alternate way of extracting
audio sectors. Monty's library is used with the
following default options:
PARANOIA_MODE_FULL, but without PARANOIA_MODE_NEV-
ERSKIP
for details see Monty's libparanoia documentation.
In this case the option --PP has no effect.
Do linear or overlapping reading of sectors
(This applies unless option --ppaarraannooiiaa is used.) --PP
sseeccttoorrss sets the given number of sectors for ini-
tial overlap sampling for jitter correction. Two
cases are to be distinguished. For nonzero values,
some sectors are read twice to enable cdda2wav's
jitter correction. If an argument of zero is
given, no overlap sampling will be used. For
nonzero overlap sectors cdda2wav dynamically
adjusts the setting during sampling (like cdpara-
noia does). If no match can be found, cdda2wav
retries the read with an increased overlap. If the
amount of jitter is lower than the current over-
lapped samples, cdda2wav reduces the overlap set-
ting, resulting in a higher reading speed. The
argument given has to be lower than the total num-
ber of sectors per request (see option _-_n below).
Cdda2wav will check this setting and issues a error
message otherwise. The case of zero sectors is
nice on low load situations or errorfree (perfect)
cdrom drives and perfect (not scratched) audio cds.
Set the transfer size
--nn sseeccttoorrss will set the transfer size to the spec-
ified sectors per request.
Set number of ring buffer elements
--ll bbuuffffeerrss will allocate the specified number of
ring buffer elements.
Set endianess of input samples
--CC eennddiiaanneessss will override the default settings of
the input format. Endianess can be set explicitly
to "little" or "big" or to the automatic endianess
detection based on voting with "guess".
Set endianess of output samples
--EE eennddiiaanneessss (endianess can be "little" or "big")
will override the default settings of the output
format.
Verbose option
--vv iitteemmlliisstt prints more information. A list allows
selection of different information items.
ddiissaabbllee keeps quiet
ttoocc displays the table of contents
ssuummmmaarryy displays a summary of recording parameters
iinnddiicceess invokes the index scanner and displays
start positions of indices
ccaattaalloogg retrieves and displays a media catalog num-
ber
ttrraacckkiidd retrieves and displays international stan-
dard recording codes
sseeccttoorrss displays track start positions in absolute
sector notation
To combine several requests just list the subop-
tions seperated with commas.
The table of contents
The display will show the table of contents with
number of tracks and total time (displayed in
_m_m:_s_s._h_h format, _m_m=minutes, _s_s=seconds, _h_h=rounded
1/100 seconds). The following list displays track
number and track time for each entry. The summary
gives a line per track describing the type of the
track.
ttrraacckk pprreeeemmpphhaassiiss ccooppyyppeerrmmiitttteedd ttrraacckkttyyppee cchhaannss
The ttrraacckk column holds the track number. pprreeeemmpphhaa--
ssiiss shows if that track has been given a non linear
frequency response. NOTE: You can undo this effect
with the --TT option. ccooppyy--ppeerrmmiitttteedd indicates if
this track is allowed to copy. ttrraacckkttyyppee can be
data or audio. On multimedia CDs (except hidden
track CDs) both of them should be present. cchhaann--
nneellss is defined for audio tracks only. There can be
two or four channels.
No file output
--NN this debugging option switches off writing to a
file.
No infofile generation
--HH this option switches off creation of an info
file and a cddb file.
Generation of simple output for gui frontends
--gg this option switches on simple line formatting,
which is needed to support gui frontends (like xcd-
roast).
Verbose SCSI logging
--VV this option switches on logging of SCSI com-
mands. This will produce a lot of output (when SCSI
devices are being used). This is needed for debug-
ging purposes. The format is the same as being used
with the cdrecord program from Jörg Schilling. I
will not describe it here.
Quiet option
--qq suppresses all screen output except error
messages. That reduces cpu time resources.
Just show information option
--JJ does not write a file, it only prints informa-
tion about the disc (depending on the --vv option).
This is just for information purposes.
CCDDDDBBPP ssuuppppoorrtt
Lookup album and track titles option
--LL ccddddbbpp mmooddee Cdda2wav tries to retrieve per-
former, album-, and track titles from a cddbp
server. The default server right now is
'freedb.freedb.org'. It is planned to have more
control over the server handling later. The param-
eter defines how multiple entries are handled:
0 interactive mode, the user chooses one of the
entries.
1 take the first entry without asking.
Set server for title lookups
ccddddbbpp--sseerrvveerr sseerrvveerrnnaammee When using -L or --cddb,
the server being contacted can be set with this
option.
Set portnumber for title lookups
ccddddbbpp--ppoorrtt ppoorrttnnuummbbeerr When using -L or --cddb, the
server port being contacted can be set with this
option.
HHIINNTTSS OONN UUSSAAGGEE
Don't create samples you cannot read. First check your
sample player software and sound card hardware. I experi-
enced problems with very low sample rates (stereo <= 1575
Hz, mono <= 3675 Hz) when trying to play them with stan-
dard WAV players for sound blaster (maybe they are not
legal in WWAAVV format). Most CD-Writers insist on audio sam-
ples in a bigendian format. Now cdda2wav supports the --EE
eennddiiaanneessss option to control the endianess of the written
samples.
If your hardware is fast enough to run cdda2wav uninter-
rupted and your CD drive is one of the 'perfect' ones, you
will gain speed when switching all overlap sampling off
with the --PP 00 option. Further fine tuning can be done
with the --nn sseeccttoorrss option. You can specify how much sec-
tors should be requested in one go.
Cdda2wav supports ppiippeess now. Use a filename of -- to let
cdda2wav output its samples to standard output.
Conversion to other sound formats can be done using the
ssooxx program package (although the use of ssooxx --xx to change
the byte order of samples should be no more necessary; see
option --EE to change the output byteorder).
If you want to sample more than one track into different
files in one run, this is currently possible with the --BB
option. When recording time exceeds the track limit a new
file will be opened for the next track.
FFIILLEESS
Cdda2wav can generate a lot of files for various purposes.
Audio files:
There are audio files containing samples with default
extensions These files are not generated when option (-N)
is given. Multiple files may be written when the bulk copy
option (-B) is used. Individual file names can be given as
arguments. If the number of file names given is sufficient
to cover all included audio tracks, the file names will be
used verbatim. Otherwise, if there are less file names
than files needed to write the included tracks, the part
of the file name before the extension is extended with
'_dd' where dd represents the current track number.
Cddb and Cdindex files:
If cdda2wav detects cd-extra or cd-text (album/track)
title information, then .cddb and .cdindex files are gen-
erated unless suppressed by the option -H. They contain
suitable formatted entries for submission to audio cd
track title databases in the internet. The CDINDEX and
CDDB(tm) systems are currently supported. For more infor-
mation please visit www.musicbrainz.org and
www.freedb.com.
Inf files:
The inf files are describing the sample files and the part
from the audio cd, it was taken from. They are a means to
transfer information to a cd burning program like
cdrecord. For example, if the original audio cd had pre-
emphasis enabled, and cdda2wav -T did remove the pre-
emphasis, then the inf file has pre-emphasis not set
(since the audio file does not have it anymore), while the
.cddb and the .cdindex have pre-emphasis set as the origi-
nal does.
WWAARRNNIINNGG
IIMMPPOORRTTAANNTT:: it is prohibited to sell copies of copyrighted
material by noncopyright holders. This program may not be
used to circumvent copyrights. The user acknowledges this
constraint when using the software.
BBUUGGSS
Generation of md5 checksums is currently broken.
Performance may not be optimal on slower systems.
The index scanner may give timeouts.
The resampling (rate conversion code) uses polynomial
interpolation, which is not optimal.
Cdda2wav should use threads.
Cdda2wav currently cannot sample hidden audio tracks
(track 1 index 0).
AACCKKNNOOWWLLEEDDGGEEMMEENNTTSS
Thanks goto Project MODE (http://www.mode.net/) and Fraun-
hofer Institut für integrierte Schaltungen (FhG-IIS)
(http://www.iis.fhg.de/) for financial support. Plextor
Europe and Ricoh Japan provided cdrom disk drives and cd
burners which helped a lot to develop this software.
Rammi has helped a lot with the debugging and showed a lot
of stamina when hearing 100 times the first 16 seconds of
the first track of the Krupps CD. Libparanoia contributed
by Monty (Christopher Montgomery) xiphmont@mit.edu.
AAUUTTHHOORR
Heiko Eissfeldt heiko@colossus.escape.de
DDAATTEE
11 Sep 2002
CDDA2WAV(1)