$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 }