URL
https://opencores.org/ocsvn/or1k/or1k/trunk
Subversion Repositories or1k
[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [cdrom/] [sjcd.h] - Rev 1765
Compare with Previous | Blame | View Log
/* * Definitions for a Sanyo CD-ROM interface. * * Copyright (C) 1995 Vadim V. Model * model@cecmow.enet.dec.com * vadim@rbrf.msk.su * vadim@ipsun.ras.ru * Eric van der Maarel * H.T.M.v.d.Maarel@marin.nl * * This information is based on mcd.c from M. Harriss and sjcd102.lst from * E. Moenkeberg. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef __SJCD_H__ #define __SJCD_H__ /* * Change this to set the I/O port address as default. More flexibility * come with setup implementation. */ #define SJCD_BASE_ADDR 0x340 /* * Change this to set the irq as default. Really SANYO do not use interrupts * at all. */ #define SJCD_INTR_NR 0 /* * Change this to set the dma as default value. really SANYO does not use * direct memory access at all. */ #define SJCD_DMA_NR 0 /* * Macros which allow us to find out the status of the drive. */ #define SJCD_STATUS_AVAILABLE( x ) (((x)&0x02)==0) #define SJCD_DATA_AVAILABLE( x ) (((x)&0x01)==0) /* * Port access macro. Three ports are available: S-data port (command port), * status port (read only) and D-data port (read only). */ #define SJCDPORT( x ) ( sjcd_base + ( x ) ) #define SJCD_STATUS_PORT SJCDPORT( 1 ) #define SJCD_S_DATA_PORT SJCDPORT( 0 ) #define SJCD_COMMAND_PORT SJCDPORT( 0 ) #define SJCD_D_DATA_PORT SJCDPORT( 2 ) /* * Drive info bits. Drive info available as first (mandatory) byte of * command completion status. */ #define SST_NOT_READY 0x10 /* no disk in the drive (???) */ #define SST_MEDIA_CHANGED 0x20 /* disk is changed */ #define SST_DOOR_OPENED 0x40 /* door is open */ /* commands */ #define SCMD_EJECT_TRAY 0xD0 /* eject tray if not locked */ #define SCMD_LOCK_TRAY 0xD2 /* lock tray when in */ #define SCMD_UNLOCK_TRAY 0xD4 /* unlock tray when in */ #define SCMD_CLOSE_TRAY 0xD6 /* load tray in */ #define SCMD_RESET 0xFA /* soft reset */ #define SCMD_GET_STATUS 0x80 #define SCMD_GET_VERSION 0xCC #define SCMD_DATA_READ 0xA0 /* are the same, depend on mode&args */ #define SCMD_SEEK 0xA0 #define SCMD_PLAY 0xA0 #define SCMD_GET_QINFO 0xA8 #define SCMD_SET_MODE 0xC4 #define SCMD_MODE_PLAY 0xE0 #define SCMD_MODE_COOKED (0xF8 & ~0x20) #define SCMD_MODE_RAW 0xF9 #define SCMD_MODE_x20_BIT 0x20 /* What is it for ? */ #define SCMD_SET_VOLUME 0xAE #define SCMD_PAUSE 0xE0 #define SCMD_STOP 0xE0 #define SCMD_GET_DISK_INFO 0xAA /* * Some standard arguments for SCMD_GET_DISK_INFO. */ #define SCMD_GET_1_TRACK 0xA0 /* get the first track information */ #define SCMD_GET_L_TRACK 0xA1 /* get the last track information */ #define SCMD_GET_D_SIZE 0xA2 /* get the whole disk information */ /* * Borrowed from hd.c. Allows to optimize multiple port read commands. */ #define S_READ_DATA( port, buf, nr ) insb( port, buf, nr ) /* * We assume that there are no audio disks with TOC length more than this * number (I personally have never seen disks with more than 20 fragments). */ #define SJCD_MAX_TRACKS 100 struct msf { unsigned char min; unsigned char sec; unsigned char frame; }; struct sjcd_hw_disk_info { unsigned char track_control; unsigned char track_no; unsigned char x, y, z; union { unsigned char track_no; struct msf track_msf; } un; }; struct sjcd_hw_qinfo { unsigned char track_control; unsigned char track_no; unsigned char x; struct msf rel; struct msf abs; }; struct sjcd_play_msf { struct msf start; struct msf end; }; struct sjcd_disk_info { unsigned char first; unsigned char last; struct msf disk_length; struct msf first_track; }; struct sjcd_toc { unsigned char ctrl_addr; unsigned char track; unsigned char point_index; struct msf track_time; struct msf disk_time; }; #if defined( SJCD_GATHER_STAT ) struct sjcd_stat { int ticks; int tticks[ 8 ]; int idle_ticks; int start_ticks; int mode_ticks; int read_ticks; int data_ticks; int stop_ticks; int stopping_ticks; }; #endif #endif