Revise so audio subchannel msf is msf_t (BCD encoded).

This commit is contained in:
rocky
2005-03-19 16:17:13 +00:00
parent a439bbf31e
commit d5221e901f
6 changed files with 69 additions and 40 deletions

View File

@@ -1,5 +1,5 @@
/*
$Id: win32_ioctl.c,v 1.25 2005/03/19 06:42:24 rocky Exp $
$Id: win32_ioctl.c,v 1.26 2005/03/19 16:17:13 rocky Exp $
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
@@ -26,7 +26,7 @@
# include "config.h"
#endif
static const char _rcsid[] = "$Id: win32_ioctl.c,v 1.25 2005/03/19 06:42:24 rocky Exp $";
static const char _rcsid[] = "$Id: win32_ioctl.c,v 1.26 2005/03/19 16:17:13 rocky Exp $";
#ifdef HAVE_WIN32_CDROM
@@ -219,12 +219,12 @@ audio_read_subchannel_win32ioctl (void *p_user_data,
const UCHAR *rel_addr =
q_subchannel_data.CurrentPosition.TrackRelativeAddress;
p_subchannel->abs_addr.m = abs_addr[1];
p_subchannel->abs_addr.s = abs_addr[2];
p_subchannel->abs_addr.f = abs_addr[3];
p_subchannel->rel_addr.m = rel_addr[1];
p_subchannel->rel_addr.s = rel_addr[2];
p_subchannel->rel_addr.f = rel_addr[3];
p_subchannel->abs_addr.m = cdio_to_bcd8(abs_addr[1]);
p_subchannel->abs_addr.s = cdio_to_bcd8(abs_addr[2]);
p_subchannel->abs_addr.f = cdio_to_bcd8(abs_addr[3]);
p_subchannel->rel_addr.m = cdio_to_bcd8(rel_addr[1]);
p_subchannel->rel_addr.s = cdio_to_bcd8(rel_addr[2]);
p_subchannel->rel_addr.f = cdio_to_bcd8(rel_addr[3]);
}
return DRIVER_OP_SUCCESS;

View File

@@ -1,5 +1,5 @@
/*
$Id: bsdi.c,v 1.7 2005/03/19 07:28:56 rocky Exp $
$Id: bsdi.c,v 1.8 2005/03/19 16:17:13 rocky Exp $
Copyright (C) 2001 Herbert Valerio Riedel <hvr@gnu.org>
Copyright (C) 2002, 2003, 2004, 2005 Rocky Bernstein <rocky@panix.com>
@@ -27,7 +27,7 @@
# include "config.h"
#endif
static const char _rcsid[] = "$Id: bsdi.c,v 1.7 2005/03/19 07:28:56 rocky Exp $";
static const char _rcsid[] = "$Id: bsdi.c,v 1.8 2005/03/19 16:17:13 rocky Exp $";
#include <cdio/logging.h>
#include <cdio/sector.h>
@@ -335,14 +335,14 @@ audio_read_subchannel_bsdi (void *p_user_data, cdio_subchannel_t *p_subchannel)
p_subchannel->index = cdstat.index_num;
cdio_lba_to_msf(cdstat.abs_frame, &msf);
p_subchannel->abs_addr.m = cdio_from_bcd8 (msf.m);
p_subchannel->abs_addr.s = cdio_from_bcd8 (msf.s);
p_subchannel->abs_addr.f = cdio_from_bcd8 (msf.f);
p_subchannel->abs_addr.m = msf.m;
p_subchannel->abs_addr.s = msf.s;
p_subchannel->abs_addr.f = msf.f;
cdio_lsn_to_msf(cdstat.rel_frame, &msf);
p_subchannel->rel_addr.m = cdio_from_bcd8 (msf.m);
p_subchannel->rel_addr.s = cdio_from_bcd8 (msf.s);
p_subchannel->rel_addr.f = cdio_from_bcd8 (msf.f);
p_subchannel->rel_addr.m = msf.m;
p_subchannel->rel_addr.s = msf.s;
p_subchannel->rel_addr.f = msf.f;
switch(cdstat.state) {
case cdstate_unknown:

View File

@@ -1,5 +1,5 @@
/*
$Id: gnu_linux.c,v 1.10 2005/03/15 12:11:53 rocky Exp $
$Id: gnu_linux.c,v 1.11 2005/03/19 16:17:13 rocky Exp $
Copyright (C) 2001 Herbert Valerio Riedel <hvr@gnu.org>
Copyright (C) 2002, 2003, 2004, 2005 Rocky Bernstein <rocky@panix.com>
@@ -27,7 +27,7 @@
# include "config.h"
#endif
static const char _rcsid[] = "$Id: gnu_linux.c,v 1.10 2005/03/15 12:11:53 rocky Exp $";
static const char _rcsid[] = "$Id: gnu_linux.c,v 1.11 2005/03/19 16:17:13 rocky Exp $";
#include <string.h>
@@ -271,8 +271,35 @@ audio_read_subchannel_linux (void *p_user_data,
{
const _img_private_t *p_env = p_user_data;
p_subchannel->format = CDIO_CDROM_MSF;
return ioctl(p_env->gen.fd, CDROMSUBCHNL, p_subchannel);
struct cdrom_subchnl subchannel;
int i_rc;
subchannel.cdsc_format = CDIO_CDROM_MSF;
i_rc = ioctl(p_env->gen.fd, CDROMSUBCHNL, &subchannel);
if (0 == i_rc) {
p_subchannel->control = subchannel.cdsc_ctrl;
p_subchannel->track = subchannel.cdsc_trk;
p_subchannel->index = subchannel.cdsc_ind;
p_subchannel->abs_addr.m =
cdio_to_bcd8(subchannel.cdsc_absaddr.msf.minute);
p_subchannel->abs_addr.s =
cdio_to_bcd8(subchannel.cdsc_absaddr.msf.second);
p_subchannel->abs_addr.f =
cdio_to_bcd8(subchannel.cdsc_absaddr.msf.frame);
p_subchannel->rel_addr.m =
cdio_to_bcd8(subchannel.cdsc_reladdr.msf.minute);
p_subchannel->rel_addr.s =
cdio_to_bcd8(subchannel.cdsc_reladdr.msf.second);
p_subchannel->rel_addr.f =
cdio_to_bcd8(subchannel.cdsc_reladdr.msf.frame);
p_subchannel->audio_status = subchannel.cdsc_audiostatus;
return DRIVER_OP_SUCCESS;
} else {
cdio_info ("ioctl CDROMSUBCHNL failed: %s\n", strerror(errno));
return DRIVER_OP_ERROR;
}
}
/*!

View File

@@ -1,6 +1,6 @@
/* Common Multimedia Command (MMC) routines.
$Id: mmc.c,v 1.23 2005/03/19 06:42:24 rocky Exp $
$Id: mmc.c,v 1.24 2005/03/19 16:17:13 rocky Exp $
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
@@ -26,6 +26,7 @@
#include <cdio/cdio.h>
#include <cdio/logging.h>
#include <cdio/mmc.h>
#include <cdio/util.h>
#include "cdio_private.h"
#ifdef HAVE_STRING_H
@@ -608,12 +609,12 @@ mmc_audio_read_subchannel (CdIo_t *p_cdio, cdio_subchannel_t *p_subchannel)
p_subchannel->control = mmc_subchannel.control;
p_subchannel->track = mmc_subchannel.track;
p_subchannel->index = mmc_subchannel.index;
p_subchannel->abs_addr.m = mmc_subchannel.abs_addr[1];
p_subchannel->abs_addr.s = mmc_subchannel.abs_addr[2];
p_subchannel->abs_addr.f = mmc_subchannel.abs_addr[3];
p_subchannel->rel_addr.m = mmc_subchannel.rel_addr[1];
p_subchannel->rel_addr.s = mmc_subchannel.rel_addr[2];
p_subchannel->rel_addr.f = mmc_subchannel.rel_addr[3];
p_subchannel->abs_addr.m = cdio_to_bcd8(mmc_subchannel.abs_addr[1]);
p_subchannel->abs_addr.s = cdio_to_bcd8(mmc_subchannel.abs_addr[2]);
p_subchannel->abs_addr.f = cdio_to_bcd8(mmc_subchannel.abs_addr[3]);
p_subchannel->rel_addr.m = cdio_to_bcd8(mmc_subchannel.rel_addr[1]);
p_subchannel->rel_addr.s = cdio_to_bcd8(mmc_subchannel.rel_addr[2]);
p_subchannel->rel_addr.f = cdio_to_bcd8(mmc_subchannel.rel_addr[3]);
}
return i_rc;
}