summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--misc/libcdio/Makefile11
-rw-r--r--misc/libcdio/files/_cdio_netbsd.c583
2 files changed, 2 insertions, 592 deletions
diff --git a/misc/libcdio/Makefile b/misc/libcdio/Makefile
index e0dd519d9f4..e568db067b2 100644
--- a/misc/libcdio/Makefile
+++ b/misc/libcdio/Makefile
@@ -1,6 +1,7 @@
-# $NetBSD: Makefile,v 1.37 2008/11/10 22:30:43 wiz Exp $
+# $NetBSD: Makefile,v 1.38 2009/01/04 12:42:20 wiz Exp $
DISTNAME= libcdio-0.81
+PKGREVISION= 1
CATEGORIES= misc
MASTER_SITES= ${MASTER_SITE_GNU:=libcdio/}
@@ -27,14 +28,6 @@ CONFIGURE_ARGS+= --without-versioned-libs
CONFIGURE_ARGS+= --enable-cpp-progs
INFO_FILES= # PLIST
-.include "../../mk/bsd.prefs.mk"
-
-.if ${OPSYS} == "NetBSD"
-# XXX we just replace the freebsd module so save patches
-pre-patch:
- ${CP} ${FILESDIR}/_cdio_netbsd.c ${WRKSRC}/lib/driver/FreeBSD/freebsd.c
-.endif
-
.include "../../devel/ncurses/buildlink3.mk"
.include "../../devel/popt/buildlink3.mk"
.include "../../audio/libcddb/buildlink3.mk"
diff --git a/misc/libcdio/files/_cdio_netbsd.c b/misc/libcdio/files/_cdio_netbsd.c
deleted file mode 100644
index 97483d04516..00000000000
--- a/misc/libcdio/files/_cdio_netbsd.c
+++ /dev/null
@@ -1,583 +0,0 @@
-/* $NetBSD: _cdio_netbsd.c,v 1.5 2008/04/15 16:13:12 tron Exp $ */
-
-/*
- * Copyright (c) 2003
- * Matthias Drochner. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-/*
- * XXX This is for NetBSD but uses "freebsd" function names to plug
- * nicely into the existing libcdio.
- */
-
-#ifdef HAVE_CONFIG_H
-#include "config.h"
-#endif
-
-#include <cdio/sector.h>
-#include <cdio/util.h>
-#include "cdio_assert.h"
-#include "cdio_private.h"
-
-#include <string.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <errno.h>
-#include <unistd.h>
-#include <fcntl.h>
-#include <sys/stat.h>
-#include <sys/types.h>
-#include <sys/ioctl.h>
-#include <sys/cdio.h>
-#include <sys/scsiio.h>
-
-#ifdef __i386__
-#define DEFAULT_CDIO_DEVICE "/dev/rcd0d"
-#else
-#define DEFAULT_CDIO_DEVICE "/dev/rcd0c"
-#endif
-
-#define TOTAL_TRACKS (_obj->tochdr.ending_track \
- - _obj->tochdr.starting_track + 1)
-#define FIRST_TRACK_NUM (_obj->tochdr.starting_track)
-
-typedef struct {
- generic_img_private_t gen;
-
- bool toc_valid;
- struct ioc_toc_header tochdr;
- struct cd_toc_entry tocent[100];
-
- bool sessionformat_valid;
- int sessionformat[100]; /* format of the session the track is in */
-} _img_private_t;
-
-static driver_return_code_t
-run_scsi_cmd_freebsd(void *p_user_data, unsigned int i_timeout_ms,
- unsigned int i_cdb, const mmc_cdb_t *p_cdb,
- cdio_mmc_direction_t e_direction,
- unsigned int i_buf, void *p_buf )
-{
- const _img_private_t *_obj = p_user_data;
- scsireq_t req;
-
- memset(&req, 0, sizeof(req));
- memcpy(&req.cmd[0], p_cdb, i_cdb);
- req.cmdlen = i_cdb;
- req.datalen = i_buf;
- req.databuf = p_buf;
- req.timeout = i_timeout_ms;
- req.flags = e_direction == SCSI_MMC_DATA_READ ? SCCMD_READ : SCCMD_WRITE;
-
- if (ioctl(_obj->gen.fd, SCIOCCOMMAND, &req) < 0) {
- perror("SCIOCCOMMAND");
- return -1;
- }
- if (req.retsts != SCCMD_OK) {
- fprintf(stderr, "SCIOCCOMMAND cmd 0x%02x sts %d\n", req.cmd[0], req.retsts);
- return -1;
- }
-
- return 0;
-}
-
-static int
-_cdio_read_audio_sectors(void *user_data, void *data, lsn_t lsn,
- unsigned int nblocks)
-{
- scsireq_t req;
- _img_private_t *_obj = user_data;
-
- memset(&req, 0, sizeof(req));
- req.cmd[0] = 0xbe;
- req.cmd[1] = 0;
- req.cmd[2] = (lsn >> 24) & 0xff;
- req.cmd[3] = (lsn >> 16) & 0xff;
- req.cmd[4] = (lsn >> 8) & 0xff;
- req.cmd[5] = (lsn >> 0) & 0xff;
- req.cmd[6] = (nblocks >> 16) & 0xff;
- req.cmd[7] = (nblocks >> 8) & 0xff;
- req.cmd[8] = (nblocks >> 0) & 0xff;
- req.cmd[9] = 0x78;
- req.cmdlen = 10;
-
- req.datalen = nblocks * CDIO_CD_FRAMESIZE_RAW;
- req.databuf = data;
- req.timeout = 10000;
- req.flags = SCCMD_READ;
-
- if (ioctl(_obj->gen.fd, SCIOCCOMMAND, &req) < 0) {
- perror("SCIOCCOMMAND");
- return 1;
- }
- if (req.retsts != SCCMD_OK) {
- fprintf(stderr, "SCIOCCOMMAND cmd 0xbe sts %d\n", req.retsts);
- return 1;
- }
-
- return 0;
-}
-
-static int
-_cdio_read_mode2_sector(void *user_data, void *data, lsn_t lsn,
- bool mode2_form2)
-{
- scsireq_t req;
- _img_private_t *_obj = user_data;
- char buf[M2RAW_SECTOR_SIZE] = { 0, };
-
- memset(&req, 0, sizeof(req));
- req.cmd[0] = 0xbe;
- req.cmd[1] = 0;
- req.cmd[2] = (lsn >> 24) & 0xff;
- req.cmd[3] = (lsn >> 16) & 0xff;
- req.cmd[4] = (lsn >> 8) & 0xff;
- req.cmd[5] = (lsn >> 0) & 0xff;
- req.cmd[6] = 0;
- req.cmd[7] = 0;
- req.cmd[8] = 1;
- req.cmd[9] = 0x58; /* subheader + userdata + ECC */
- req.cmdlen = 10;
-
- req.datalen = M2RAW_SECTOR_SIZE;
- req.databuf = buf;
- req.timeout = 10000;
- req.flags = SCCMD_READ;
-
- if (ioctl(_obj->gen.fd, SCIOCCOMMAND, &req) < 0) {
- perror("SCIOCCOMMAND");
- return 1;
- }
- if (req.retsts != SCCMD_OK) {
- fprintf(stderr, "SCIOCCOMMAND cmd %0xbe sts %d\n", req.retsts);
- return 1;
- }
-
- if (mode2_form2)
- memcpy(data, buf, M2RAW_SECTOR_SIZE);
- else
- memcpy(data, buf + CDIO_CD_SUBHEADER_SIZE, CDIO_CD_FRAMESIZE);
-
- return 0;
-}
-
-static int
-_cdio_read_mode2_sectors(void *user_data, void *data, lsn_t lsn,
- bool mode2_form2, unsigned int nblocks)
-{
- int i, res;
- char *buf = data;
-
- for (i = 0; i < nblocks; i++) {
- res = _cdio_read_mode2_sector(user_data, buf, lsn, mode2_form2);
- if (res)
- return res;
-
- buf += (mode2_form2 ? M2RAW_SECTOR_SIZE : CDIO_CD_FRAMESIZE);
- lsn++;
- }
-
- return 0;
-}
-
-static uint32_t
-_cdio_stat_size(void *user_data)
-{
- _img_private_t *_obj = user_data;
- struct ioc_read_toc_entry req;
- struct cd_toc_entry tocent;
-
- req.address_format = CD_LBA_FORMAT;
- req.starting_track = 0xaa;
- req.data_len = sizeof(tocent);
- req.data = &tocent;
-
- if (ioctl(_obj->gen.fd, CDIOREADTOCENTRIES, &req) < 0) {
- perror("ioctl(CDIOREADTOCENTRY) leadout");
- exit(EXIT_FAILURE);
- }
-
- return (tocent.addr.lba);
-}
-
-static int
-_cdio_set_arg(void *user_data, const char key[], const char value[])
-{
- _img_private_t *_obj = user_data;
-
- if (!strcmp(key, "source")) {
- if (!value)
- return -2;
-
- free(_obj->gen.source_name);
- _obj->gen.source_name = strdup(value);
- } else if (!strcmp(key, "access-mode")) {
- if (strcmp(value, "READ_CD"))
- cdio_error("unknown access type: %s ignored.", value);
- } else
- return -1;
-
- return 0;
-}
-
-static bool
-_cdio_read_toc(_img_private_t *_obj)
-{
- int res;
- struct ioc_read_toc_entry req;
-
- res = ioctl(_obj->gen.fd, CDIOREADTOCHEADER, &_obj->tochdr);
- if (res < 0) {
- cdio_error("error in ioctl(CDIOREADTOCHEADER): %s\n",
- strerror(errno));
- return false;
- }
-
- req.address_format = CD_MSF_FORMAT;
- req.starting_track = FIRST_TRACK_NUM;
- req.data_len = (TOTAL_TRACKS + 1) /* leadout! */
- * sizeof(struct cd_toc_entry);
- req.data = _obj->tocent;
-
- res = ioctl(_obj->gen.fd, CDIOREADTOCENTRIES, &req);
- if (res < 0) {
- cdio_error("error in ioctl(CDROMREADTOCENTRIES): %s\n",
- strerror(errno));
- return false;
- }
-
- _obj->toc_valid = 1;
- return true;
-}
-
-static bool
-read_toc_freebsd (void *p_user_data)
-{
-
- return _cdio_read_toc(p_user_data);
-}
-
-static int
-_cdio_read_discinfo(_img_private_t *_obj)
-{
- scsireq_t req;
-#define FULLTOCBUF (4 + 1000*11)
- unsigned char buf[FULLTOCBUF] = { 0, };
- int i, j;
-
- memset(&req, 0, sizeof(req));
- req.cmd[0] = 0x43; /* READ TOC/PMA/ATIP */
- req.cmd[1] = 0x02;
- req.cmd[2] = 0x02; /* full TOC */
- req.cmd[3] = 0;
- req.cmd[4] = 0;
- req.cmd[5] = 0;
- req.cmd[6] = 0;
- req.cmd[7] = FULLTOCBUF / 256;
- req.cmd[8] = FULLTOCBUF % 256;
- req.cmd[9] = 0;
- req.cmdlen = 10;
-
- req.datalen = FULLTOCBUF;
- req.databuf = buf;
- req.timeout = 10000;
- req.flags = SCCMD_READ;
-
- if (ioctl(_obj->gen.fd, SCIOCCOMMAND, &req) < 0) {
- perror("SCIOCCOMMAND");
- return 1;
- }
- if (req.retsts != SCCMD_OK) {
- fprintf(stderr, "SCIOCCOMMAND cmd 0x43 sts %d\n", req.retsts);
- return 1;
- }
-#if 1
- printf("discinfo:");
- for (i = 0; i < 4; i++)
- printf(" %02x", buf[i]);
- printf("\n");
- for (i = 0; i < buf[1] - 2; i++) {
- printf(" %02x", buf[i + 4]);
- if (!((i + 1) % 11))
- printf("\n");
- }
-#endif
-
- for (i = 4; i < req.datalen_used; i += 11) {
- if (buf[i + 3] == 0xa0) { /* POINT */
- /* XXX: assume entry 0xa1 follows */
- for (j = buf[i + 8] - 1; j <= buf[i + 11 + 8] - 1; j++)
- _obj->sessionformat[j] = buf[i + 9];
- }
- }
-
- _obj->sessionformat_valid = true;
- return 0;
-}
-
-static int
-_cdio_eject_media(void *user_data) {
-
- _img_private_t *_obj = user_data;
- int fd, res, ret = 0;
-
- fd = open(_obj->gen.source_name, O_RDONLY|O_NONBLOCK);
- if (fd < 0)
- return 2;
-
- res = ioctl(fd, CDIOCALLOW);
- if (res < 0) {
- cdio_error("ioctl(fd, CDIOCALLOW) failed: %s\n",
- strerror(errno));
- /* go on... */
- }
- res = ioctl(fd, CDIOCEJECT);
- if (res < 0) {
- cdio_error("ioctl(CDIOCEJECT) failed: %s\n",
- strerror(errno));
- ret = 1;
- }
-
- return ret;
-}
-
-static const char *
-_cdio_get_arg(void *user_data, const char key[])
-{
- _img_private_t *_obj = user_data;
-
- if (!strcmp(key, "source")) {
- return _obj->gen.source_name;
- } else if (!strcmp(key, "access-mode")) {
- return "READ_CD";
- }
-
- return NULL;
-}
-
-static track_t
-_cdio_get_first_track_num(void *user_data)
-{
- _img_private_t *_obj = user_data;
- int res;
-
- if (!_obj->toc_valid) {
- res = _cdio_read_toc(_obj);
- if (!res)
- return CDIO_INVALID_TRACK;
- }
-
- return FIRST_TRACK_NUM;
-}
-
-static track_t
-_cdio_get_num_tracks(void *user_data)
-{
- _img_private_t *_obj = user_data;
- int res;
-
- if (!_obj->toc_valid) {
- res = _cdio_read_toc(_obj);
- if (!res)
- return CDIO_INVALID_TRACK;
- }
-
- return TOTAL_TRACKS;
-}
-
-static track_format_t
-_cdio_get_track_format(void *user_data, track_t track_num)
-{
- _img_private_t *_obj = user_data;
- int res;
-
- if (!_obj->toc_valid) {
- res = _cdio_read_toc(_obj);
- if (!res)
- return CDIO_INVALID_TRACK;
- }
-
- if (track_num > TOTAL_TRACKS || track_num == 0)
- return TRACK_FORMAT_ERROR;
-
- if (_obj->tocent[track_num - 1].control & 0x04) {
- if (!_obj->sessionformat_valid) {
- res = _cdio_read_discinfo(_obj);
- if (res)
- return CDIO_INVALID_TRACK;
- }
-
- if (_obj->sessionformat[track_num - 1] == 0x10)
- return TRACK_FORMAT_CDI;
- else if (_obj->sessionformat[track_num - 1] == 0x20)
- return TRACK_FORMAT_XA;
- else
- return TRACK_FORMAT_DATA;
- } else
- return TRACK_FORMAT_AUDIO;
-}
-
-static bool
-_cdio_get_track_green(void *user_data, track_t track_num)
-{
-
- return (_cdio_get_track_format(user_data, track_num)
- == TRACK_FORMAT_XA);
-}
-
-static bool
-_cdio_get_track_msf(void *user_data, track_t track_num, msf_t *msf)
-{
- _img_private_t *_obj = user_data;
- int res;
-
- if (!msf)
- return false;
-
- if (!_obj->toc_valid) {
- res = _cdio_read_toc(_obj);
- if (!res)
- return CDIO_INVALID_TRACK;
- }
-
- if (track_num == CDIO_CDROM_LEADOUT_TRACK)
- track_num = TOTAL_TRACKS + 1;
-
- if (track_num > TOTAL_TRACKS + 1 || track_num == 0)
- return false;
-
- msf->m = cdio_to_bcd8(_obj->tocent[track_num - 1].addr.msf.minute);
- msf->s = cdio_to_bcd8(_obj->tocent[track_num - 1].addr.msf.second);
- msf->f = cdio_to_bcd8(_obj->tocent[track_num - 1].addr.msf.frame);
-
- return true;
-}
-
-static lsn_t
-get_disc_last_lsn_netbsd(void *user_data)
-{
- msf_t msf;
-
- _cdio_get_track_msf(user_data, CDIO_CDROM_LEADOUT_TRACK, &msf);
-
- return (((msf.m * 60) + msf.s) * 75 + msf.f);
-}
-
-
-char **
-cdio_get_devices_freebsd (void)
-{
-
- return 0;
-}
-
-char *
-cdio_get_default_device_freebsd()
-{
-
- return strdup(DEFAULT_CDIO_DEVICE);
-}
-
-driver_return_code_t
-close_tray_freebsd (const char *psz_device)
-{
-
- return DRIVER_OP_SUCCESS;
-}
-
-static cdio_funcs_t _funcs = {
- .eject_media = _cdio_eject_media,
- .free = cdio_generic_free,
- .get_arg = _cdio_get_arg,
- .get_cdtext = get_cdtext_generic,
- .get_default_device = cdio_get_default_device_freebsd,
- .get_devices = cdio_get_devices_freebsd,
- .get_disc_last_lsn = get_disc_last_lsn_netbsd,
- .get_discmode = get_discmode_generic,
- .get_drive_cap = get_drive_cap_mmc,
- .get_first_track_num= _cdio_get_first_track_num,
- .get_mcn = get_mcn_mmc,
- .get_num_tracks = _cdio_get_num_tracks,
- .get_track_format = _cdio_get_track_format,
- .get_track_green = _cdio_get_track_green,
- .get_track_lba = NULL,
- .get_track_msf = _cdio_get_track_msf,
- .lseek = cdio_generic_lseek,
- .read = cdio_generic_read,
- .read_audio_sectors = _cdio_read_audio_sectors,
- .read_data_sectors = read_data_sectors_generic,
- .read_mode2_sector = _cdio_read_mode2_sector,
- .read_mode2_sectors = _cdio_read_mode2_sectors,
- .read_toc = read_toc_freebsd,
-#if 1
- .run_mmc_cmd = run_scsi_cmd_freebsd,
-#endif
- .set_arg = _cdio_set_arg,
-#if 0
- .stat_size = _cdio_stat_size
-#endif
-};
-
-CdIo *
-cdio_open_freebsd(const char *source_name)
-{
- CdIo *ret;
- _img_private_t *_data;
-
- _data = calloc(1, sizeof(_img_private_t));
- _data->gen.init = false;
- _data->gen.fd = -1;
- _data->toc_valid = false;
- _data->sessionformat_valid = false;
-
- _cdio_set_arg(_data, "source",
- (source_name ? source_name : DEFAULT_CDIO_DEVICE));
-
- if (source_name && !cdio_is_device_generic(source_name))
- return (NULL);
-
- ret = cdio_new(&_data->gen, &_funcs);
- if (!ret)
- return NULL;
-
- if (cdio_generic_init(_data, O_RDONLY)) {
- return ret;
- } else {
- cdio_generic_free(_data);
- return NULL;
- }
-}
-
-CdIo *
-cdio_open_am_freebsd(const char *source_name, const char *am)
-{
-
- return (cdio_open_freebsd(source_name));
-}
-
-bool
-cdio_have_freebsd(void)
-{
-
- return true;
-}