]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blob - drivers/cdrom/sjcd.h
Linux-2.6.12-rc2
[mirror_ubuntu-artful-kernel.git] / drivers / cdrom / sjcd.h
1 /*
2 * Definitions for a Sanyo CD-ROM interface.
3 *
4 * Copyright (C) 1995 Vadim V. Model
5 * model@cecmow.enet.dec.com
6 * vadim@rbrf.msk.su
7 * vadim@ipsun.ras.ru
8 * Eric van der Maarel
9 * H.T.M.v.d.Maarel@marin.nl
10 *
11 * This information is based on mcd.c from M. Harriss and sjcd102.lst from
12 * E. Moenkeberg.
13 *
14 * This program is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation; either version 2 of the License, or
17 * (at your option) any later version.
18 *
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU General Public License
25 * along with this program; if not, write to the Free Software
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
27 */
28
29 #ifndef __SJCD_H__
30 #define __SJCD_H__
31
32 /*
33 * Change this to set the I/O port address as default. More flexibility
34 * come with setup implementation.
35 */
36 #define SJCD_BASE_ADDR 0x340
37
38 /*
39 * Change this to set the irq as default. Really SANYO do not use interrupts
40 * at all.
41 */
42 #define SJCD_INTR_NR 0
43
44 /*
45 * Change this to set the dma as default value. really SANYO does not use
46 * direct memory access at all.
47 */
48 #define SJCD_DMA_NR 0
49
50 /*
51 * Macros which allow us to find out the status of the drive.
52 */
53 #define SJCD_STATUS_AVAILABLE( x ) (((x)&0x02)==0)
54 #define SJCD_DATA_AVAILABLE( x ) (((x)&0x01)==0)
55
56 /*
57 * Port access macro. Three ports are available: S-data port (command port),
58 * status port (read only) and D-data port (read only).
59 */
60 #define SJCDPORT( x ) ( sjcd_base + ( x ) )
61 #define SJCD_STATUS_PORT SJCDPORT( 1 )
62 #define SJCD_S_DATA_PORT SJCDPORT( 0 )
63 #define SJCD_COMMAND_PORT SJCDPORT( 0 )
64 #define SJCD_D_DATA_PORT SJCDPORT( 2 )
65
66 /*
67 * Drive info bits. Drive info available as first (mandatory) byte of
68 * command completion status.
69 */
70 #define SST_NOT_READY 0x10 /* no disk in the drive (???) */
71 #define SST_MEDIA_CHANGED 0x20 /* disk is changed */
72 #define SST_DOOR_OPENED 0x40 /* door is open */
73
74 /* commands */
75
76 #define SCMD_EJECT_TRAY 0xD0 /* eject tray if not locked */
77 #define SCMD_LOCK_TRAY 0xD2 /* lock tray when in */
78 #define SCMD_UNLOCK_TRAY 0xD4 /* unlock tray when in */
79 #define SCMD_CLOSE_TRAY 0xD6 /* load tray in */
80
81 #define SCMD_RESET 0xFA /* soft reset */
82 #define SCMD_GET_STATUS 0x80
83 #define SCMD_GET_VERSION 0xCC
84
85 #define SCMD_DATA_READ 0xA0 /* are the same, depend on mode&args */
86 #define SCMD_SEEK 0xA0
87 #define SCMD_PLAY 0xA0
88
89 #define SCMD_GET_QINFO 0xA8
90
91 #define SCMD_SET_MODE 0xC4
92 #define SCMD_MODE_PLAY 0xE0
93 #define SCMD_MODE_COOKED (0xF8 & ~0x20)
94 #define SCMD_MODE_RAW 0xF9
95 #define SCMD_MODE_x20_BIT 0x20 /* What is it for ? */
96
97 #define SCMD_SET_VOLUME 0xAE
98 #define SCMD_PAUSE 0xE0
99 #define SCMD_STOP 0xE0
100
101 #define SCMD_GET_DISK_INFO 0xAA
102
103 /*
104 * Some standard arguments for SCMD_GET_DISK_INFO.
105 */
106 #define SCMD_GET_1_TRACK 0xA0 /* get the first track information */
107 #define SCMD_GET_L_TRACK 0xA1 /* get the last track information */
108 #define SCMD_GET_D_SIZE 0xA2 /* get the whole disk information */
109
110 /*
111 * Borrowed from hd.c. Allows to optimize multiple port read commands.
112 */
113 #define S_READ_DATA( port, buf, nr ) insb( port, buf, nr )
114
115 /*
116 * We assume that there are no audio disks with TOC length more than this
117 * number (I personally have never seen disks with more than 20 fragments).
118 */
119 #define SJCD_MAX_TRACKS 100
120
121 struct msf {
122 unsigned char min;
123 unsigned char sec;
124 unsigned char frame;
125 };
126
127 struct sjcd_hw_disk_info {
128 unsigned char track_control;
129 unsigned char track_no;
130 unsigned char x, y, z;
131 union {
132 unsigned char track_no;
133 struct msf track_msf;
134 } un;
135 };
136
137 struct sjcd_hw_qinfo {
138 unsigned char track_control;
139 unsigned char track_no;
140 unsigned char x;
141 struct msf rel;
142 struct msf abs;
143 };
144
145 struct sjcd_play_msf {
146 struct msf start;
147 struct msf end;
148 };
149
150 struct sjcd_disk_info {
151 unsigned char first;
152 unsigned char last;
153 struct msf disk_length;
154 struct msf first_track;
155 };
156
157 struct sjcd_toc {
158 unsigned char ctrl_addr;
159 unsigned char track;
160 unsigned char point_index;
161 struct msf track_time;
162 struct msf disk_time;
163 };
164
165 #if defined( SJCD_GATHER_STAT )
166
167 struct sjcd_stat {
168 int ticks;
169 int tticks[ 8 ];
170 int idle_ticks;
171 int start_ticks;
172 int mode_ticks;
173 int read_ticks;
174 int data_ticks;
175 int stop_ticks;
176 int stopping_ticks;
177 };
178
179 #endif
180
181 #endif