4f62f8691c
from Bjorn Sandell <biorn@dce.chalmers.se> and from NetBSD
108 lines
2.9 KiB
Plaintext
108 lines
2.9 KiB
Plaintext
$OpenBSD: patch-interface_cooked_interface_c,v 1.2 2002/09/16 13:35:52 lebel Exp $
|
|
--- interface/cooked_interface.c.orig Thu Apr 20 00:41:04 2000
|
|
+++ interface/cooked_interface.c Mon Sep 16 12:47:11 2002
|
|
@@ -13,6 +13,7 @@
|
|
static int cooked_readtoc (cdrom_drive *d){
|
|
int i;
|
|
int tracks;
|
|
+#ifdef __linux__
|
|
struct cdrom_tochdr hdr;
|
|
struct cdrom_tocentry entry;
|
|
|
|
@@ -52,6 +53,45 @@ static int cooked_readtoc (cdrom_drive *
|
|
d->disc_toc[i].dwStartSector = entry.cdte_addr.lba;
|
|
|
|
tracks=hdr.cdth_trk1+1;
|
|
+#endif
|
|
+
|
|
+#if defined (__NetBSD__) || defined (__OpenBSD__)
|
|
+ struct ioc_read_toc_entry hdr;
|
|
+ struct cd_toc_entry entries[MAXTRK + 1]; /* + 1 for leadout */
|
|
+
|
|
+ hdr.address_format = CD_LBA_FORMAT;
|
|
+ hdr.starting_track = 1;
|
|
+ hdr.data_len = sizeof entries;
|
|
+ hdr.data = entries;
|
|
+ memset(entries, 0, sizeof entries);
|
|
+
|
|
+ /* get all TOC entries at once */
|
|
+#ifndef CDIOREADTOCENTRIES
|
|
+#define CDIOREADTOCENTRIES CDIOREADTOCENTRYS
|
|
+#endif
|
|
+ if(ioctl(d->ioctl_fd, CDIOREADTOCENTRIES, &hdr))
|
|
+ switch(errno){
|
|
+ case EPERM:
|
|
+ cderror(d,"102: Permision denied on cdrom (ioctl) device\n");
|
|
+ return(-102);
|
|
+ default:
|
|
+ cderror(d,"004: Unable to read table of contents header\n");
|
|
+ return(-4);
|
|
+ }
|
|
+
|
|
+ for(i = 0; i < MAXTRK + 1; i++) {
|
|
+ d->disc_toc[i].bFlags = (entries[i].addr_type << 4) | (entries[i].control & 0x0f);
|
|
+ d->disc_toc[i].bTrack = entries[i].track;
|
|
+ d->disc_toc[i].dwStartSector = entries[i].addr.lba;
|
|
+ if (entries[i].track == 0) {
|
|
+ cderror(d,"005: Unable to read table of contents entry\n");
|
|
+ return(-5);
|
|
+ }
|
|
+ if (entries[i].track >= 100)
|
|
+ break; /* leadout */
|
|
+ }
|
|
+ tracks = i;
|
|
+#endif
|
|
d->cd_extra=FixupTOC(d,tracks);
|
|
return(--tracks); /* without lead-out */
|
|
}
|
|
@@ -60,10 +100,14 @@ static int cooked_readtoc (cdrom_drive *
|
|
/* Set operating speed */
|
|
static int cooked_setspeed(cdrom_drive *d, int speed)
|
|
{
|
|
+#ifdef __linux__
|
|
if(d->ioctl_fd!=-1)
|
|
return ioctl(d->ioctl_fd, CDROM_SELECT_SPEED, speed);
|
|
else
|
|
return 0;
|
|
+#else
|
|
+ errx(1, "cooked_setspeed: not implemented");
|
|
+#endif
|
|
}
|
|
|
|
|
|
@@ -72,6 +116,7 @@ static int cooked_setspeed(cdrom_drive *
|
|
*/
|
|
|
|
static long cooked_read (cdrom_drive *d, void *p, long begin, long sectors){
|
|
+#ifdef __linux__
|
|
int retry_count,err;
|
|
struct cdrom_read_audio arg;
|
|
char *buffer=(char *)p;
|
|
@@ -127,6 +172,9 @@ static long cooked_read (cdrom_drive *d,
|
|
} while (err);
|
|
|
|
return(sectors);
|
|
+#else
|
|
+ errx(1, "cooked_read: not implemented");
|
|
+#endif
|
|
}
|
|
|
|
/* hook */
|
|
@@ -191,6 +239,7 @@ static void check_exceptions(cdrom_drive
|
|
|
|
/* set function pointers to use the ioctl routines */
|
|
int cooked_init_drive (cdrom_drive *d){
|
|
+#ifdef __linux__
|
|
int ret;
|
|
|
|
switch(d->drive_type){
|
|
@@ -255,5 +304,8 @@ int cooked_init_drive (cdrom_drive *d){
|
|
if((ret=verify_read_command(d)))return(ret);
|
|
d->error_retry=1;
|
|
return(0);
|
|
+#else
|
|
+ errx(1, "cooked_init_drive: not implemented");
|
|
+#endif
|
|
}
|
|
|