Author: mav
Date: Thu Jan 12 14:53:08 2012
New Revision: 230014
URL: http://svn.freebsd.org/changeset/base/230014

Log:
  MFC r228808, r228847, 229395:
  
  r228808, r228847:
  Make cd driver to handle Audio CDs, reporting their 2352 bytes sectors to
  GEOM and using READ CD command for reading data, same as acd driver does.
  Audio CDs identified by checking respective bit of the control field of
  the first track in TOC.
  
  229395:
  Add support for CDRIOCGETBLOCKSIZE and CDRIOCSETBLOCKSIZE IOCTLs to control
  sector size same as acd driver does. Together with r228808 and r228847 this
  allows existing multimedia/vlc to play Audio CDs via CAM cd driver.
  
  PR:             ports/162190
  Sponsored by: iXsystems, Inc.

Modified:
  stable/9/sys/cam/scsi/scsi_all.h
  stable/9/sys/cam/scsi/scsi_cd.c
Directory Properties:
  stable/9/sys/   (props changed)
  stable/9/sys/amd64/include/xen/   (props changed)
  stable/9/sys/boot/   (props changed)
  stable/9/sys/boot/i386/efi/   (props changed)
  stable/9/sys/boot/ia64/efi/   (props changed)
  stable/9/sys/boot/ia64/ski/   (props changed)
  stable/9/sys/boot/powerpc/boot1.chrp/   (props changed)
  stable/9/sys/boot/powerpc/ofw/   (props changed)
  stable/9/sys/cddl/contrib/opensolaris/   (props changed)
  stable/9/sys/conf/   (props changed)
  stable/9/sys/contrib/dev/acpica/   (props changed)
  stable/9/sys/contrib/octeon-sdk/   (props changed)
  stable/9/sys/contrib/pf/   (props changed)
  stable/9/sys/contrib/x86emu/   (props changed)

Modified: stable/9/sys/cam/scsi/scsi_all.h
==============================================================================
--- stable/9/sys/cam/scsi/scsi_all.h    Thu Jan 12 14:44:14 2012        
(r230013)
+++ stable/9/sys/cam/scsi/scsi_all.h    Thu Jan 12 14:53:08 2012        
(r230014)
@@ -932,6 +932,7 @@ struct ata_pass_16 {
 #define        WRITE_12                0xAA
 #define        WRITE_VERIFY_12         0xAE
 #define        READ_ELEMENT_STATUS     0xB8
+#define        READ_CD                 0xBE
 
 /* Maintenance In Service Action Codes */
 #define        REPORT_IDENTIFYING_INFRMATION           0x05

Modified: stable/9/sys/cam/scsi/scsi_cd.c
==============================================================================
--- stable/9/sys/cam/scsi/scsi_cd.c     Thu Jan 12 14:44:14 2012        
(r230013)
+++ stable/9/sys/cam/scsi/scsi_cd.c     Thu Jan 12 14:53:08 2012        
(r230014)
@@ -1482,6 +1482,14 @@ cdstart(struct cam_periph *periph, union
                                        /* dxfer_len */ bp->bio_bcount,
                                        /* sense_len */ SSD_FULL_SIZE,
                                        /* timeout */ 30000);
+                       /* Use READ CD command for audio tracks. */
+                       if (softc->params.blksize == 2352) {
+                               start_ccb->csio.cdb_io.cdb_bytes[0] = READ_CD;
+                               start_ccb->csio.cdb_io.cdb_bytes[9] = 0xf8;
+                               start_ccb->csio.cdb_io.cdb_bytes[10] = 0;
+                               start_ccb->csio.cdb_io.cdb_bytes[11] = 0;
+                               start_ccb->csio.cdb_len = 12;
+                       }
                        start_ccb->ccb_h.ccb_state = CD_CCB_BUFFER_IO;
 
                        
@@ -2676,6 +2684,16 @@ cdioctl(struct disk *dp, u_long cmd, voi
                error = cdsetspeed(periph, CDR_MAX_SPEED, *(u_int32_t *)addr);
                cam_periph_unlock(periph);
                break;
+       case CDRIOCGETBLOCKSIZE:
+               *(int *)addr = softc->params.blksize;
+               break;
+       case CDRIOCSETBLOCKSIZE:
+               if (*(int *)addr <= 0) {
+                       error = EINVAL;
+                       break;
+               }
+               softc->disk->d_sectorsize = softc->params.blksize = *(int 
*)addr;
+               break;
        case DVDIOCSENDKEY:
        case DVDIOCREPORTKEY: {
                struct dvd_authinfo *authinfo;
@@ -2879,6 +2897,13 @@ cdcheckmedia(struct cam_periph *periph)
 
        softc->flags |= CD_FLAG_VALID_TOC;
 
+       /* If the first track is audio, correct sector size. */
+       if ((softc->toc.entries[0].control & 4) == 0) {
+               softc->disk->d_sectorsize = softc->params.blksize = 2352;
+               softc->disk->d_mediasize =
+                   (off_t)softc->params.blksize * softc->params.disksize;
+       }
+
 bailout:
 
        /*
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to