Blob Blame History Raw
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)