File: /usr/src/linux/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
182