1*5b6ecd7fSRichard Lowe /* 2*5b6ecd7fSRichard Lowe * CDDL HEADER START 3*5b6ecd7fSRichard Lowe * 4*5b6ecd7fSRichard Lowe * The contents of this file are subject to the terms of the 5*5b6ecd7fSRichard Lowe * Common Development and Distribution License, Version 1.0 only 6*5b6ecd7fSRichard Lowe * (the "License"). You may not use this file except in compliance 7*5b6ecd7fSRichard Lowe * with the License. 8*5b6ecd7fSRichard Lowe * 9*5b6ecd7fSRichard Lowe * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*5b6ecd7fSRichard Lowe * or http://www.opensolaris.org/os/licensing. 11*5b6ecd7fSRichard Lowe * See the License for the specific language governing permissions 12*5b6ecd7fSRichard Lowe * and limitations under the License. 13*5b6ecd7fSRichard Lowe * 14*5b6ecd7fSRichard Lowe * When distributing Covered Code, include this CDDL HEADER in each 15*5b6ecd7fSRichard Lowe * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*5b6ecd7fSRichard Lowe * If applicable, add the following below this CDDL HEADER, with the 17*5b6ecd7fSRichard Lowe * fields enclosed by brackets "[]" replaced with your own identifying 18*5b6ecd7fSRichard Lowe * information: Portions Copyright [yyyy] [name of copyright owner] 19*5b6ecd7fSRichard Lowe * 20*5b6ecd7fSRichard Lowe * CDDL HEADER END 21*5b6ecd7fSRichard Lowe */ 22*5b6ecd7fSRichard Lowe /* 23*5b6ecd7fSRichard Lowe * Copyright (c) 1995 by Sun Microsystems, Inc. 24*5b6ecd7fSRichard Lowe * All rights reserved. 25*5b6ecd7fSRichard Lowe */ 26*5b6ecd7fSRichard Lowe 27*5b6ecd7fSRichard Lowe #ifndef _SYS_I8272A_H 28*5b6ecd7fSRichard Lowe #define _SYS_I8272A_H 29*5b6ecd7fSRichard Lowe 30*5b6ecd7fSRichard Lowe #ifdef __cplusplus 31*5b6ecd7fSRichard Lowe extern "C" { 32*5b6ecd7fSRichard Lowe #endif 33*5b6ecd7fSRichard Lowe 34*5b6ecd7fSRichard Lowe /* 35*5b6ecd7fSRichard Lowe * i/o port numbers 36*5b6ecd7fSRichard Lowe */ 37*5b6ecd7fSRichard Lowe #define FCR_BASE 0x3f0 /* default i/o base address */ 38*5b6ecd7fSRichard Lowe 39*5b6ecd7fSRichard Lowe #define FCR_SRA 0x000 /* only 82077AA (not AT mode) or SMC */ 40*5b6ecd7fSRichard Lowe #define FCR_SRB 0x001 /* only 82077AA (not AT mode) or SMC */ 41*5b6ecd7fSRichard Lowe #define FCR_DOR 0x002 42*5b6ecd7fSRichard Lowe #define FCR_MSR 0x004 43*5b6ecd7fSRichard Lowe #define FCR_DSR 0x004 /* only enhanced controllers */ 44*5b6ecd7fSRichard Lowe #define FCR_DATA 0x005 45*5b6ecd7fSRichard Lowe #define FCR_DIR 0x007 46*5b6ecd7fSRichard Lowe #define FCR_CCR 0x007 /* 82077AA term; == DSR on PC/AT */ 47*5b6ecd7fSRichard Lowe 48*5b6ecd7fSRichard Lowe /* SRA : values for Configuration Select Register for SMC FDC37C66xGT */ 49*5b6ecd7fSRichard Lowe #define FSA_ENA5 0x55 /* enable config mode, issue twice */ 50*5b6ecd7fSRichard Lowe #define FSA_ENA6 0x44 /* enable config mode, issue twice */ 51*5b6ecd7fSRichard Lowe #define FSA_DISB 0xAA /* disable config mode */ 52*5b6ecd7fSRichard Lowe #define FSA_CR5 0x05 /* select config register 5 */ 53*5b6ecd7fSRichard Lowe 54*5b6ecd7fSRichard Lowe /* SRB : Configuration Data Register for SMC FDC37C66xGT */ 55*5b6ecd7fSRichard Lowe #define FSB_DSDEF 0xE7 /* bit mask for density select in reg 5 */ 56*5b6ecd7fSRichard Lowe #define FSB_DSLO 0x10 /* density select = LOW (300 rpm) */ 57*5b6ecd7fSRichard Lowe #define FSB_DSHI 0x18 /* density select = HIGH (360 rpm) */ 58*5b6ecd7fSRichard Lowe 59*5b6ecd7fSRichard Lowe /* DOR : Digital Output Register */ 60*5b6ecd7fSRichard Lowe #define FD_DMTREN 0xF0 61*5b6ecd7fSRichard Lowe #define FD_D3MTR 0x80 62*5b6ecd7fSRichard Lowe #define FD_D2MTR 0x40 63*5b6ecd7fSRichard Lowe #define FD_DBMTR 0x20 64*5b6ecd7fSRichard Lowe #define FD_DAMTR 0x10 65*5b6ecd7fSRichard Lowe #define FD_ENABLE 0x08 /* DMA gate */ 66*5b6ecd7fSRichard Lowe #define FD_RSETZ 0x04 67*5b6ecd7fSRichard Lowe #define FD_DRSEL 0x03 68*5b6ecd7fSRichard Lowe #define FD_DBSEL 0x01 69*5b6ecd7fSRichard Lowe #define FD_DASEL 0x00 70*5b6ecd7fSRichard Lowe 71*5b6ecd7fSRichard Lowe #define ENAB_MCA_INT 0x00 72*5b6ecd7fSRichard Lowe 73*5b6ecd7fSRichard Lowe 74*5b6ecd7fSRichard Lowe /* MSR - Main Status Register */ 75*5b6ecd7fSRichard Lowe #define MS_RQM 0x80 /* request for master - chip needs attention */ 76*5b6ecd7fSRichard Lowe #define MS_DIO 0x40 /* data in/out, 1 = remove bytes from fifo */ 77*5b6ecd7fSRichard Lowe #define MS_NDM 0x20 /* non-dma mode - 1 during execution phase */ 78*5b6ecd7fSRichard Lowe #define MS_CB 0x10 /* controller busy, command in progress */ 79*5b6ecd7fSRichard Lowe #define MS_D3B 0x08 /* drive 3 busy */ 80*5b6ecd7fSRichard Lowe #define MS_D2B 0x04 /* drive 2 busy */ 81*5b6ecd7fSRichard Lowe #define MS_DBB 0x02 /* drive B busy */ 82*5b6ecd7fSRichard Lowe #define MS_DAB 0x01 /* drive A busy */ 83*5b6ecd7fSRichard Lowe 84*5b6ecd7fSRichard Lowe #define FDC_RQM_RETRY 300 85*5b6ecd7fSRichard Lowe 86*5b6ecd7fSRichard Lowe 87*5b6ecd7fSRichard Lowe /* DIR : Digital Input Register */ 88*5b6ecd7fSRichard Lowe #define FDI_DKCHG 0x80 /* this is inverted in Model 30 mode */ 89*5b6ecd7fSRichard Lowe #define FDI_DMAGAT 0x08 /* Model 30: DMA gate */ 90*5b6ecd7fSRichard Lowe #define FDI_NOPREC 0x04 /* Model 30 only */ 91*5b6ecd7fSRichard Lowe #define FDI_DRATE 0x03 /* Model 30: selected datarate mask */ 92*5b6ecd7fSRichard Lowe 93*5b6ecd7fSRichard Lowe 94*5b6ecd7fSRichard Lowe /* DSR : Datarate Select Register on 82072 and 82077AA */ 95*5b6ecd7fSRichard Lowe #define FSR_SWR 0x80 /* software reset */ 96*5b6ecd7fSRichard Lowe #define FSR_PD 0x40 /* power down */ 97*5b6ecd7fSRichard Lowe #define FSR_PRECP 0x1C /* precomp mask */ 98*5b6ecd7fSRichard Lowe #define FSR_DRATE 0x3 /* datarate select mask */ 99*5b6ecd7fSRichard Lowe 100*5b6ecd7fSRichard Lowe 101*5b6ecd7fSRichard Lowe /* CCR : Configuration Control Register, aka Datarate Select Register */ 102*5b6ecd7fSRichard Lowe #define FCC_NOPREC 0x4 /* Model 30 only */ 103*5b6ecd7fSRichard Lowe #define FCC_DRATE 0x3 /* datarate select mask */ 104*5b6ecd7fSRichard Lowe 105*5b6ecd7fSRichard Lowe 106*5b6ecd7fSRichard Lowe /* 107*5b6ecd7fSRichard Lowe * Floppy controller command opcodes 108*5b6ecd7fSRichard Lowe */ 109*5b6ecd7fSRichard Lowe #define FO_MODE 0x01 /* National PC8477 types only */ 110*5b6ecd7fSRichard Lowe #define FO_RDTRK 0x02 111*5b6ecd7fSRichard Lowe #define FO_SPEC 0x03 112*5b6ecd7fSRichard Lowe #define FO_SDRV 0x04 /* read status register 3 */ 113*5b6ecd7fSRichard Lowe #define FO_WRDAT 0x05 114*5b6ecd7fSRichard Lowe #define FO_RDDAT 0x06 115*5b6ecd7fSRichard Lowe #define FO_RECAL 0x07 116*5b6ecd7fSRichard Lowe #define FO_SINT 0x08 117*5b6ecd7fSRichard Lowe #define FO_WRDEL 0x09 118*5b6ecd7fSRichard Lowe #define FO_RDID 0x0A 119*5b6ecd7fSRichard Lowe #define FO_RDDEL 0x0C 120*5b6ecd7fSRichard Lowe #define FO_FRMT 0x0D 121*5b6ecd7fSRichard Lowe #define FO_SEEK 0x0F 122*5b6ecd7fSRichard Lowe #define FO_VRSN 0x10 /* get version */ 123*5b6ecd7fSRichard Lowe #define FO_PERP 0x12 /* perpendicular mode */ 124*5b6ecd7fSRichard Lowe #define FO_CNFG 0x13 /* configure */ 125*5b6ecd7fSRichard Lowe #define FO_NSC 0x18 /* identify National chip */ 126*5b6ecd7fSRichard Lowe 127*5b6ecd7fSRichard Lowe /* option bits */ 128*5b6ecd7fSRichard Lowe #define FO_MT 0x80 /* multi-track operation */ 129*5b6ecd7fSRichard Lowe #define FO_MFM 0x40 /* double & high density disks */ 130*5b6ecd7fSRichard Lowe #define FO_FM 0x00 /* single density disks */ 131*5b6ecd7fSRichard Lowe #define FO_SK 0x20 /* skip deleted adr mark */ 132*5b6ecd7fSRichard Lowe 133*5b6ecd7fSRichard Lowe 134*5b6ecd7fSRichard Lowe #define S0_ICMASK 0xC0 /* status register 0 */ 135*5b6ecd7fSRichard Lowe #define S0_XRDY 0xC0 136*5b6ecd7fSRichard Lowe #define S0_IVCMD 0x80 137*5b6ecd7fSRichard Lowe #define S0_ABTERM 0x40 138*5b6ecd7fSRichard Lowe #define S0_SEKEND 0x20 139*5b6ecd7fSRichard Lowe #define S0_ECHK 0x10 140*5b6ecd7fSRichard Lowe #define S0_NOTRDY 0x08 141*5b6ecd7fSRichard Lowe 142*5b6ecd7fSRichard Lowe #define S1_EOCYL 0x80 /* status register 1 */ 143*5b6ecd7fSRichard Lowe #define S1_CRCER 0x20 144*5b6ecd7fSRichard Lowe #define S1_OVRUN 0x10 145*5b6ecd7fSRichard Lowe #define S1_NODATA 0x04 146*5b6ecd7fSRichard Lowe #define S1_MADMK 0x01 147*5b6ecd7fSRichard Lowe 148*5b6ecd7fSRichard Lowe #define S3_FAULT 0x80 /* status register 3 */ 149*5b6ecd7fSRichard Lowe #define S3_WPROT 0x40 150*5b6ecd7fSRichard Lowe #define S3_DRRDY 0x20 151*5b6ecd7fSRichard Lowe #define S3_TRK0 0x10 152*5b6ecd7fSRichard Lowe #define S3_2SIDE 0x08 153*5b6ecd7fSRichard Lowe #define S3_HEAD 0x04 154*5b6ecd7fSRichard Lowe #define S3_UNIT 0x03 155*5b6ecd7fSRichard Lowe 156*5b6ecd7fSRichard Lowe 157*5b6ecd7fSRichard Lowe /* 158*5b6ecd7fSRichard Lowe * controller chip values 159*5b6ecd7fSRichard Lowe */ 160*5b6ecd7fSRichard Lowe #define i8272A 0x8272 161*5b6ecd7fSRichard Lowe #define uPD72064 0x72064 /* NEC */ 162*5b6ecd7fSRichard Lowe /* enhanced floppy controllers */ 163*5b6ecd7fSRichard Lowe #define i82077 0x82077 164*5b6ecd7fSRichard Lowe #define PC87322 0x87322 /* National Semiconducter */ 165*5b6ecd7fSRichard Lowe #define FDC37C665 0x37c665 /* SMC */ 166*5b6ecd7fSRichard Lowe #define FDC37C666 0x37c666 /* SMC */ 167*5b6ecd7fSRichard Lowe 168*5b6ecd7fSRichard Lowe #ifdef __cplusplus 169*5b6ecd7fSRichard Lowe } 170*5b6ecd7fSRichard Lowe #endif 171*5b6ecd7fSRichard Lowe 172*5b6ecd7fSRichard Lowe #endif /* !_SYS_I8272A_H */ 173