/* * topic.h 1.13 2000/06/12 21:29:37 * * The contents of this file are subject to the Mozilla Public License * Version 1.1 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License * at http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See * the License for the specific language governing rights and * limitations under the License. * * The initial developer of the original code is David A. Hinds * . Portions created by David A. Hinds * are Copyright (C) 1999 David A. Hinds. All Rights Reserved. * * Alternatively, the contents of this file may be used under the * terms of the GNU Public License version 2 (the "GPL"), in which * case the provisions of the GPL are applicable instead of the * above. If you wish to allow the use of your version of this file * only under the terms of the GPL and not to allow others to use * your version of this file under the MPL, indicate your decision by * deleting the provisions above and replace them with the notice and * other provisions required by the GPL. If you do not delete the * provisions above, a recipient may use your version of this file * under either the MPL or the GPL. * topic.h $Release$ 2000/06/12 21:29:37 */ #ifndef _LINUX_TOPIC_H #define _LINUX_TOPIC_H #ifndef PCI_VENDOR_ID_TOSHIBA #define PCI_VENDOR_ID_TOSHIBA 0x1179 #endif #ifndef PCI_DEVICE_ID_TOSHIBA_TOPIC95_A #define PCI_DEVICE_ID_TOSHIBA_TOPIC95_A 0x0603 #endif #ifndef PCI_DEVICE_ID_TOSHIBA_TOPIC95_B #define PCI_DEVICE_ID_TOSHIBA_TOPIC95_B 0x060a #endif #ifndef PCI_DEVICE_ID_TOSHIBA_TOPIC97 #define PCI_DEVICE_ID_TOSHIBA_TOPIC97 0x060f #endif #ifndef PCI_DEVICE_ID_TOSHIBA_TOPIC100 #define PCI_DEVICE_ID_TOSHIBA_TOPIC100 0x0617 #endif /* Register definitions for Toshiba ToPIC95 controllers */ #define TOPIC_SOCKET_CONTROL 0x0090 /* 32 bit */ #define TOPIC_SCR_IRQSEL 0x00000001 #define TOPIC_SLOT_CONTROL 0x00a0 /* 8 bit */ #define TOPIC_SLOT_SLOTON 0x80 #define TOPIC_SLOT_SLOTEN 0x40 #define TOPIC_SLOT_ID_LOCK 0x20 #define TOPIC_SLOT_ID_WP 0x10 #define TOPIC_SLOT_PORT_MASK 0x0c #define TOPIC_SLOT_PORT_SHIFT 2 #define TOPIC_SLOT_OFS_MASK 0x03 #define TOPIC_CARD_CONTROL 0x00a1 /* 8 bit */ #define TOPIC_CCR_INTB 0x20 #define TOPIC_CCR_INTA 0x10 #define TOPIC_CCR_CLOCK 0x0c #define TOPIC_CCR_PCICLK 0x0c #define TOPIC_CCR_PCICLK_2 0x08 #define TOPIC_CCR_CCLK 0x04 #define TOPIC97_INT_CONTROL 0x00a1 /* 8 bit */ #define TOPIC97_ICR_INTB 0x20 #define TOPIC97_ICR_INTA 0x10 #define TOPIC97_ICR_STSIRQNP 0x04 #define TOPIC97_ICR_IRQNP 0x02 #define TOPIC97_ICR_IRQSEL 0x01 #define TOPIC_CARD_DETECT 0x00a3 /* 8 bit */ #define TOPIC_CDR_MODE_PC32 0x80 #define TOPIC_CDR_VS1 0x04 #define TOPIC_CDR_VS2 0x02 #define TOPIC_CDR_SW_DETECT 0x01 #define TOPIC_REGISTER_CONTROL 0x00a4 /* 32 bit */ #define TOPIC_RCR_RESUME_RESET 0x80000000 #define TOPIC_RCR_REMOVE_RESET 0x40000000 #define TOPIC97_RCR_CLKRUN_ENA 0x20000000 #define TOPIC97_RCR_TESTMODE 0x10000000 #define TOPIC97_RCR_IOPLUP 0x08000000 #define TOPIC_RCR_BUFOFF_PWROFF 0x02000000 #define TOPIC_RCR_BUFOFF_SIGOFF 0x01000000 #define TOPIC97_RCR_CB_DEV_MASK 0x0000f800 #define TOPIC97_RCR_CB_DEV_SHIFT 11 #define TOPIC97_RCR_RI_DISABLE 0x00000004 #define TOPIC97_RCR_CAUDIO_OFF 0x00000002 #define TOPIC_RCR_CAUDIO_INVERT 0x00000001 /* Data structure for tracking vendor-specific state */ typedef struct topic_state_t { u_char slot; /* TOPIC_SLOT_CONTROL */ u_char ccr; /* TOPIC_CARD_CONTROL */ u_char cdr; /* TOPIC_CARD_DETECT */ u_int rcr; /* TOPIC_REGISTER_CONTROL */ } topic_state_t; #define TOPIC_PCIC_ID \ IS_TOPIC95_A, IS_TOPIC95_B, IS_TOPIC97, IS_TOPIC100 #define TOPIC_PCIC_INFO \ { "Toshiba ToPIC95-A", IS_CARDBUS|IS_TOPIC, ID(TOSHIBA, TOPIC95_A) }, \ { "Toshiba ToPIC95-B", IS_CARDBUS|IS_TOPIC, ID(TOSHIBA, TOPIC95_B) }, \ { "Toshiba ToPIC97", IS_CARDBUS|IS_TOPIC, ID(TOSHIBA, TOPIC97) }, \ { "Toshiba ToPIC100", IS_CARDBUS|IS_TOPIC, ID(TOSHIBA, TOPIC100) } #endif /* _LINUX_TOPIC_H */