Home | History | Annotate | Line # | Download | only in scsipi
scsipi_cd.h revision 1.20.4.1
      1  1.20.4.1       snj /*	$NetBSD: scsipi_cd.h,v 1.20.4.1 2009/04/08 23:02:15 snj 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.18     perry } __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.18     perry } __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.18     perry } __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.18     perry } __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.18     perry } __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.18     perry } __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.12   reinoud 	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.18     perry } __packed;
    108       1.2    bouyer 
    109      1.12   reinoud struct scsipi_toc_header {
    110      1.12   reinoud 	uint8_t	 length[2];
    111      1.12   reinoud 	uint8_t  first;			/* track or session */
    112      1.12   reinoud 	uint8_t  last;
    113      1.18     perry } __packed;
    114      1.12   reinoud 
    115      1.12   reinoud /* read TOC form 0 result entries */
    116      1.12   reinoud struct scsipi_toc_formatted {
    117      1.12   reinoud 	uint8_t  unused1;
    118  1.20.4.1       snj 	uint8_t  adrcontrol;
    119      1.12   reinoud 	uint8_t  tracknr;
    120      1.12   reinoud 	uint8_t  unused2;
    121      1.12   reinoud 	uint8_t	 msf_lba[4];		/* union msf_lba from cdio.h */
    122      1.18     perry } __packed;
    123      1.12   reinoud 
    124      1.12   reinoud /* read TOC form 1 result entries */
    125      1.12   reinoud struct scsipi_toc_msinfo {
    126      1.12   reinoud 	uint8_t  unused1;
    127      1.12   reinoud 	uint8_t  adrcontol;
    128      1.12   reinoud 	uint8_t  tracknr;		/* first track last compl. session */
    129      1.12   reinoud 	uint8_t  unused2;
    130      1.12   reinoud 	uint8_t	 msf_lba[4];		/* union msf_lba from cdio.h */
    131      1.18     perry } __packed;
    132      1.12   reinoud 
    133      1.12   reinoud /* read TOC form 2 result entries */
    134      1.12   reinoud struct scsipi_toc_rawtoc {
    135      1.12   reinoud 	uint8_t  sessionnr;
    136      1.12   reinoud 	uint8_t  adrcontrol;
    137      1.12   reinoud 	uint8_t  tno;
    138      1.12   reinoud 	uint8_t  point;
    139      1.12   reinoud 	uint8_t  min;
    140      1.12   reinoud 	uint8_t  sec;
    141      1.12   reinoud 	uint8_t  frame;
    142      1.12   reinoud 	uint8_t  zero;			/* zero/unused */
    143      1.12   reinoud 	uint8_t  pmin;
    144      1.12   reinoud 	uint8_t  psec;
    145      1.12   reinoud 	uint8_t  pframe;
    146      1.18     perry } __packed;
    147      1.12   reinoud 
    148      1.12   reinoud /* read TOC form 3, 4 and 5 obmitted yet */
    149      1.12   reinoud 
    150      1.12   reinoud #define GET_CONFIGURATION	0x46	/* Get configuration */
    151      1.12   reinoud #define GET_CONF_NO_FEATURES_LEN 8
    152      1.12   reinoud struct scsipi_get_configuration {
    153      1.12   reinoud 	uint8_t  opcode;
    154      1.12   reinoud 	uint8_t  request_type;
    155      1.12   reinoud 	uint8_t  start_at_feature[2];
    156      1.12   reinoud 	uint8_t  unused[3];
    157      1.12   reinoud 	uint8_t  data_len[2];
    158      1.12   reinoud 	uint8_t  control;
    159      1.18     perry } __packed;
    160      1.12   reinoud 
    161      1.12   reinoud struct scsipi_get_conf_data {
    162      1.12   reinoud 	uint8_t  data_len[4];
    163      1.12   reinoud 	uint8_t  unused[2];
    164      1.12   reinoud 	uint8_t  mmc_profile[2];	/* current mmc profile for disk */
    165      1.12   reinoud 	uint8_t  feature_desc[1];	/* feature descriptors follow	*/
    166      1.18     perry } __packed;
    167      1.12   reinoud 
    168      1.12   reinoud struct scsipi_get_conf_feature {	/* feature descriptor */
    169      1.12   reinoud 	uint8_t  featurecode[2];
    170      1.12   reinoud 	uint8_t  flags;
    171      1.12   reinoud 	uint8_t  additional_length;	/* length of feature dependent  */
    172      1.12   reinoud 	uint8_t  feature_dependent[256];
    173      1.18     perry } __packed;
    174      1.12   reinoud #define FEATUREFLAG_CURRENT    1
    175      1.12   reinoud #define FEATUREFLAG_PERSISTENT 2
    176      1.12   reinoud 
    177      1.12   reinoud 
    178      1.12   reinoud #define READ_DISCINFO 0x51
    179      1.12   reinoud struct scsipi_read_discinfo {
    180      1.12   reinoud 	uint8_t  opcode;
    181      1.12   reinoud 	uint8_t  unused[6];
    182      1.12   reinoud 	uint8_t  data_len[2];
    183      1.12   reinoud 	uint8_t  control;
    184      1.18     perry } __packed;
    185      1.12   reinoud 
    186      1.12   reinoud #define READ_DISCINFO_SMALLSIZE  12
    187      1.12   reinoud #define READ_DISCINFO_BIGSIZE    34	/* + entries */
    188      1.12   reinoud struct scsipi_read_discinfo_data {
    189      1.12   reinoud 	uint8_t  data_len[2];
    190      1.12   reinoud 	uint8_t  disc_state;
    191      1.12   reinoud 	uint8_t  first_track;
    192      1.12   reinoud 	uint8_t  num_sessions_lsb;
    193      1.12   reinoud 	uint8_t  first_track_last_session_lsb;
    194      1.12   reinoud 	uint8_t  last_track_last_session_lsb;
    195      1.12   reinoud 	uint8_t  disc_state2;
    196      1.12   reinoud 	uint8_t  disc_type;
    197      1.12   reinoud 	uint8_t  num_sessions_msb;
    198      1.12   reinoud 	uint8_t  first_track_last_session_msb;
    199      1.12   reinoud 	uint8_t  last_track_last_session_msb;
    200      1.12   reinoud 	uint8_t  discid[4];
    201      1.12   reinoud 	uint8_t  last_session_leadin_hmsf[4];
    202      1.12   reinoud 	uint8_t  last_possible_start_leadout_hmsf[4];
    203      1.12   reinoud 	uint8_t  disc_bar_code[8];
    204      1.14   reinoud 	uint8_t  application_code;
    205      1.12   reinoud 	uint8_t  num_opc_table_entries;
    206      1.12   reinoud 	uint8_t  opc_table_entries[1];	/* opc table entries follow	*/
    207      1.18     perry } __packed;
    208      1.12   reinoud 
    209      1.12   reinoud 
    210      1.12   reinoud #define READ_TRACKINFO 0x52
    211      1.12   reinoud struct scsipi_read_trackinfo {
    212      1.12   reinoud 	uint8_t  opcode;
    213      1.12   reinoud 	uint8_t  addr_type;
    214      1.12   reinoud 	uint8_t  address[4];
    215      1.12   reinoud 	uint8_t  nothing;
    216      1.12   reinoud 	uint8_t  data_len[2];
    217      1.12   reinoud 	uint8_t  control;
    218      1.18     perry } __packed;
    219      1.12   reinoud #define READ_TRACKINFO_ADDR_LBA    0
    220      1.12   reinoud #define READ_TRACKINFO_ADDR_TRACK  1
    221      1.12   reinoud #define READ_TRACKINFO_ADDR_SESS   2
    222      1.12   reinoud 
    223      1.12   reinoud struct scsipi_read_trackinfo_data {
    224      1.12   reinoud 	uint8_t  data_len[2];
    225      1.12   reinoud 	uint8_t  track_lsb;
    226      1.12   reinoud 	uint8_t  session_lsb;
    227      1.12   reinoud 	uint8_t  unused1;
    228      1.12   reinoud 	uint8_t  track_info_1;
    229      1.12   reinoud 	uint8_t  track_info_2;
    230      1.12   reinoud 	uint8_t  data_valid;
    231      1.12   reinoud 	uint8_t  track_start[4];
    232      1.12   reinoud 	uint8_t  next_writable[4];
    233      1.12   reinoud 	uint8_t  free_blocks[4];
    234      1.12   reinoud 	uint8_t  packet_size[4];
    235      1.12   reinoud 	uint8_t  track_size[4];
    236      1.12   reinoud 	uint8_t  last_recorded[4];
    237      1.12   reinoud 	uint8_t  track_msb;
    238      1.12   reinoud 	uint8_t  session_msb;
    239      1.12   reinoud 	uint8_t  unused2[2];
    240      1.18     perry } __packed;
    241      1.12   reinoud #define READ_TRACKINFO_RETURNSIZE 36
    242      1.12   reinoud 
    243      1.12   reinoud 
    244      1.19   reinoud #define CLOSE_TRACKSESSION 0x5B
    245      1.19   reinoud struct scsipi_close_tracksession {
    246      1.19   reinoud 	uint8_t  opcode;
    247      1.19   reinoud 	uint8_t  addr_type;		/* bit 1 holds immediate */
    248      1.19   reinoud 	uint8_t  function;		/* bits 2,1,0 */
    249      1.19   reinoud 	uint8_t  unused1;
    250      1.19   reinoud 	uint8_t  tracksessionnr[2];
    251      1.19   reinoud 	uint8_t  unused2[3];
    252      1.19   reinoud 	uint8_t  control;
    253      1.20  gmcgarry } __packed;
    254      1.19   reinoud 
    255      1.19   reinoud 
    256      1.19   reinoud #define RESERVE_TRACK 0x53
    257      1.19   reinoud struct scsipi_reserve_track {
    258      1.19   reinoud 	uint8_t  opcode;
    259      1.19   reinoud 	uint8_t  reserved[4];
    260      1.19   reinoud 	uint8_t  reservation_size[4];
    261      1.19   reinoud 	uint8_t  control;
    262      1.20  gmcgarry } __packed;
    263      1.19   reinoud 
    264      1.19   reinoud 
    265      1.19   reinoud #define REPAIR_TRACK 0x58
    266      1.19   reinoud struct scsipi_repair_track {
    267      1.19   reinoud 	uint8_t  opcode;
    268      1.19   reinoud 	uint8_t  reserved1;		/* bit 1 holds immediate */
    269      1.19   reinoud 	uint8_t  reserved2[2];
    270      1.19   reinoud 	uint8_t  tracknr[2];		/* logical track nr */
    271      1.19   reinoud 	uint8_t  reserved3[3];
    272      1.19   reinoud 	uint8_t  control;
    273      1.20  gmcgarry } __packed;
    274      1.19   reinoud 
    275      1.19   reinoud 
    276       1.2    bouyer #define READ_CD_CAPACITY	0x25	/* slightly different from disk */
    277       1.2    bouyer struct scsipi_read_cd_capacity {
    278      1.10   reinoud 	u_int8_t opcode;
    279      1.10   reinoud 	u_int8_t byte2;
    280      1.10   reinoud 	u_int8_t addr[4];
    281      1.10   reinoud 	u_int8_t unused[3];
    282      1.10   reinoud 	u_int8_t control;
    283      1.18     perry } __packed;
    284       1.2    bouyer 
    285       1.2    bouyer struct scsipi_read_cd_cap_data {
    286      1.10   reinoud 	u_int8_t addr[4];
    287      1.10   reinoud 	u_int8_t length[4];
    288      1.18     perry } __packed;
    289       1.2    bouyer 
    290      1.12   reinoud 
    291       1.2    bouyer /* mod pages common to scsi and atapi */
    292       1.2    bouyer struct cd_audio_page {
    293      1.10   reinoud 	u_int8_t pg_code;
    294       1.3     enami #define		AUDIO_PAGE	0x0e
    295      1.10   reinoud 	u_int8_t pg_length;
    296      1.10   reinoud 	u_int8_t flags;
    297       1.2    bouyer #define		CD_PA_SOTC	0x02
    298       1.2    bouyer #define		CD_PA_IMMED	0x04
    299      1.10   reinoud 	u_int8_t unused[2];
    300      1.10   reinoud 	u_int8_t format_lba; /* valid only for SCSI CDs */
    301       1.3     enami #define		CD_PA_FORMAT_LBA 0x0F
    302       1.2    bouyer #define		CD_PA_APR_VALID	0x80
    303      1.10   reinoud 	u_int8_t lb_per_sec[2];
    304       1.3     enami 	struct port_control {
    305      1.10   reinoud 		u_int8_t channels;
    306       1.2    bouyer #define	CHANNEL 0x0F
    307       1.2    bouyer #define	CHANNEL_0 1
    308       1.2    bouyer #define	CHANNEL_1 2
    309       1.2    bouyer #define	CHANNEL_2 4
    310       1.2    bouyer #define	CHANNEL_3 8
    311       1.3     enami #define		LEFT_CHANNEL	CHANNEL_0
    312       1.3     enami #define		RIGHT_CHANNEL	CHANNEL_1
    313       1.3     enami #define		MUTE_CHANNEL	0x0
    314       1.3     enami #define		BOTH_CHANNEL	LEFT_CHANNEL | RIGHT_CHANNEL
    315      1.10   reinoud 		u_int8_t volume;
    316       1.2    bouyer 	} port[4];
    317       1.2    bouyer #define	LEFT_PORT	0
    318       1.2    bouyer #define	RIGHT_PORT	1
    319       1.2    bouyer };
    320