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
182