⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 scsi_mmc.h

📁 linux下的MPEG1
💻 H
字号:
/*    $Id: scsi_mmc.h,v 1.1 2005/01/01 02:43:58 rockyb Exp $    Copyright (C) 2003, 2004 Rocky Bernstein <rocky@panix.com>    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*//*!   \file scsi_mmc.h    \brief Common definitions for SCSI MMC (Multi-Media Commands).*/#ifndef __SCSI_MMC_H__#define __SCSI_MMC_H__#include <cdio/cdio.h>#include <cdio/types.h>#include <cdio/dvd.h>/*! The generic packet command opcodes for CD/DVD Logical Units. */#define CDIO_MMC_GPCMD_INQUIRY 	             0x12#define CDIO_MMC_GPCMD_MODE_SELECT_6	     0x15#define CDIO_MMC_GPCMD_MODE_SENSE 	     0x1a#define CDIO_MMC_GPCMD_START_STOP            0x1b#define CDIO_MMC_GPCMD_ALLOW_MEDIUM_REMOVAL  0x1e#define CDIO_MMC_GPCMD_READ_10	             0x28/*!  	Group 2 Commands  */#define CDIO_MMC_GPCMD_READ_SUBCHANNEL	     0x42#define CDIO_MMC_GPCMD_READ_TOC              0x43#define CDIO_MMC_GPCMD_READ_HEADER           0x44#define CDIO_MMC_GPCMD_PLAY_AUDIO_10         0x45#define CDIO_MMC_GPCMD_GET_CONFIGURATION     0x46#define CDIO_MMC_GPCMD_PLAY_AUDIO_MSF        0x47#define CDIO_MMC_GPCMD_PLAY_AUDIO_TI         0x48#define CDIO_MMC_GPCMD_PLAY_TRACK_REL_10     0x49#define CDIO_MMC_GPCMD_PAUSE_RESUME          0x4b#define CDIO_MMC_GPCMD_READ_DISC_INFO	     0x51#define CDIO_MMC_GPCMD_MODE_SELECT	     0x55#define CDIO_MMC_GPCMD_MODE_SENSE_10	     0x5a/*! 	Group 5 Commands */#define CDIO_MMC_GPCMD_PLAY_AUDIO_12	     0xa5#define CDIO_MMC_GPCMD_READ_12	             0xa8#define CDIO_MMC_GPCMD_PLAY_TRACK_REL_12     0xa9#define CDIO_MMC_GPCMD_READ_DVD_STRUCTURE    0xad#define CDIO_MMC_GPCMD_READ_CD	             0xbe#define CDIO_MMC_GPCMD_READ_MSF	             0xb9/*! 	Group 6 Commands */#define	CDIO_MMC_GPCMD_CD_PLAYBACK_STATUS    0xc4 /**< SONY unique command */#define	CDIO_MMC_GPCMD_PLAYBACK_CONTROL      0xc9 /**< SONY unique command */#define	CDIO_MMC_GPCMD_READ_CDDA	     0xd8 /**< Vendor unique command */#define	CDIO_MMC_GPCMD_READ_CDXA	     0xdb /**< Vendor unique command */#define	CDIO_MMC_GPCMD_READ_ALL_SUBCODES     0xdf /**< Vendor unique command *//*! Level values that can go into READ_CD */#define CDIO_MMC_READ_TYPE_ANY   0  /**< All types */#define CDIO_MMC_READ_TYPE_CDDA  1  /**< Only CD-DA sectors */#define CDIO_MMC_READ_TYPE_MODE1 2  /**< mode1 sectors (user data = 2048) */#define CDIO_MMC_READ_TYPE_MODE2 3  /**< mode2 sectors form1 or form2 */#define CDIO_MMC_READ_TYPE_M2F1  4  /**< mode2 sectors form1 */#define CDIO_MMC_READ_TYPE_M2F2  5  /**< mode2 sectors form2 *//*! Format values for READ_TOC */#define CDIO_MMC_READTOC_FMT_TOC      0#define CDIO_MMC_READTOC_FMT_SESSION  1  #define CDIO_MMC_READTOC_FMT_FULTOC   2  #define CDIO_MMC_READTOC_FMT_PMA      3  /**< Q subcode data */#define CDIO_MMC_READTOC_FMT_ATIP     4  /**< includes media type */#define CDIO_MMC_READTOC_FMT_CDTEXT   5  /**< CD-TEXT info  *//*! Page codes for MODE SENSE and MODE SET. */#define CDIO_MMC_R_W_ERROR_PAGE		0x01#define CDIO_MMC_WRITE_PARMS_PAGE	0x05#define CDIO_MMC_AUDIO_CTL_PAGE		0x0e#define CDIO_MMC_CDR_PARMS_PAGE		0x0d#define CDIO_MMC_POWER_PAGE		0x1a#define CDIO_MMC_FAULT_FAIL_PAGE	0x1c#define CDIO_MMC_TO_PROTECT_PAGE	0x1d#define CDIO_MMC_CAPABILITIES_PAGE	0x2a#define CDIO_MMC_ALL_PAGES		0x3f/*! Return type codes for GET_CONFIGURATION. */#define CDIO_MMC_GET_CONF_ALL_FEATURES     0  /**< all features without regard					           to currency. */#define CDIO_MMC_GET_CONF_CURRENT_FEATURES 1  /**< features which are currently					           in effect (e.g. based on					           medium inserted). */#define CDIO_MMC_GET_CONF_NAMED_FEATURE    2  /**< just the feature named in					           the GET_CONFIGURATION 					           cdb. *//*! FEATURE codes used in GET CONFIGURATION. */#define CDIO_MMC_FEATURE_PROFILE_LIST     0x000 /**< Profile List Feature */#define CDIO_MMC_FEATURE_CORE             0x001 #define CDIO_MMC_FEATURE_REMOVABLE_MEDIUM 0x002 /**< Removable Medium						   Feature */#define CDIO_MMC_FEATURE_WRITE_PROTECT    0x003 /**< Write Protect						   Feature */#define CDIO_MMC_FEATURE_RANDOM_READABLE  0x010 /**< Random Readable						   Feature */#define CDIO_MMC_FEATURE_MULTI_READ       0x01D /**< Multi-Read						   Feature */#define CDIO_MMC_FEATURE_CD_READ          0x01E /**< CD Read						   Feature */#define CDIO_MMC_FEATURE_DVD_READ         0x01F /**< DVD Read						   Feature */#define CDIO_MMC_FEATURE_RANDOM_WRITABLE  0x020 /**< Random Writable						   Feature */#define CDIO_MMC_FEATURE_INCR_WRITE       0x021 /**< Incremental						   Streaming Writable						   Feature */#define CDIO_MMC_FEATURE_SECTOR_ERASE     0x022 /**< Sector Erasable						   Feature */#define CDIO_MMC_FEATURE_FORMATABLE       0x023 /**< Formattable						   Feature */#define CDIO_MMC_FEATURE_DEFECT_MGMT      0x024 /**< Management						   Ability of the						   Logical Unit/media						   system to provide						   an apparently						   defect-free						   space.*/#define CDIO_MMC_FEATURE_WRITE_ONCE       0x025 /**< Write Once						   Feature */#define CDIO_MMC_FEATURE_RESTRICT_OVERW   0x026 /**< Restricted						   Overwrite						   Feature */#define CDIO_MMC_FEATURE_CD_RW_CAV        0x027 /**< CD-RW CAV Write						   Feature */#define CDIO_MMC_FEATURE_MRW              0x028 /**< MRW Feature */#define CDIO_MMC_FEATURE_DVD_PRW          0x02A /**< DVD+RW Feature */#define CDIO_MMC_FEATURE_DVD_PR           0x02B /**< DVD+R Feature */#define CDIO_MMC_FEATURE_CD_TAO           0x02D#define CDIO_MMC_FEATURE_CD_SAO           0x02E#define CDIO_MMC_FEATURE_POWER_MGMT       0x100 /**< Initiator and						   device directed						   power management */#define CDIO_MMC_FEATURE_CDDA_EXT_PLAY    0x103 /**< Ability to play						   audio CDs via the						   Logical Unit s own						   analog output */#define CDIO_MMC_FEATURE_MCODE_UPGRADE    0x104 /* Ability for the						   device to accept						   new microcode via						   the interface */#define CDIO_MMC_FEATURE_TIME_OUT         0x105 /**< Ability to						   respond to all						   commands within a						   specific time */#define CDIO_MMC_FEATURE_DVD_CSS          0x106 /**< Ability to						   perform DVD						   CSS/CPPM						   authentication and						   RPC */#define CDIO_MMC_FEATURE_RT_STREAMING     0x107 /**< Ability to read						   and write using						   Initiator requested						   performance						   parameters						   */#define CDIO_MMC_FEATURE_LU_SN            0x108 /**< The Logical Unit						   has a unique						   identifier. */#define CDIO_MMC_FEATURE_FIRMWARE_DATE    0x1FF /**< Firmware creation						   date report */				/*! Profile codes used in GET_CONFIGURATION - PROFILE LIST. */#define CDIO_MMC_FEATURE_PROF_NON_REMOVABLE 0x0001 /**< Re-writable						     disk, capable of						     changing						     behavior */#define CDIO_MMC_FEATURE_PROF_REMOVABLE     0x0002 /**< disk						      Re-writable;						      with removable						      media */#define CDIO_MMC_FEATURE_PROF_MO_ERASABLE   0x0003 /**< Erasable						      Magneto-Optical						      disk with sector						      erase						      capability */#define CDIO_MMC_FEATURE_PROF_MO_WRITE_ONCE 0x0004 /**< Write Once						      Magneto-Optical						      write once */#define CDIO_MMC_FEATURE_PROF_AS_MO         0x0005 /**< Advance						      Storage						      Magneto-Optical */#define CDIO_MMC_FEATURE_PROF_CD_ROM        0x0008 /**< Read only						      Compact Disc						      capable */#define CDIO_MMC_FEATURE_PROF_CD_R          0x0009 /**< Write once						      Compact Disc						      capable */#define CDIO_MMC_FEATURE_PROF_CD_RW         0x000A /**< CD-RW						      Re-writable						      Compact Disc						      capable */#define CDIO_MMC_FEATURE_PROF_DVD_ROM       0x0010 /**< Read only						      DVD */#define CDIO_MMC_FEATURE_PROF_DVD_R_SEQ     0x0011 /**< Re-recordable						      DVD using						      Sequential						      recording */#define CDIO_MMC_FEATURE_PROF_DVD_RAM       0x0012 /**< Re-writable						      DVD */#define CDIO_MMC_FEATURE_PROF_DVD_RW_RO     0x0013 /**< Re-recordable						      DVD using						      Restricted						      Overwrite */#define CDIO_MMC_FEATURE_PROF_DVD_RW_SEQ    0x0014 /**< Re-recordable						      DVD using						      Sequential						      recording */#define CDIO_MMC_FEATURE_PROF_DVD_PRW       0x001A /**< DVD+RW - DVD						      ReWritable */#define CDIO_MMC_FEATURE_PROF_DVD_PR        0x001B /**< DVD+R - DVD						      Recordable */#define CDIO_MMC_FEATURE_PROF_DDCD_ROM      0x0020 /**< Read only						      DDCD */#define CDIO_MMC_FEATURE_PROF_DDCD_R        0x0021 /**< DDCD-R Write						      only DDCD */#define CDIO_MMC_FEATURE_PROF_DDCD_RW       0x0022 /**< Re-Write only						      DDCD */#define CDIO_MMC_FEATURE_PROF_NON_CONFORM   0xFFFF /**< The Logical						      Unit does not						      conform to any						      Profile. *//*! This is listed as optional in ATAPI 2.6, but is (curiously)   missing from Mt. Fuji, Table 57.  It _is_ mentioned in Mt. Fuji  Table 377 as an MMC command for SCSi devices though...  Most ATAPI  drives support it. */#define CDIO_MMC_GPCMD_SET_SPEED	0xbb/*! The largest Command Descriptor Buffer (CDB) size.    The possible sizes are 6, 10, and 12 bytes. */#define MAX_CDB_LEN 12/*! \brief A Command Descriptor Buffer (CDB) used in sending SCSI MMC     commands. */typedef struct scsi_mmc_cdb {  uint8_t field[MAX_CDB_LEN];} scsi_mmc_cdb_t;/*! \brief Format of header block in data returned from a SCSI-MMC    GET_CONFIGURATION command. */typedef struct scsi_mmc_feature_list_header {  unsigned char length_msb;  unsigned char length_1sb;  unsigned char length_2sb;  unsigned char length_lsb;  unsigned char reserved1;  unsigned char reserved2;  unsigned char profile_msb;  unsigned char profile_lsb;} scs_mmc_feature_list_header_t;/*! An enumeration indicating whether a SCSI MMC command is sending    data or getting data. */typedef enum scsi_mmc_direction {  SCSI_MMC_DATA_READ,  SCSI_MMC_DATA_WRITE} scsi_mmc_direction_t;#define CDIO_MMC_SET_COMMAND(cdb, command) \  cdb[0] = command#define CDIO_MMC_SET_READ_TYPE(cdb, sector_type) \  cdb[1] = (sector_type << 2)#define CDIO_MMC_GET_LEN16(p) \  (p[0]<<8) + p[1]#define CDIO_MMC_GET_LEN32(p) \  (p[0] << 24) + (p[1] << 16) + (p[2] << 8) + p[3];#define CDIO_MMC_SET_LEN16(cdb, pos, len)  \  cdb[pos  ] = (len >>  8) & 0xff; \  cdb[pos+1] = (len      ) & 0xff#define CDIO_MMC_SET_READ_LBA(cdb, lba) \  cdb[2] = (lba >> 24) & 0xff; \  cdb[3] = (lba >> 16) & 0xff; \  cdb[4] = (lba >>  8) & 0xff; \  cdb[5] = (lba      ) & 0xff#define CDIO_MMC_SET_START_TRACK(cdb, command) \  cdb[6] = command#define CDIO_MMC_SET_READ_LENGTH24(cdb, len) \  cdb[6] = (len >> 16) & 0xff; \  cdb[7] = (len >>  8) & 0xff; \  cdb[8] = (len      ) & 0xff#define CDIO_MMC_SET_READ_LENGTH16(cdb, len) \  CDIO_MMC_SET_LEN16(cdb, 7, len)#define CDIO_MMC_SET_READ_LENGTH8(cdb, len) \  cdb[8] = (len      ) & 0xff#define CDIO_MMC_MCSB_ALL_HEADERS 0x78#define CDIO_MMC_SET_MAIN_CHANNEL_SELECTION_BITS(cdb, val) \  cdb[9] = val;/*!    Return the number of length in bytes of the Command Descriptor  buffer (CDB) for a given SCSI MMC command. The length will be   either 6, 10, or 12. */uint8_t scsi_mmc_get_cmd_len(uint8_t scsi_cmd);/*!  Run a SCSI MMC command.    cdio	        CD structure set by cdio_open().  i_timeout_ms  time in milliseconds we will wait for the command                to complete.   p_cdb	        CDB bytes. All values that are needed should be set on                 input. We'll figure out what the right CDB length should be.  e_direction	direction the transfer is to go.  i_buf	        Size of buffer  p_buf	        Buffer for data, both sending and receiving.  Returns 0 if command completed successfully. */int scsi_mmc_run_cmd( const CdIo *p_cdio, unsigned int i_timeout_ms,		      const scsi_mmc_cdb_t *p_cdb,		      scsi_mmc_direction_t e_direction, unsigned int i_buf, 		      /*in/out*/ void *p_buf );/*! * Eject using SCSI MMC commands. Return 0 if successful. */int scsi_mmc_eject_media( const CdIo *p_cdio);/*! Packet driver to read mode2 sectors.    Can read only up to 25 blocks.*/int scsi_mmc_read_sectors ( const CdIo *p_cdio, void *p_buf, lba_t lba, 			    int sector_type, unsigned int nblocks);/*!  Set the block size for subsequest read requests, via a SCSI MMC   MODE_SELECT 6 command. */int scsi_mmc_set_blocksize ( const CdIo *p_cdio, unsigned int bsize);/*!  Return the the kind of drive capabilities of device. */void scsi_mmc_get_drive_cap (const CdIo *p_cdio,			     /*out*/ cdio_drive_read_cap_t  *p_read_cap,			     /*out*/ cdio_drive_write_cap_t *p_write_cap,			     /*out*/ cdio_drive_misc_cap_t  *p_misc_cap);/*!   Get the DVD type associated with cd object.*/discmode_t scsi_mmc_get_dvd_struct_physical ( const CdIo *p_cdio, 					      cdio_dvd_struct_t *s);/*!   Get the CD-ROM hardware info via a SCSI MMC INQUIRY command.  False is returned if we had an error getting the information.*/bool scsi_mmc_get_hwinfo ( const CdIo *p_cdio, 			   /* out*/ cdio_hwinfo_t *p_hw_info );/*!  Get the media catalog number (MCN) from the CD via MMC.    @return the media catalog number r NULL if there is none or we  don't have the ability to get it.    Note: string is malloc'd so caller has to free() the returned  string when done with it.  */char *scsi_mmc_get_mcn ( const CdIo *p_cdio );#endif /* __SCSI_MMC_H__ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -