| /* -- isp16.h |
| * |
| * Header for detection and initialisation of cdrom interface (only) on |
| * ISP16 (MAD16, Mozart) sound card. |
| * |
| * 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. |
| * |
| */ |
| |
| /* These are the default values */ |
| #define ISP16_CDROM_TYPE "Sanyo" |
| #define ISP16_CDROM_IO_BASE 0x340 |
| #define ISP16_CDROM_IRQ 0 |
| #define ISP16_CDROM_DMA 0 |
| |
| /* Some (Media)Magic */ |
| /* define types of drive the interface on an ISP16 card may be looking at */ |
| #define ISP16_DRIVE_X 0x00 |
| #define ISP16_SONY 0x02 |
| #define ISP16_PANASONIC0 0x02 |
| #define ISP16_SANYO0 0x02 |
| #define ISP16_MITSUMI 0x04 |
| #define ISP16_PANASONIC1 0x06 |
| #define ISP16_SANYO1 0x06 |
| #define ISP16_DRIVE_NOT_USED 0x08 /* not used */ |
| #define ISP16_DRIVE_SET_MASK 0xF1 /* don't change 0-bit or 4-7-bits*/ |
| /* ...for port */ |
| #define ISP16_DRIVE_SET_PORT 0xF8D |
| /* set io parameters */ |
| #define ISP16_BASE_340 0x00 |
| #define ISP16_BASE_330 0x40 |
| #define ISP16_BASE_360 0x80 |
| #define ISP16_BASE_320 0xC0 |
| #define ISP16_IRQ_X 0x00 |
| #define ISP16_IRQ_5 0x04 /* shouldn't be used to avoid sound card conflicts */ |
| #define ISP16_IRQ_7 0x08 /* shouldn't be used to avoid sound card conflicts */ |
| #define ISP16_IRQ_3 0x0C |
| #define ISP16_IRQ_9 0x10 |
| #define ISP16_IRQ_10 0x14 |
| #define ISP16_IRQ_11 0x18 |
| #define ISP16_DMA_X 0x03 |
| #define ISP16_DMA_3 0x00 |
| #define ISP16_DMA_5 0x00 |
| #define ISP16_DMA_6 0x01 |
| #define ISP16_DMA_7 0x02 |
| #define ISP16_IO_SET_MASK 0x20 /* don't change 5-bit */ |
| /* ...for port */ |
| #define ISP16_IO_SET_PORT 0xF8E |
| /* enable the card */ |
| #define ISP16_C928__ENABLE_PORT 0xF90 /* ISP16 with OPTi 82C928 chip */ |
| #define ISP16_C929__ENABLE_PORT 0xF91 /* ISP16 with OPTi 82C929 chip */ |
| #define ISP16_ENABLE_CDROM 0x80 /* seven bit */ |
| |
| /* the magic stuff */ |
| #define ISP16_CTRL_PORT 0xF8F |
| #define ISP16_C928__CTRL 0xE2 /* ISP16 with OPTi 82C928 chip */ |
| #define ISP16_C929__CTRL 0xE3 /* ISP16 with OPTi 82C929 chip */ |
| |
| #define ISP16_IO_BASE 0xF8D |
| #define ISP16_IO_SIZE 5 /* ports used from 0xF8D up to 0xF91 */ |