/* $NetBSD: iwm_fdvar.h,v 1.13 2007/03/05 15:32:33 he Exp $ */ /* * Copyright (c) 1997, 1998 Hauke Fath. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef _MAC68K_FDVAR_H #define _MAC68K_FDVAR_H /** ** Constants **/ enum { IWM_MAX_DRIVE = 2, /* Attachable drives */ IWM_GCR_DISK_ZONES = 5, /* Zones on GCR disk */ IWM_MAX_GCR_SECTORS = 12, /* Max. sectors per GCR track */ IWM_MAX_FLOPPY_SECT = 50, /* Larger than the highest sector */ /* number likely to occur */ }; /* Physical track format codes */ enum { IWM_GCR, /* Apple's Group Code Recording format */ IWM_MFM_DD, /* Standard MFM on DD disk (250 KBit/s) */ IWM_MFM_HD /* Standard MFM on HD disk (500 KBit/s) */ }; /* Drive softc flags */ enum { IWM_FD_IS_OPEN = 0x00000001, IWM_FD_MOTOR_ON = 0x00000002 }; /* seek() behaviour */ enum { IWM_SEEK_VANILLA, IWM_SEEK_RECAL, IWM_SEEK_VERIFY }; /* I/O direction */ enum { IWM_WRITE = 0, IWM_READ }; /** ** Data Types **/ /* * Floppy disk format information * * XXX How to describe ZBR here? UN*X disk drive handling -- clinging * tenaciously to the trailing edge of technology... */ struct fdInfo { short heads; /* # of heads the drive has */ short tracks; /* # of tracks per side (cyl's) */ short sectorSize; /* Bytes per sector */ short secPerTrack; /* fake */ short secPerCyl; /* fake */ short secPerDisk; /* # of sectors per __disk__ */ short stepRate; /* in ms (is a software delay) */ short interleave; /* Sector interleave */ short physFormat; /* GCR, MFM DD, MFM HD */ const char *description; }; typedef struct fdInfo fdInfo_t; /* * Current physical location on Sony GCR disk */ struct diskPosition { short track; short oldTrack; short side; short sector; short maxSect; /* Highest sector # for this track */ }; typedef struct diskPosition diskPosition_t; /* * Zone recording scheme (per disk surface/head) */ struct diskZone { short tracks; /* # of tracks per zone */ short sectPerTrack; short firstBlock; short lastBlock; }; typedef struct diskZone diskZone_t; /* * Arguments passed between iwmAttach() and the fd probe routines. */ struct iwmAttachArgs { fdInfo_t *driveType; /* Default drive parameters */ short unit; /* Current drive # */ }; typedef struct iwmAttachArgs iwmAttachArgs_t; /* * Software state per disk: the IWM can have max. 2 drives. Newer * machines don't even have a port for an external drive. * */ struct fd_softc { struct device devInfo; /* generic device info */ struct disk diskInfo; /* generic disk info */ struct bufq_state *bufQueue; /* queue of buf's */ int sc_active; /* number of active requests */ struct callout motor_ch; /* motor callout */ /* private stuff here */ /* errors & retries in current I/O job */ int iwmErr; /* Last IO error */ int ioRetries; int seekRetries; int sectRetries; int verifyRetries; /* hardware info */ int drvFlags; /* Copy of drive flags */ short stepDirection; /* Current step direction */ diskPosition_t pos; /* Physical position on disk */ /* drive info */ short unit; /* Drive # as seen by IWM */ short partition; /* "Partition" info {a,b,c,...} */ fdInfo_t *defaultType; /* default floppy format */ fdInfo_t *currentType; /* current floppy format */ int state; /* XXX */ /* data transfer info */ int ioDirection; /* Read/write */ daddr_t startBlk; /* Starting block # */ int bytesLeft; /* Bytes left to transfer */ int bytesDone; /* Bytes transferred */ char *current_buffer; /* target of current data transfer */ unsigned char *cbuf; /* ptr to cylinder cache */ int cachedSide; /* Which head is cached? */ cylCacheSlot_t r_slots[IWM_MAX_GCR_SECTORS]; cylCacheSlot_t w_slots[IWM_MAX_GCR_SECTORS]; int writeLabel; /* Write access to disklabel? */ sectorHdr_t sHdr; /* current sector header */ }; typedef struct fd_softc fd_softc_t; /* * Software state of IWM controller * * SWIM/MFM mode may have some state to keep here. */ struct iwm_softc { struct device devInfo; /* generic device info */ int drives; /* # of attached fd's */ fd_softc_t *fd[IWM_MAX_DRIVE]; /* ptrs to children */ int state; /* make that an enum? */ u_char modeReg; /* Copy of IWM mode register */ short maxRetries; /* I/O retries */ int errors; int underruns; /* data not delivered in time */ }; typedef struct iwm_softc iwm_softc_t; /** ** Exported functions **/ /* * IWM Loadable Kernel Module : Exported functions */ #ifdef _LKM int fdModInit(void); void fdModFree(void); #endif int iwmInit(void); int iwmCheckDrive(int32_t); int iwmSelectDrive(int32_t); int iwmSelectSide(int32_t); int iwmTrack00(void); int iwmSeek(int32_t); int iwmReadSector(sectorHdr_t *, cylCacheSlot_t *, void *); int iwmWriteSector(sectorHdr_t *, cylCacheSlot_t *); int iwmDiskEject(int32_t); /* drive = [0..1] */ int iwmMotor(int32_t, int32_t); /* on(1)/off(0) */ /* * Debugging only */ int iwmQueryDrvFlag(int32_t, int32_t); /* reg = [0..15] */ /* Make sure we run at splhigh when calling! */ int iwmReadSectHdr(sectorHdr_t *); #if 0 /* XXX not yet */ int iwmReadRawSector(int32_t, void *); int iwmWriteRawSector(int32_t, void *); int iwmReadRawTrack(int32_t, void *); #endif #endif /* _MAC68K_FDVAR_H */