Home | History | Annotate | Line # | Download | only in ic
atppcreg.h revision 1.3.4.4
      1  1.3.4.4  skrll /* $NetBSD: atppcreg.h,v 1.3.4.4 2004/09/21 13:27:53 skrll Exp $ */
      2  1.3.4.2  skrll 
      3  1.3.4.2  skrll /*-
      4  1.3.4.2  skrll  * Copyright (c) 2001 Alcove - Nicolas Souchu
      5  1.3.4.2  skrll  * All rights reserved.
      6  1.3.4.2  skrll  *
      7  1.3.4.2  skrll  * Redistribution and use in source and binary forms, with or without
      8  1.3.4.2  skrll  * modification, are permitted provided that the following conditions
      9  1.3.4.2  skrll  * are met:
     10  1.3.4.2  skrll  * 1. Redistributions of source code must retain the above copyright
     11  1.3.4.2  skrll  *    notice, this list of conditions and the following disclaimer.
     12  1.3.4.2  skrll  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.3.4.2  skrll  *    notice, this list of conditions and the following disclaimer in the
     14  1.3.4.2  skrll  *    documentation and/or other materials provided with the distribution.
     15  1.3.4.2  skrll  *
     16  1.3.4.2  skrll  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
     17  1.3.4.2  skrll  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     18  1.3.4.2  skrll  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     19  1.3.4.2  skrll  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     20  1.3.4.2  skrll  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     21  1.3.4.2  skrll  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     22  1.3.4.2  skrll  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     23  1.3.4.2  skrll  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     24  1.3.4.2  skrll  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.3.4.2  skrll  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.3.4.2  skrll  * SUCH DAMAGE.
     27  1.3.4.2  skrll  *
     28  1.3.4.2  skrll  * FreeBSD: src/sys/isa/ppcreg.h,v 1.10.2.4 2001/10/02 05:21:45 nsouch Exp
     29  1.3.4.2  skrll  *
     30  1.3.4.2  skrll  */
     31  1.3.4.2  skrll 
     32  1.3.4.2  skrll #ifndef __ATPPCREG_H
     33  1.3.4.2  skrll #define __ATPPCREG_H
     34  1.3.4.2  skrll 
     35  1.3.4.2  skrll /* Generic register definitions as offsets from a base address */
     36  1.3.4.2  skrll 
     37  1.3.4.2  skrll #define ATPPC_SPP_DTR 		0	/* SPP data register */
     38  1.3.4.2  skrll #define ATPPC_ECP_A_FIFO	0	/* ECP Address fifo register */
     39  1.3.4.2  skrll #define ATPPC_SPP_STR		1	/* SPP status register */
     40  1.3.4.2  skrll #define ATPPC_SPP_CTR		2	/* SPP control register */
     41  1.3.4.2  skrll #define ATPPC_EPP_ADDR		3	/* EPP address register (8 bit) */
     42  1.3.4.2  skrll #define ATPPC_EPP_DATA		4	/* EPP data register (8, 16, 32 bit) */
     43  1.3.4.2  skrll #define ATPPC_ECP_D_FIFO	0x400	/* ECP Data fifo register */
     44  1.3.4.2  skrll #define ATPPC_ECP_CNFGA		0x400	/* Configuration register A */
     45  1.3.4.2  skrll #define ATPPC_ECP_CNFGB		0x401	/* Configuration register B */
     46  1.3.4.2  skrll #define ATPPC_ECP_ECR		0x402	/* ECP extended control register */
     47  1.3.4.2  skrll 
     48  1.3.4.2  skrll /* ECP control register commands/modes */
     49  1.3.4.2  skrll #define ATPPC_FIFO_EMPTY	0x1	/* ecr register - bit 0 */
     50  1.3.4.2  skrll #define ATPPC_FIFO_FULL		0x2	/* ecr register - bit 1 */
     51  1.3.4.2  skrll #define ATPPC_SERVICE_INTR 	0x4	/* ecr register - bit 2 */
     52  1.3.4.2  skrll #define ATPPC_ENABLE_DMA	0x8	/* ecr register - bit 3 */
     53  1.3.4.2  skrll #define ATPPC_nFAULT_INTR	0x10	/* ecr register - bit 4 */
     54  1.3.4.2  skrll /* ecr register - bits 5 through 7 */
     55  1.3.4.2  skrll #define ATPPC_ECR_STD		0x00	/* Standard mode */
     56  1.3.4.2  skrll #define ATPPC_ECR_PS2		0x20	/* Bidirectional mode */
     57  1.3.4.2  skrll #define ATPPC_ECR_FIFO		0x40	/* Fast Centronics mode */
     58  1.3.4.2  skrll #define ATPPC_ECR_ECP		0x60	/* ECP mode */
     59  1.3.4.2  skrll #define ATPPC_ECR_EPP		0x80	/* EPP mode */
     60  1.3.4.2  skrll #define ATPPC_ECR_TST		0xd0	/* Test mode*/
     61  1.3.4.2  skrll #define ATPPC_ECR_CFG		0xe0	/* Test mode*/
     62  1.3.4.2  skrll 
     63  1.3.4.2  skrll 
     64  1.3.4.2  skrll 
     65  1.3.4.2  skrll /* To set "inverted" flags, do AND. Otherwise, do OR */
     66  1.3.4.2  skrll /* 0 & x = 0, 1 | x = 1 */
     67  1.3.4.2  skrll 
     68  1.3.4.2  skrll /* Clear flags: n(var) is equivalent to var = 0.
     69  1.3.4.2  skrll #define n(flags) (~(flags) & (flags))*/
     70  1.3.4.2  skrll 
     71  1.3.4.2  skrll /* Invert flags
     72  1.3.4.2  skrll #define inv(flags) (~(flags))*/
     73  1.3.4.2  skrll 
     74  1.3.4.2  skrll /* SPP mode control register bit positions. */
     75  1.3.4.2  skrll #define STROBE		0x01
     76  1.3.4.2  skrll #define AUTOFEED	0x02
     77  1.3.4.2  skrll #define nINIT		0x04
     78  1.3.4.2  skrll #define SELECTIN	0x08
     79  1.3.4.2  skrll #define IRQENABLE	0x10
     80  1.3.4.2  skrll #define PCD             0x20
     81  1.3.4.2  skrll 
     82  1.3.4.2  skrll /*
     83  1.3.4.2  skrll #define nSTROBE		inv(STROBE)
     84  1.3.4.2  skrll #define nAUTOFEED	inv(AUTOFEED)
     85  1.3.4.2  skrll #define INIT		inv(nINIT)
     86  1.3.4.2  skrll #define nSELECTIN	inv(SELECTIN)
     87  1.3.4.2  skrll #define nPCD		inv(PCD)
     88  1.3.4.2  skrll */
     89  1.3.4.2  skrll 
     90  1.3.4.2  skrll /* SPP status register bit positions. */
     91  1.3.4.2  skrll #define TIMEOUT         0x01
     92  1.3.4.2  skrll #define nFAULT          0x08
     93  1.3.4.2  skrll #define SELECT          0x10
     94  1.3.4.2  skrll #define PERROR          0x20
     95  1.3.4.2  skrll #define nACK            0x40
     96  1.3.4.2  skrll #define nBUSY           0x80
     97  1.3.4.2  skrll 
     98  1.3.4.2  skrll /* Flags indicating ready condition */
     99  1.3.4.2  skrll #define SPP_READY (SELECT | nFAULT | nBUSY)
    100  1.3.4.2  skrll #define SPP_MASK (SELECT | nFAULT | PERROR | nBUSY)
    101  1.3.4.2  skrll 
    102  1.3.4.2  skrll /* Byte mode signals */
    103  1.3.4.2  skrll #define HOSTCLK		STROBE /* Also ECP mode signal */
    104  1.3.4.2  skrll #define HOSTBUSY	AUTOFEED
    105  1.3.4.2  skrll #define ACTIVE1284	SELECTIN /* Also ECP mode signal */
    106  1.3.4.2  skrll #define PTRCLK		nACK
    107  1.3.4.2  skrll #define PTRBUSY		nBUSY
    108  1.3.4.2  skrll #define ACKDATAREQ	PERROR
    109  1.3.4.2  skrll #define XFLAG		SELECT /* Also ECP mode signal */
    110  1.3.4.2  skrll #define nDATAVAIL	nFAULT
    111  1.3.4.2  skrll 
    112  1.3.4.2  skrll /* ECP mode signals */
    113  1.3.4.2  skrll #define HOSTACK		AUTOFEED
    114  1.3.4.2  skrll #define nREVREQ		nINIT
    115  1.3.4.2  skrll #define PERICLK		nACK
    116  1.3.4.2  skrll #define PERIACK		nBUSY
    117  1.3.4.2  skrll #define nACKREV		PERROR
    118  1.3.4.2  skrll #define nPERIREQ	nFAULT
    119  1.3.4.2  skrll 
    120  1.3.4.2  skrll /* EPP mode signals */
    121  1.3.4.2  skrll #define nWRITE		STROBE
    122  1.3.4.2  skrll #define nDATASTB	AUTOFEED
    123  1.3.4.2  skrll #define nADDRSTB	SELECTIN
    124  1.3.4.2  skrll #define nWAIT		nBUSY
    125  1.3.4.2  skrll #define nRESET		nINIT
    126  1.3.4.2  skrll #define nINTR		nACK
    127  1.3.4.2  skrll 
    128  1.3.4.2  skrll 
    129  1.3.4.2  skrll /*
    130  1.3.4.2  skrll  * Useful macros for reading/writing registers.
    131  1.3.4.2  skrll  */
    132  1.3.4.2  skrll 
    133  1.3.4.2  skrll /* Reading macros */
    134  1.3.4.2  skrll #define atppc_r_dtr(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh, \
    135  1.3.4.2  skrll 	ATPPC_SPP_DTR)
    136  1.3.4.2  skrll #define atppc_r_str(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh, \
    137  1.3.4.2  skrll 	ATPPC_SPP_STR)
    138  1.3.4.2  skrll #define atppc_r_ctr(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh, \
    139  1.3.4.2  skrll 	ATPPC_SPP_CTR)
    140  1.3.4.2  skrll #define atppc_r_eppA(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh,\
    141  1.3.4.2  skrll 	ATPPC_EPP_ADDR)
    142  1.3.4.2  skrll #define atppc_r_eppD(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh,\
    143  1.3.4.2  skrll 	ATPPC_EPP_DATA)
    144  1.3.4.2  skrll #define atppc_r_eppD_multi(atppc, buf, count) bus_space_read_multi_1( \
    145  1.3.4.2  skrll 	(atppc)->sc_iot, (atppc)->sc_ioh, ATPPC_EPP_DATA, (buf), (count))
    146  1.3.4.2  skrll #define atppc_r_cnfgA(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh,\
    147  1.3.4.2  skrll 	ATPPC_ECP_CNFGA)
    148  1.3.4.2  skrll #define atppc_r_cnfgB(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh,\
    149  1.3.4.2  skrll 	ATPPC_ECP_CNFGB)
    150  1.3.4.2  skrll #define atppc_r_ecr(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh, \
    151  1.3.4.2  skrll 	ATPPC_ECP_ECR)
    152  1.3.4.2  skrll #define atppc_r_fifo(atppc) bus_space_read_1((atppc)->sc_iot, (atppc)->sc_ioh, \
    153  1.3.4.2  skrll 	ATPPC_ECP_D_FIFO)
    154  1.3.4.2  skrll #define atppc_r_fifo_multi(atppc, buf, count) bus_space_read_multi_1( \
    155  1.3.4.2  skrll 	(atppc)->sc_iot, (atppc)->sc_ioh, ATPPC_ECP_D_FIFO, (buf), (count))
    156  1.3.4.2  skrll 
    157  1.3.4.2  skrll /* Writing macros */
    158  1.3.4.2  skrll #define atppc_w_dtr(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    159  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_SPP_DTR, (byte))
    160  1.3.4.2  skrll #define atppc_w_str(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    161  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_SPP_STR, (byte))
    162  1.3.4.2  skrll #define atppc_w_ctr(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    163  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_SPP_CTR, (byte))
    164  1.3.4.2  skrll #define atppc_w_eppA(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    165  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_EPP_ADDR, (byte))
    166  1.3.4.2  skrll #define atppc_w_eppD(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    167  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_EPP_DATA, (byte))
    168  1.3.4.2  skrll #define atppc_w_eppD_multi(atppc, buf, count) bus_space_write_multi_1( \
    169  1.3.4.2  skrll 	(atppc)->sc_iot, (atppc)->sc_ioh, ATPPC_EPP_DATA, (buf), (count))
    170  1.3.4.2  skrll #define atppc_w_cnfgA(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    171  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_ECP_CNFGA, (byte))
    172  1.3.4.2  skrll #define atppc_w_cnfgB(atppc, byte) bus_space_read_1((atppc)->sc_iot, \
    173  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_ECP_CNFGB, (byte))
    174  1.3.4.2  skrll #define atppc_w_ecr(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    175  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_ECP_ECR, (byte))
    176  1.3.4.2  skrll #define atppc_w_fifo(atppc, byte) bus_space_write_1((atppc)->sc_iot, \
    177  1.3.4.2  skrll 	(atppc)->sc_ioh, ATPPC_ECP_D_FIFO, (byte))
    178  1.3.4.2  skrll #define atppc_w_fifo_multi(atppc, buf, count) bus_space_write_multi_1( \
    179  1.3.4.2  skrll 	(atppc)->sc_iot, (atppc)->sc_ioh, ATPPC_ECP_D_FIFO, (buf), (count))
    180  1.3.4.2  skrll 
    181  1.3.4.2  skrll /* Barrier macros for reads/writes */
    182  1.3.4.2  skrll #define atppc_barrier_r(atppc) bus_space_barrier((atppc)->sc_iot, \
    183  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_READ)
    184  1.3.4.2  skrll #define atppc_barrier_w(atppc) bus_space_barrier((atppc)->sc_iot, \
    185  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_WRITE)
    186  1.3.4.2  skrll #define atppc_barrier(atppc) bus_space_barrier((atppc)->sc_iot, \
    187  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_WRITE | \
    188  1.3.4.2  skrll 	BUS_SPACE_BARRIER_READ)
    189  1.3.4.2  skrll 
    190  1.3.4.2  skrll /* These are defined in man pages but don't actually exist for all acrhs */
    191  1.3.4.2  skrll #define atppc_barrier_rr(atppc) bus_space_barrier((atppc)->sc_iot, \
    192  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_READ_BEFORE_READ)
    193  1.3.4.2  skrll #define atppc_barrier_rw(atppc) bus_space_barrier((atppc)->sc_iot, \
    194  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_READ_BEFORE_WRITE)
    195  1.3.4.2  skrll #define atppc_barrier_rb(atppc) bus_space_barrier((atppc)->sc_iot, \
    196  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_READ_BEFORE_READ | \
    197  1.3.4.2  skrll 	BUS_SPACE_BARRIER_READ_BEFORE_WRITE)
    198  1.3.4.2  skrll #define atppc_barrier_wr(atppc) bus_space_barrier((atppc)->sc_iot, \
    199  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_WRITE_BEFORE_READ)
    200  1.3.4.2  skrll #define atppc_barrier_ww(atppc) bus_space_barrier((atppc)->sc_iot, \
    201  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_WRITE_BEFORE_WRITE)
    202  1.3.4.2  skrll #define atppc_barrier_wb(atppc) bus_space_barrier((atppc)->sc_iot, \
    203  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_WRITE_BEFORE_READ | \
    204  1.3.4.2  skrll 	BUS_SPACE_BARRIER_WRITE_BEFORE_WRITE)
    205  1.3.4.2  skrll #define atppc_barrier_sync(atppc) bus_space_barrier((atppc)->sc_iot, \
    206  1.3.4.2  skrll 	(atppc)->sc_ioh, 0, IO_LPTSIZE, BUS_SPACE_BARRIER_SYNC)
    207  1.3.4.2  skrll 
    208  1.3.4.2  skrll /*
    209  1.3.4.2  skrll  * Register defines for the PC873xx parts
    210  1.3.4.2  skrll  */
    211  1.3.4.2  skrll 
    212  1.3.4.2  skrll #define PC873_FER	0x00
    213  1.3.4.2  skrll #define PC873_PPENABLE	(1<<0)
    214  1.3.4.2  skrll #define PC873_FAR	0x01
    215  1.3.4.2  skrll #define PC873_PTR	0x02
    216  1.3.4.2  skrll #define PC873_CFGLOCK	(1<<6)
    217  1.3.4.2  skrll #define PC873_EPPRDIR	(1<<7)
    218  1.3.4.2  skrll #define PC873_EXTENDED	(1<<7)
    219  1.3.4.2  skrll #define PC873_LPTBIRQ7	(1<<3)
    220  1.3.4.2  skrll #define PC873_FCR	0x03
    221  1.3.4.2  skrll #define PC873_ZWS	(1<<5)
    222  1.3.4.2  skrll #define PC873_ZWSPWDN	(1<<6)
    223  1.3.4.2  skrll #define PC873_PCR	0x04
    224  1.3.4.2  skrll #define PC873_EPPEN	(1<<0)
    225  1.3.4.2  skrll #define PC873_EPP19	(1<<1)
    226  1.3.4.2  skrll #define PC873_ECPEN	(1<<2)
    227  1.3.4.2  skrll #define PC873_ECPCLK	(1<<3)
    228  1.3.4.2  skrll #define PC873_PMC	0x06
    229  1.3.4.2  skrll #define PC873_TUP	0x07
    230  1.3.4.2  skrll #define PC873_SID	0x08
    231  1.3.4.2  skrll #define PC873_PNP0	0x1b
    232  1.3.4.2  skrll #define PC873_PNP1	0x1c
    233  1.3.4.2  skrll #define PC873_LPTBA	0x19
    234  1.3.4.2  skrll 
    235  1.3.4.2  skrll /*
    236  1.3.4.2  skrll  * Register defines for the SMC FDC37C66xGT parts
    237  1.3.4.2  skrll  */
    238  1.3.4.2  skrll 
    239  1.3.4.2  skrll /* Init codes */
    240  1.3.4.2  skrll #define SMC665_iCODE	0x55
    241  1.3.4.2  skrll #define SMC666_iCODE	0x44
    242  1.3.4.2  skrll 
    243  1.3.4.2  skrll /* Base configuration ports */
    244  1.3.4.2  skrll #define SMC66x_CSR	0x3F0
    245  1.3.4.2  skrll #define SMC666_CSR	0x370		/* hard-configured value for 666 */
    246  1.3.4.2  skrll 
    247  1.3.4.2  skrll /* Bits */
    248  1.3.4.2  skrll #define SMC_CR1_ADDR	0x3		/* bit 0 and 1 */
    249  1.3.4.2  skrll #define SMC_CR1_MODE	(1<<3)		/* bit 3 */
    250  1.3.4.2  skrll #define SMC_CR4_EMODE	0x3		/* bits 0 and 1 */
    251  1.3.4.2  skrll #define SMC_CR4_EPPTYPE	(1<<6)		/* bit 6 */
    252  1.3.4.2  skrll 
    253  1.3.4.2  skrll /* Extended modes */
    254  1.3.4.2  skrll #define SMC_SPP		0x0		/* SPP */
    255  1.3.4.2  skrll #define SMC_EPPSPP	0x1		/* EPP and SPP */
    256  1.3.4.2  skrll #define SMC_ECP		0x2 		/* ECP */
    257  1.3.4.2  skrll #define SMC_ECPEPP	0x3		/* ECP and EPP */
    258  1.3.4.2  skrll 
    259  1.3.4.2  skrll /*
    260  1.3.4.2  skrll  * Register defines for the SMC FDC37C935 parts
    261  1.3.4.2  skrll  */
    262  1.3.4.2  skrll 
    263  1.3.4.2  skrll /* Configuration ports */
    264  1.3.4.2  skrll #define SMC935_CFG	0x370
    265  1.3.4.2  skrll #define SMC935_IND	0x370
    266  1.3.4.2  skrll #define SMC935_DAT	0x371
    267  1.3.4.2  skrll 
    268  1.3.4.2  skrll /* Registers */
    269  1.3.4.2  skrll #define SMC935_LOGDEV	0x7
    270  1.3.4.2  skrll #define SMC935_ID	0x20
    271  1.3.4.2  skrll #define SMC935_PORTHI	0x60
    272  1.3.4.2  skrll #define SMC935_PORTLO	0x61
    273  1.3.4.2  skrll #define SMC935_PPMODE	0xf0
    274  1.3.4.2  skrll 
    275  1.3.4.2  skrll /* Parallel port modes */
    276  1.3.4.2  skrll #define SMC935_SPP	0x38 + 0
    277  1.3.4.2  skrll #define SMC935_EPP19SPP	0x38 + 1
    278  1.3.4.2  skrll #define SMC935_ECP	0x38 + 2
    279  1.3.4.2  skrll #define SMC935_ECPEPP19	0x38 + 3
    280  1.3.4.2  skrll #define SMC935_CENT	0x38 + 4
    281  1.3.4.2  skrll #define SMC935_EPP17SPP	0x38 + 5
    282  1.3.4.2  skrll #define SMC935_UNUSED	0x38 + 6
    283  1.3.4.2  skrll #define SMC935_ECPEPP17	0x38 + 7
    284  1.3.4.2  skrll 
    285  1.3.4.2  skrll /*
    286  1.3.4.2  skrll  * Register defines for the Winbond W83877F parts
    287  1.3.4.2  skrll  */
    288  1.3.4.2  skrll 
    289  1.3.4.2  skrll #define WINB_W83877F_ID		0xa
    290  1.3.4.2  skrll #define WINB_W83877AF_ID	0xb
    291  1.3.4.2  skrll 
    292  1.3.4.2  skrll /* Configuration bits */
    293  1.3.4.2  skrll #define WINB_HEFERE	(1<<5)		/* CROC bit 5 */
    294  1.3.4.2  skrll #define WINB_HEFRAS	(1<<0)		/* CR16 bit 0 */
    295  1.3.4.2  skrll 
    296  1.3.4.2  skrll #define WINB_PNPCVS	(1<<2)		/* CR16 bit 2 */
    297  1.3.4.2  skrll #define WINB_CHIPID	0xf		/* CR9 bits 0-3 */
    298  1.3.4.2  skrll 
    299  1.3.4.2  skrll #define WINB_PRTMODS0	(1<<2)		/* CR0 bit 2 */
    300  1.3.4.2  skrll #define WINB_PRTMODS1	(1<<3)		/* CR0 bit 3 */
    301  1.3.4.2  skrll #define WINB_PRTMODS2	(1<<7)		/* CR9 bit 7 */
    302  1.3.4.2  skrll 
    303  1.3.4.2  skrll /* W83877F modes: CR9/bit7 | CR0/bit3 | CR0/bit2 */
    304  1.3.4.2  skrll #define WINB_W83757	0x0
    305  1.3.4.2  skrll #define WINB_EXTFDC	0x4
    306  1.3.4.2  skrll #define WINB_EXTADP	0x8
    307  1.3.4.2  skrll #define WINB_EXT2FDD	0xc
    308  1.3.4.2  skrll #define WINB_JOYSTICK	0x80
    309  1.3.4.2  skrll 
    310  1.3.4.2  skrll #define WINB_PARALLEL	0x80
    311  1.3.4.2  skrll #define WINB_EPP_SPP	0x4
    312  1.3.4.2  skrll #define WINB_ECP	0x8
    313  1.3.4.2  skrll #define WINB_ECP_EPP	0xc
    314  1.3.4.2  skrll 
    315  1.3.4.2  skrll #endif /* __ATPPCREG_H */
    316