Home | History | Annotate | Line # | Download | only in scsipi
scsipi_cd.h revision 1.10.6.2
      1  1.10.6.2     yamt /*	$NetBSD: scsipi_cd.h,v 1.10.6.2 2006/12/30 20:49:34 yamt Exp $	*/
      2       1.2   bouyer 
      3       1.2   bouyer /*
      4       1.2   bouyer  * Written by Julian Elischer (julian (at) tfs.com)
      5       1.2   bouyer  * for TRW Financial Systems.
      6       1.2   bouyer  *
      7       1.2   bouyer  * TRW Financial Systems, in accordance with their agreement with Carnegie
      8       1.2   bouyer  * Mellon University, makes this software available to CMU to distribute
      9       1.3    enami  * or use in any manner that they see fit as long as this message is kept with
     10       1.2   bouyer  * the software. For this reason TFS also grants any other persons or
     11       1.2   bouyer  * organisations permission to use or modify this software.
     12       1.2   bouyer  *
     13       1.2   bouyer  * TFS supplies this software to be publicly redistributed
     14       1.2   bouyer  * on the understanding that TFS is not responsible for the correct
     15       1.2   bouyer  * functioning of this software in any circumstances.
     16       1.2   bouyer  *
     17       1.2   bouyer  * Ported to run under 386BSD by Julian Elischer (julian (at) tfs.com) Sept 1992
     18       1.2   bouyer  */
     19       1.4    enami 
     20       1.2   bouyer /*
     21       1.2   bouyer  *	Define two bits always in the same place in byte 2 (flag byte)
     22       1.2   bouyer  */
     23       1.2   bouyer #define	CD_RELADDR	0x01
     24       1.2   bouyer #define	CD_MSF		0x02
     25       1.2   bouyer 
     26       1.2   bouyer /*
     27       1.2   bouyer  * SCSI and SCSI-like command format
     28       1.2   bouyer  */
     29       1.2   bouyer 
     30       1.7  mycroft #define	LOAD_UNLOAD	0xa6
     31       1.7  mycroft struct scsipi_load_unload {
     32      1.10  reinoud 	u_int8_t opcode;
     33      1.10  reinoud 	u_int8_t unused1[3];
     34      1.10  reinoud 	u_int8_t options;
     35      1.10  reinoud 	u_int8_t unused2[3];
     36      1.10  reinoud 	u_int8_t slot;
     37      1.10  reinoud 	u_int8_t unused3[3];
     38  1.10.6.2     yamt } __attribute__((__packed__));
     39       1.7  mycroft 
     40       1.2   bouyer #define PAUSE			0x4b	/* cdrom pause in 'play audio' mode */
     41       1.2   bouyer struct scsipi_pause {
     42      1.10  reinoud 	u_int8_t opcode;
     43      1.10  reinoud 	u_int8_t byte2;
     44      1.10  reinoud 	u_int8_t unused[6];
     45      1.10  reinoud 	u_int8_t resume;
     46      1.10  reinoud 	u_int8_t control;
     47  1.10.6.2     yamt } __attribute__((__packed__));
     48       1.2   bouyer #define	PA_PAUSE	0x00
     49       1.2   bouyer #define PA_RESUME	0x01
     50       1.2   bouyer 
     51       1.2   bouyer #define PLAY_MSF		0x47	/* cdrom play Min,Sec,Frames mode */
     52       1.2   bouyer struct scsipi_play_msf {
     53      1.10  reinoud 	u_int8_t opcode;
     54      1.10  reinoud 	u_int8_t byte2;
     55      1.10  reinoud 	u_int8_t unused;
     56      1.10  reinoud 	u_int8_t start_m;
     57      1.10  reinoud 	u_int8_t start_s;
     58      1.10  reinoud 	u_int8_t start_f;
     59      1.10  reinoud 	u_int8_t end_m;
     60      1.10  reinoud 	u_int8_t end_s;
     61      1.10  reinoud 	u_int8_t end_f;
     62      1.10  reinoud 	u_int8_t control;
     63  1.10.6.2     yamt } __attribute__((__packed__));
     64       1.2   bouyer 
     65       1.2   bouyer #define PLAY			0x45	/* cdrom play  'play audio' mode */
     66       1.2   bouyer struct scsipi_play {
     67      1.10  reinoud 	u_int8_t opcode;
     68      1.10  reinoud 	u_int8_t byte2;
     69      1.10  reinoud 	u_int8_t blk_addr[4];
     70      1.10  reinoud 	u_int8_t unused;
     71      1.10  reinoud 	u_int8_t xfer_len[2];
     72      1.10  reinoud 	u_int8_t control;
     73  1.10.6.2     yamt } __attribute__((__packed__));
     74       1.2   bouyer 
     75       1.2   bouyer #define READ_HEADER		0x44	/* cdrom read header */
     76       1.2   bouyer struct scsipi_read_header {
     77      1.10  reinoud 	u_int8_t opcode;
     78      1.10  reinoud 	u_int8_t byte2;
     79      1.10  reinoud 	u_int8_t blk_addr[4];
     80      1.10  reinoud 	u_int8_t unused;
     81      1.10  reinoud 	u_int8_t data_len[2];
     82      1.10  reinoud 	u_int8_t control;
     83  1.10.6.2     yamt } __attribute__((__packed__));
     84       1.2   bouyer 
     85       1.2   bouyer #define READ_SUBCHANNEL		0x42	/* cdrom read Subchannel */
     86       1.2   bouyer struct scsipi_read_subchannel {
     87      1.10  reinoud 	u_int8_t opcode;
     88      1.10  reinoud 	u_int8_t byte2;
     89      1.10  reinoud 	u_int8_t byte3;
     90       1.2   bouyer #define	SRS_SUBQ	0x40
     91      1.10  reinoud 	u_int8_t subchan_format;
     92      1.10  reinoud 	u_int8_t unused[2];
     93      1.10  reinoud 	u_int8_t track;
     94      1.10  reinoud 	u_int8_t data_len[2];
     95      1.10  reinoud 	u_int8_t control;
     96  1.10.6.2     yamt } __attribute__((__packed__));
     97       1.2   bouyer 
     98       1.2   bouyer #define READ_TOC		0x43	/* cdrom read TOC */
     99       1.2   bouyer struct scsipi_read_toc {
    100      1.10  reinoud 	u_int8_t opcode;
    101      1.10  reinoud 	u_int8_t addr_mode;
    102      1.10  reinoud 	u_int8_t resp_format;
    103      1.10  reinoud 	u_int8_t unused[3];
    104  1.10.6.1     yamt 	u_int8_t from_track;		/* session nr in format 2 */
    105      1.10  reinoud 	u_int8_t data_len[2];
    106      1.10  reinoud 	u_int8_t control;
    107  1.10.6.2     yamt } __attribute__((__packed__));
    108       1.2   bouyer 
    109  1.10.6.1     yamt struct scsipi_toc_header {
    110  1.10.6.1     yamt 	uint8_t	 length[2];
    111  1.10.6.1     yamt 	uint8_t  first;			/* track or session */
    112  1.10.6.1     yamt 	uint8_t  last;
    113  1.10.6.2     yamt } __attribute__((__packed__));
    114  1.10.6.1     yamt 
    115  1.10.6.1     yamt /* read TOC form 0 result entries */
    116  1.10.6.1     yamt struct scsipi_toc_formatted {
    117  1.10.6.1     yamt 	uint8_t  unused1;
    118  1.10.6.1     yamt 	uint8_t  adrcontol;
    119  1.10.6.1     yamt 	uint8_t  tracknr;
    120  1.10.6.1     yamt 	uint8_t  unused2;
    121  1.10.6.1     yamt 	uint8_t	 msf_lba[4];		/* union msf_lba from cdio.h */
    122  1.10.6.2     yamt } __attribute__((__packed__));
    123  1.10.6.1     yamt 
    124  1.10.6.1     yamt /* read TOC form 1 result entries */
    125  1.10.6.1     yamt struct scsipi_toc_msinfo {
    126  1.10.6.1     yamt 	uint8_t  unused1;
    127  1.10.6.1     yamt 	uint8_t  adrcontol;
    128  1.10.6.1     yamt 	uint8_t  tracknr;		/* first track last compl. session */
    129  1.10.6.1     yamt 	uint8_t  unused2;
    130  1.10.6.1     yamt 	uint8_t	 msf_lba[4];		/* union msf_lba from cdio.h */
    131  1.10.6.2     yamt } __attribute__((__packed__));
    132  1.10.6.1     yamt 
    133  1.10.6.1     yamt /* read TOC form 2 result entries */
    134  1.10.6.1     yamt struct scsipi_toc_rawtoc {
    135  1.10.6.1     yamt 	uint8_t  sessionnr;
    136  1.10.6.1     yamt 	uint8_t  adrcontrol;
    137  1.10.6.1     yamt 	uint8_t  tno;
    138  1.10.6.1     yamt 	uint8_t  point;
    139  1.10.6.1     yamt 	uint8_t  min;
    140  1.10.6.1     yamt 	uint8_t  sec;
    141  1.10.6.1     yamt 	uint8_t  frame;
    142  1.10.6.1     yamt 	uint8_t  zero;			/* zero/unused */
    143  1.10.6.1     yamt 	uint8_t  pmin;
    144  1.10.6.1     yamt 	uint8_t  psec;
    145  1.10.6.1     yamt 	uint8_t  pframe;
    146  1.10.6.2     yamt } __attribute__((__packed__));
    147  1.10.6.1     yamt 
    148  1.10.6.1     yamt /* read TOC form 3, 4 and 5 obmitted yet */
    149  1.10.6.1     yamt 
    150  1.10.6.1     yamt #define GET_CONFIGURATION	0x46	/* Get configuration */
    151  1.10.6.1     yamt #define GET_CONF_NO_FEATURES_LEN 8
    152  1.10.6.1     yamt struct scsipi_get_configuration {
    153  1.10.6.1     yamt 	uint8_t  opcode;
    154  1.10.6.1     yamt 	uint8_t  request_type;
    155  1.10.6.1     yamt 	uint8_t  start_at_feature[2];
    156  1.10.6.1     yamt 	uint8_t  unused[3];
    157  1.10.6.1     yamt 	uint8_t  data_len[2];
    158  1.10.6.1     yamt 	uint8_t  control;
    159  1.10.6.2     yamt } __attribute__((__packed__));
    160  1.10.6.1     yamt 
    161  1.10.6.1     yamt struct scsipi_get_conf_data {
    162  1.10.6.1     yamt 	uint8_t  data_len[4];
    163  1.10.6.1     yamt 	uint8_t  unused[2];
    164  1.10.6.1     yamt 	uint8_t  mmc_profile[2];	/* current mmc profile for disk */
    165  1.10.6.1     yamt 	uint8_t  feature_desc[1];	/* feature descriptors follow	*/
    166  1.10.6.2     yamt } __attribute__((__packed__));
    167  1.10.6.1     yamt 
    168  1.10.6.1     yamt struct scsipi_get_conf_feature {	/* feature descriptor */
    169  1.10.6.1     yamt 	uint8_t  featurecode[2];
    170  1.10.6.1     yamt 	uint8_t  flags;
    171  1.10.6.1     yamt 	uint8_t  additional_length;	/* length of feature dependent  */
    172  1.10.6.1     yamt 	uint8_t  feature_dependent[256];
    173  1.10.6.2     yamt } __attribute__((__packed__));
    174  1.10.6.1     yamt #define FEATUREFLAG_CURRENT    1
    175  1.10.6.1     yamt #define FEATUREFLAG_PERSISTENT 2
    176  1.10.6.1     yamt 
    177  1.10.6.1     yamt 
    178  1.10.6.1     yamt #define READ_DISCINFO 0x51
    179  1.10.6.1     yamt struct scsipi_read_discinfo {
    180  1.10.6.1     yamt 	uint8_t  opcode;
    181  1.10.6.1     yamt 	uint8_t  unused[6];
    182  1.10.6.1     yamt 	uint8_t  data_len[2];
    183  1.10.6.1     yamt 	uint8_t  control;
    184  1.10.6.2     yamt } __attribute__((__packed__));
    185  1.10.6.1     yamt 
    186  1.10.6.1     yamt #define READ_DISCINFO_SMALLSIZE  12
    187  1.10.6.1     yamt #define READ_DISCINFO_BIGSIZE    34	/* + entries */
    188  1.10.6.1     yamt struct scsipi_read_discinfo_data {
    189  1.10.6.1     yamt 	uint8_t  data_len[2];
    190  1.10.6.1     yamt 	uint8_t  disc_state;
    191  1.10.6.1     yamt 	uint8_t  first_track;
    192  1.10.6.1     yamt 	uint8_t  num_sessions_lsb;
    193  1.10.6.1     yamt 	uint8_t  first_track_last_session_lsb;
    194  1.10.6.1     yamt 	uint8_t  last_track_last_session_lsb;
    195  1.10.6.1     yamt 	uint8_t  disc_state2;
    196  1.10.6.1     yamt 	uint8_t  disc_type;
    197  1.10.6.1     yamt 	uint8_t  num_sessions_msb;
    198  1.10.6.1     yamt 	uint8_t  first_track_last_session_msb;
    199  1.10.6.1     yamt 	uint8_t  last_track_last_session_msb;
    200  1.10.6.1     yamt 	uint8_t  discid[4];
    201  1.10.6.1     yamt 	uint8_t  last_session_leadin_hmsf[4];
    202  1.10.6.1     yamt 	uint8_t  last_possible_start_leadout_hmsf[4];
    203  1.10.6.1     yamt 	uint8_t  disc_bar_code[8];
    204  1.10.6.1     yamt 	uint8_t  application_code;
    205  1.10.6.1     yamt 	uint8_t  num_opc_table_entries;
    206  1.10.6.1     yamt 	uint8_t  opc_table_entries[1];	/* opc table entries follow	*/
    207  1.10.6.2     yamt } __attribute__((__packed__));
    208  1.10.6.1     yamt 
    209  1.10.6.1     yamt 
    210  1.10.6.1     yamt #define READ_TRACKINFO 0x52
    211  1.10.6.1     yamt struct scsipi_read_trackinfo {
    212  1.10.6.1     yamt 	uint8_t  opcode;
    213  1.10.6.1     yamt 	uint8_t  addr_type;
    214  1.10.6.1     yamt 	uint8_t  address[4];
    215  1.10.6.1     yamt 	uint8_t  nothing;
    216  1.10.6.1     yamt 	uint8_t  data_len[2];
    217  1.10.6.1     yamt 	uint8_t  control;
    218  1.10.6.2     yamt } __attribute__((__packed__));
    219  1.10.6.1     yamt #define READ_TRACKINFO_ADDR_LBA    0
    220  1.10.6.1     yamt #define READ_TRACKINFO_ADDR_TRACK  1
    221  1.10.6.1     yamt #define READ_TRACKINFO_ADDR_SESS   2
    222  1.10.6.1     yamt 
    223  1.10.6.1     yamt struct scsipi_read_trackinfo_data {
    224  1.10.6.1     yamt 	uint8_t  data_len[2];
    225  1.10.6.1     yamt 	uint8_t  track_lsb;
    226  1.10.6.1     yamt 	uint8_t  session_lsb;
    227  1.10.6.1     yamt 	uint8_t  unused1;
    228  1.10.6.1     yamt 	uint8_t  track_info_1;
    229  1.10.6.1     yamt 	uint8_t  track_info_2;
    230  1.10.6.1     yamt 	uint8_t  data_valid;
    231  1.10.6.1     yamt 	uint8_t  track_start[4];
    232  1.10.6.1     yamt 	uint8_t  next_writable[4];
    233  1.10.6.1     yamt 	uint8_t  free_blocks[4];
    234  1.10.6.1     yamt 	uint8_t  packet_size[4];
    235  1.10.6.1     yamt 	uint8_t  track_size[4];
    236  1.10.6.1     yamt 	uint8_t  last_recorded[4];
    237  1.10.6.1     yamt 	uint8_t  track_msb;
    238  1.10.6.1     yamt 	uint8_t  session_msb;
    239  1.10.6.1     yamt 	uint8_t  unused2[2];
    240  1.10.6.2     yamt } __attribute__((__packed__));
    241  1.10.6.1     yamt #define READ_TRACKINFO_RETURNSIZE 36
    242  1.10.6.1     yamt 
    243  1.10.6.1     yamt 
    244       1.2   bouyer #define READ_CD_CAPACITY	0x25	/* slightly different from disk */
    245       1.2   bouyer struct scsipi_read_cd_capacity {
    246      1.10  reinoud 	u_int8_t opcode;
    247      1.10  reinoud 	u_int8_t byte2;
    248      1.10  reinoud 	u_int8_t addr[4];
    249      1.10  reinoud 	u_int8_t unused[3];
    250      1.10  reinoud 	u_int8_t control;
    251  1.10.6.2     yamt } __attribute__((__packed__));
    252       1.2   bouyer 
    253       1.2   bouyer struct scsipi_read_cd_cap_data {
    254      1.10  reinoud 	u_int8_t addr[4];
    255      1.10  reinoud 	u_int8_t length[4];
    256  1.10.6.2     yamt } __attribute__((__packed__));
    257       1.2   bouyer 
    258  1.10.6.1     yamt 
    259       1.2   bouyer /* mod pages common to scsi and atapi */
    260       1.2   bouyer struct cd_audio_page {
    261      1.10  reinoud 	u_int8_t pg_code;
    262       1.3    enami #define		AUDIO_PAGE	0x0e
    263      1.10  reinoud 	u_int8_t pg_length;
    264      1.10  reinoud 	u_int8_t flags;
    265       1.2   bouyer #define		CD_PA_SOTC	0x02
    266       1.2   bouyer #define		CD_PA_IMMED	0x04
    267      1.10  reinoud 	u_int8_t unused[2];
    268      1.10  reinoud 	u_int8_t format_lba; /* valid only for SCSI CDs */
    269       1.3    enami #define		CD_PA_FORMAT_LBA 0x0F
    270       1.2   bouyer #define		CD_PA_APR_VALID	0x80
    271      1.10  reinoud 	u_int8_t lb_per_sec[2];
    272       1.3    enami 	struct port_control {
    273      1.10  reinoud 		u_int8_t channels;
    274       1.2   bouyer #define	CHANNEL 0x0F
    275       1.2   bouyer #define	CHANNEL_0 1
    276       1.2   bouyer #define	CHANNEL_1 2
    277       1.2   bouyer #define	CHANNEL_2 4
    278       1.2   bouyer #define	CHANNEL_3 8
    279       1.3    enami #define		LEFT_CHANNEL	CHANNEL_0
    280       1.3    enami #define		RIGHT_CHANNEL	CHANNEL_1
    281       1.3    enami #define		MUTE_CHANNEL	0x0
    282       1.3    enami #define		BOTH_CHANNEL	LEFT_CHANNEL | RIGHT_CHANNEL
    283      1.10  reinoud 		u_int8_t volume;
    284       1.2   bouyer 	} port[4];
    285       1.2   bouyer #define	LEFT_PORT	0
    286       1.2   bouyer #define	RIGHT_PORT	1
    287       1.2   bouyer };
    288