cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

aha152x.rst (7000B)


      1.. SPDX-License-Identifier: GPL-2.0
      2.. include:: <isonum.txt>
      3
      4=====================================================
      5Adaptec AHA-1520/1522 SCSI driver for Linux (aha152x)
      6=====================================================
      7
      8Copyright |copy| 1993-1999 Jürgen Fischer <fischer@norbit.de>
      9
     10TC1550 patches by Luuk van Dijk (ldz@xs4all.nl)
     11
     12
     13In Revision 2 the driver was modified a lot (especially the
     14bottom-half handler complete()).
     15
     16The driver is much cleaner now, has support for the new
     17error handling code in 2.3, produced less cpu load (much
     18less polling loops), has slightly higher throughput (at
     19least on my ancient test box; a i486/33Mhz/20MB).
     20
     21
     22Configuration Arguments
     23=======================
     24
     25============  ========================================  ======================
     26IOPORT        base io address                           (0x340/0x140)
     27IRQ           interrupt level                           (9-12; default 11)
     28SCSI_ID       scsi id of controller                     (0-7; default 7)
     29RECONNECT     allow targets to disconnect from the bus  (0/1; default 1 [on])
     30PARITY        enable parity checking                    (0/1; default 1 [on])
     31SYNCHRONOUS   enable synchronous transfers              (0/1; default 1 [on])
     32DELAY:        bus reset delay                           (default 100)
     33EXT_TRANS:    enable extended translation               (0/1: default 0 [off])
     34              (see NOTES)
     35============  ========================================  ======================
     36
     37Compile Time Configuration
     38==========================
     39
     40(go into AHA152X in drivers/scsi/Makefile):
     41
     42- DAUTOCONF
     43    use configuration the controller reports (AHA-152x only)
     44
     45- DSKIP_BIOSTEST
     46    Don't test for BIOS signature (AHA-1510 or disabled BIOS)
     47
     48- DSETUP0="{ IOPORT, IRQ, SCSI_ID, RECONNECT, PARITY, SYNCHRONOUS, DELAY, EXT_TRANS }"
     49    override for the first controller
     50
     51- DSETUP1="{ IOPORT, IRQ, SCSI_ID, RECONNECT, PARITY, SYNCHRONOUS, DELAY, EXT_TRANS }"
     52    override for the second controller
     53
     54- DAHA152X_DEBUG
     55    enable debugging output
     56
     57- DAHA152X_STAT
     58    enable some statistics
     59
     60
     61LILO Command Line Options
     62=========================
     63
     64 ::
     65
     66    aha152x=<IOPORT>[,<IRQ>[,<SCSI-ID>[,<RECONNECT>[,<PARITY>[,<SYNCHRONOUS>[,<DELAY> [,<EXT_TRANS]]]]]]]
     67
     68 The normal configuration can be overridden by specifying a command line.
     69 When you do this, the BIOS test is skipped. Entered values have to be
     70 valid (known).  Don't use values that aren't supported under normal
     71 operation.  If you think that you need other values: contact me.
     72 For two controllers use the aha152x statement twice.
     73
     74
     75Symbols for Module Configuration
     76================================
     77
     78Choose from 2 alternatives:
     79
     801. specify everything (old)::
     81
     82    aha152x=IOPORT,IRQ,SCSI_ID,RECONNECT,PARITY,SYNCHRONOUS,DELAY,EXT_TRANS
     83
     84  configuration override for first controller
     85
     86  ::
     87
     88    aha152x1=IOPORT,IRQ,SCSI_ID,RECONNECT,PARITY,SYNCHRONOUS,DELAY,EXT_TRANS
     89
     90  configuration override for second controller
     91
     922. specify only what you need to (irq or io is required; new)
     93
     94io=IOPORT0[,IOPORT1]
     95  IOPORT for first and second controller
     96
     97irq=IRQ0[,IRQ1]
     98  IRQ for first and second controller
     99
    100scsiid=SCSIID0[,SCSIID1]
    101  SCSIID for first and second controller
    102
    103reconnect=RECONNECT0[,RECONNECT1]
    104  allow targets to disconnect for first and second controller
    105
    106parity=PAR0[PAR1]
    107  use parity for first and second controller
    108
    109sync=SYNCHRONOUS0[,SYNCHRONOUS1]
    110  enable synchronous transfers for first and second controller
    111
    112delay=DELAY0[,DELAY1]
    113  reset DELAY for first and second controller
    114
    115exttrans=EXTTRANS0[,EXTTRANS1]
    116  enable extended translation for first and second controller
    117
    118
    119If you use both alternatives the first will be taken.
    120
    121
    122Notes on EXT_TRANS
    123==================
    124
    125SCSI uses block numbers to address blocks/sectors on a device.
    126The BIOS uses a cylinder/head/sector addressing scheme (C/H/S)
    127scheme instead.  DOS expects a BIOS or driver that understands this
    128C/H/S addressing.
    129
    130The number of cylinders/heads/sectors is called geometry and is required
    131as base for requests in C/H/S addressing.  SCSI only knows about the
    132total capacity of disks in blocks (sectors).
    133
    134Therefore the SCSI BIOS/DOS driver has to calculate a logical/virtual
    135geometry just to be able to support that addressing scheme.  The geometry
    136returned by the SCSI BIOS is a pure calculation and has nothing to
    137do with the real/physical geometry of the disk (which is usually
    138irrelevant anyway).
    139
    140Basically this has no impact at all on Linux, because it also uses block
    141instead of C/H/S addressing.  Unfortunately C/H/S addressing is also used
    142in the partition table and therefore every operating system has to know
    143the right geometry to be able to interpret it.
    144
    145Moreover there are certain limitations to the C/H/S addressing scheme,
    146namely the address space is limited to up to 255 heads, up to 63 sectors
    147and a maximum of 1023 cylinders.
    148
    149The AHA-1522 BIOS calculates the geometry by fixing the number of heads
    150to 64, the number of sectors to 32 and by calculating the number of
    151cylinders by dividing the capacity reported by the disk by 64*32 (1 MB).
    152This is considered to be the default translation.
    153
    154With respect to the limit of 1023 cylinders using C/H/S you can only
    155address the first GB of your disk in the partition table.  Therefore
    156BIOSes of some newer controllers based on the AIC-6260/6360 support
    157extended translation.  This means that the BIOS uses 255 for heads,
    15863 for sectors and then divides the capacity of the disk by 255*63
    159(about 8 MB), as soon it sees a disk greater than 1 GB.  That results
    160in a maximum of about 8 GB addressable diskspace in the partition table
    161(but there are already bigger disks out there today).
    162
    163To make it even more complicated the translation mode might/might
    164not be configurable in certain BIOS setups.
    165
    166This driver does some more or less failsafe guessing to get the
    167geometry right in most cases:
    168
    169- for disks<1GB: use default translation (C/32/64)
    170
    171- for disks>1GB:
    172
    173  - take current geometry from the partition table
    174    (using scsicam_bios_param and accept only 'valid' geometries,
    175    ie. either (C/32/64) or (C/63/255)).  This can be extended translation
    176    even if it's not enabled in the driver.
    177
    178  - if that fails, take extended translation if enabled by override,
    179    kernel or module parameter, otherwise take default translation and
    180    ask the user for verification.  This might on not yet partitioned
    181    disks.
    182
    183
    184References Used
    185===============
    186
    187 "AIC-6260 SCSI Chip Specification", Adaptec Corporation.
    188
    189 "SCSI COMPUTER SYSTEM INTERFACE - 2 (SCSI-2)", X3T9.2/86-109 rev. 10h
    190
    191 "Writing a SCSI device driver for Linux", Rik Faith (faith@cs.unc.edu)
    192
    193 "Kernel Hacker's Guide", Michael K. Johnson (johnsonm@sunsite.unc.edu)
    194
    195 "Adaptec 1520/1522 User's Guide", Adaptec Corporation.
    196
    197 Michael K. Johnson (johnsonm@sunsite.unc.edu)
    198
    199 Drew Eckhardt (drew@cs.colorado.edu)
    200
    201 Eric Youngdale (eric@andante.org)
    202
    203 special thanks to Eric Youngdale for the free(!) supplying the
    204 documentation on the chip.