#ifndef _SCSI_CD_H
#define _SCSI_CD_H
#define CD_RELADDR 0x01
#define CD_MSF 0x02
struct scsi_blank {
u_int8_t opcode;
u_int8_t byte2;
#define BLANK_DISC 0
#define BLANK_MINIMAL 1
u_int8_t addr[4];
u_int8_t unused[5];
u_int8_t control;
};
struct scsi_close_track {
u_int8_t opcode;
u_int8_t flags;
#define CT_IMMED 1
u_int8_t closefunc;
#define CT_CLOSE_TRACK 1
#define CT_CLOSE_SESS 2
#define CT_CLOSE_BORDER 3
u_int8_t unused;
u_int8_t track[2];
u_int8_t unused1[3];
u_int8_t control;
};
struct scsi_pause {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t unused[6];
u_int8_t resume;
u_int8_t control;
};
#define PA_PAUSE 1
#define PA_RESUME 0
struct scsi_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;
};
struct scsi_play_track {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t unused[2];
u_int8_t start_track;
u_int8_t start_index;
u_int8_t unused1;
u_int8_t end_track;
u_int8_t end_index;
u_int8_t control;
};
struct scsi_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;
};
struct scsi_play_big {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t blk_addr[4];
u_int8_t xfer_len[4];
u_int8_t unused;
u_int8_t control;
};
struct scsi_play_rel_big {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t blk_addr[4];
u_int8_t xfer_len[4];
u_int8_t track;
u_int8_t control;
};
struct scsi_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;
};
struct scsi_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;
};
struct scsi_read_toc {
u_int8_t opcode;
u_int8_t byte2;
u_int8_t unused[4];
u_int8_t from_track;
u_int8_t data_len[2];
u_int8_t control;
};
struct scsi_read_track_info {
u_int8_t opcode;
u_int8_t addrtype;
#define RTI_LBA 0
#define RTI_TRACK 1
#define RTI_BORDER 2
u_int8_t addr[4];
u_int8_t unused;
u_int8_t data_len[2];
u_int8_t control;
};
struct scsi_load_unload {
u_int8_t opcode;
u_int8_t reserved;
#define IMMED 0x1
u_int8_t reserved2[2];
u_int8_t options;
#define START 0x1
#define LOUNLO 0x2
u_int8_t reserved4[3];
u_int8_t slot;
u_int8_t reserved5[2];
u_int8_t control;
};
struct scsi_set_cd_speed {
u_int8_t opcode;
u_int8_t rotation;
#define ROTATE_CLV 0
#define ROTATE_CAV 1
u_int8_t read[2];
u_int8_t write[2];
u_int8_t reserved[5];
u_int8_t control;
};
#define READ_SUBCHANNEL 0x42
#define READ_TOC 0x43
#define READ_HEADER 0x44
#define PLAY 0x45
#define PLAY_MSF 0x47
#define PLAY_TRACK 0x48
#define PLAY_TRACK_REL 0x49
#define PAUSE 0x4b
#define READ_TRACK_INFO 0x52
#define CLOSE_TRACK 0x5b
#define BLANK 0xa1
#define PLAY_BIG 0xa5
#define LOAD_UNLOAD 0xa6
#define PLAY_TRACK_REL_BIG 0xa9
#define SET_CD_SPEED 0xbb
#define ERR_RECOVERY_PAGE 0x01
#define WRITE_PARAM_PAGE 0x05
#define AUDIO_PAGE 0x0e
#define CDVD_CAPABILITIES_PAGE 0x2a
struct cd_audio_page {
u_int8_t page_code;
#define CD_PAGE_CODE 0x3F
#define CD_PAGE_PS 0x80
u_int8_t param_len;
u_int8_t flags;
#define CD_PA_SOTC 0x02
#define CD_PA_IMMED 0x04
u_int8_t unused[2];
u_int8_t format_lba;
#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
};
#define CD_DA_BLKSIZ 2352
#define CD_NORMAL_DENSITY_CODE 0x00
#define CD_DA_DENSITY_CODE 0x82
struct scsi_read_dvd_structure {
u_int8_t opcode;
u_int8_t reserved;
u_int8_t address[4];
u_int8_t layer;
u_int8_t format;
u_int8_t length[2];
u_int8_t agid;
u_int8_t control;
};
struct scsi_read_dvd_structure_data {
u_int8_t len[2];
u_int8_t reserved[2];
u_int8_t data[2048];
};
#endif