NetBSD/sys/dev/scsipi/scsipi_cd.h

152 lines
3.6 KiB
C

/* $NetBSD: scsipi_cd.h,v 1.10 2005/02/01 00:19:34 reinoud Exp $ */
/*
* Written by Julian Elischer (julian@tfs.com)
* for TRW Financial Systems.
*
* TRW Financial Systems, in accordance with their agreement with Carnegie
* Mellon University, makes this software available to CMU to distribute
* or use in any manner that they see fit as long as this message is kept with
* the software. For this reason TFS also grants any other persons or
* organisations permission to use or modify this software.
*
* TFS supplies this software to be publicly redistributed
* on the understanding that TFS is not responsible for the correct
* functioning of this software in any circumstances.
*
* Ported to run under 386BSD by Julian Elischer (julian@tfs.com) Sept 1992
*/
/*
* Define two bits always in the same place in byte 2 (flag byte)
*/
#define CD_RELADDR 0x01
#define CD_MSF 0x02
/*
* SCSI and SCSI-like command format
*/
#define LOAD_UNLOAD 0xa6
struct scsipi_load_unload {
u_int8_t opcode;
u_int8_t unused1[3];
u_int8_t options;
u_int8_t unused2[3];
u_int8_t slot;
u_int8_t unused3[3];
} __attribute__((packed));
#define PAUSE 0x4b /* cdrom pause in 'play audio' mode */
struct scsipi_pause {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t unused[6];
u_int8_t resume;
u_int8_t control;
} __attribute__((packed));
#define PA_PAUSE 0x00
#define PA_RESUME 0x01
#define PLAY_MSF 0x47 /* cdrom play Min,Sec,Frames mode */
struct scsipi_play_msf {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t unused;
u_int8_t start_m;
u_int8_t start_s;
u_int8_t start_f;
u_int8_t end_m;
u_int8_t end_s;
u_int8_t end_f;
u_int8_t control;
} __attribute__((packed));
#define PLAY 0x45 /* cdrom play 'play audio' mode */
struct scsipi_play {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t blk_addr[4];
u_int8_t unused;
u_int8_t xfer_len[2];
u_int8_t control;
} __attribute__((packed));
#define READ_HEADER 0x44 /* cdrom read header */
struct scsipi_read_header {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t blk_addr[4];
u_int8_t unused;
u_int8_t data_len[2];
u_int8_t control;
} __attribute__((packed));
#define READ_SUBCHANNEL 0x42 /* cdrom read Subchannel */
struct scsipi_read_subchannel {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t byte3;
#define SRS_SUBQ 0x40
u_int8_t subchan_format;
u_int8_t unused[2];
u_int8_t track;
u_int8_t data_len[2];
u_int8_t control;
} __attribute__((packed));
#define READ_TOC 0x43 /* cdrom read TOC */
struct scsipi_read_toc {
u_int8_t opcode;
u_int8_t addr_mode;
u_int8_t resp_format;
u_int8_t unused[3];
u_int8_t from_track;
u_int8_t data_len[2];
u_int8_t control;
} __attribute__((packed));
#define READ_CD_CAPACITY 0x25 /* slightly different from disk */
struct scsipi_read_cd_capacity {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t addr[4];
u_int8_t unused[3];
u_int8_t control;
} __attribute__((packed));
struct scsipi_read_cd_cap_data {
u_int8_t addr[4];
u_int8_t length[4];
} __attribute__((packed));
/* mod pages common to scsi and atapi */
struct cd_audio_page {
u_int8_t pg_code;
#define AUDIO_PAGE 0x0e
u_int8_t pg_length;
u_int8_t flags;
#define CD_PA_SOTC 0x02
#define CD_PA_IMMED 0x04
u_int8_t unused[2];
u_int8_t format_lba; /* valid only for SCSI CDs */
#define CD_PA_FORMAT_LBA 0x0F
#define CD_PA_APR_VALID 0x80
u_int8_t lb_per_sec[2];
struct port_control {
u_int8_t channels;
#define CHANNEL 0x0F
#define CHANNEL_0 1
#define CHANNEL_1 2
#define CHANNEL_2 4
#define CHANNEL_3 8
#define LEFT_CHANNEL CHANNEL_0
#define RIGHT_CHANNEL CHANNEL_1
#define MUTE_CHANNEL 0x0
#define BOTH_CHANNEL LEFT_CHANNEL | RIGHT_CHANNEL
u_int8_t volume;
} port[4];
#define LEFT_PORT 0
#define RIGHT_PORT 1
};