1/*- 2 * Copyright (c) 1998,1999,2000 S�ren Schmidt 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer, 10 * without modification, immediately at the beginning of the file. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 3. The name of the author may not be used to endorse or promote products 15 * derived from this software without specific prior written permission. 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 *
| 1/*- 2 * Copyright (c) 1998,1999,2000 S�ren Schmidt 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer, 10 * without modification, immediately at the beginning of the file. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 3. The name of the author may not be used to endorse or promote products 15 * derived from this software without specific prior written permission. 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 *
|
28 * $FreeBSD: head/sys/dev/ata/ata-dma.c 56138 2000-01-17 02:04:19Z sos $
| 28 * $FreeBSD: head/sys/dev/ata/ata-dma.c 56558 2000-01-24 20:45:24Z sos $
|
29 */ 30 31#include "pci.h" 32#include "apm.h" 33#include <sys/param.h> 34#include <sys/systm.h> 35#include <sys/buf.h> 36#include <sys/malloc.h> 37#include <sys/bus.h> 38#include <sys/disk.h> 39#include <sys/devicestat.h> 40#include <vm/vm.h> 41#include <vm/pmap.h> 42#if NPCI > 0 43#include <pci/pcivar.h> 44#endif 45#if NAPM > 0 46#include <machine/apm_bios.h> 47#endif 48#include <dev/ata/ata-all.h> 49#include <dev/ata/ata-disk.h> 50 51/* prototypes */ 52static void promise_timing(struct ata_softc *, int32_t, int32_t); 53static void hpt366_timing(struct ata_softc *, int32_t, int32_t); 54 55/* misc defines */
| 29 */ 30 31#include "pci.h" 32#include "apm.h" 33#include <sys/param.h> 34#include <sys/systm.h> 35#include <sys/buf.h> 36#include <sys/malloc.h> 37#include <sys/bus.h> 38#include <sys/disk.h> 39#include <sys/devicestat.h> 40#include <vm/vm.h> 41#include <vm/pmap.h> 42#if NPCI > 0 43#include <pci/pcivar.h> 44#endif 45#if NAPM > 0 46#include <machine/apm_bios.h> 47#endif 48#include <dev/ata/ata-all.h> 49#include <dev/ata/ata-disk.h> 50 51/* prototypes */ 52static void promise_timing(struct ata_softc *, int32_t, int32_t); 53static void hpt366_timing(struct ata_softc *, int32_t, int32_t); 54 55/* misc defines */
|
56#define MIN(a,b) ((a)>(b)?(b):(a))
| |
57#ifdef __alpha__ 58#undef vtophys 59#define vtophys(va) alpha_XXX_dmamap((vm_offset_t)va) 60#endif 61 62#if NPCI > 0 63 64int32_t 65ata_dmainit(struct ata_softc *scp, int32_t device, 66 int32_t apiomode, int32_t wdmamode, int32_t udmamode) 67{
| 56#ifdef __alpha__ 57#undef vtophys 58#define vtophys(va) alpha_XXX_dmamap((vm_offset_t)va) 59#endif 60 61#if NPCI > 0 62 63int32_t 64ata_dmainit(struct ata_softc *scp, int32_t device, 65 int32_t apiomode, int32_t wdmamode, int32_t udmamode) 66{
|
68 int32_t devno = (scp->unit << 1) + ((device == ATA_MASTER) ? 0 : 1);
| 67 int32_t devno = (scp->unit << 1) + ATA_DEV(device);
|
69 int32_t error;
| 68 int32_t error;
|
70 void *dmatab;
| |
71 72 if (!scp->bmaddr) 73 return -1; 74 75 /* if simplex controller, only allow DMA on primary channel */ 76 if (scp->unit == 1) { 77 outb(scp->bmaddr + ATA_BMSTAT_PORT, inb(scp->bmaddr + ATA_BMSTAT_PORT) & 78 (ATA_BMSTAT_DMA_MASTER | ATA_BMSTAT_DMA_SLAVE)); 79 if (inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_DMA_SIMPLEX) {
| 69 70 if (!scp->bmaddr) 71 return -1; 72 73 /* if simplex controller, only allow DMA on primary channel */ 74 if (scp->unit == 1) { 75 outb(scp->bmaddr + ATA_BMSTAT_PORT, inb(scp->bmaddr + ATA_BMSTAT_PORT) & 76 (ATA_BMSTAT_DMA_MASTER | ATA_BMSTAT_DMA_SLAVE)); 77 if (inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_DMA_SIMPLEX) {
|
80 printf("ata%d: simplex device, DMA on primary channel only\n", 81 scp->lun);
| 78 ata_printf(scp, device, "simplex device, DMA on primary only\n");
|
82 return -1; 83 } 84 } 85
| 79 return -1; 80 } 81 } 82
|
86 if (!(dmatab = malloc(PAGE_SIZE, M_DEVBUF, M_NOWAIT))) 87 return -1;
| 83 if (!scp->dmatab[ATA_DEV(device)]) { 84 void *dmatab;
|
88
| 85
|
89 if (((uintptr_t)dmatab >> PAGE_SHIFT) ^ 90 (((uintptr_t)dmatab + PAGE_SIZE - 1) >> PAGE_SHIFT)) { 91 printf("ata%d-%s: dmatab crosses page boundary, no DMA\n", 92 scp->lun, (device == ATA_MASTER) ? "master" : "slave"); 93 free(dmatab, M_DEVBUF); 94 return -1;
| 86 if (!(dmatab = malloc(PAGE_SIZE, M_DEVBUF, M_NOWAIT))) 87 return -1; 88 if (((uintptr_t)dmatab >> PAGE_SHIFT) ^ 89 (((uintptr_t)dmatab + PAGE_SIZE - 1) >> PAGE_SHIFT)) { 90 ata_printf(scp, device, "dmatab crosses page boundary, no DMA\n"); 91 free(dmatab, M_DEVBUF); 92 return -1; 93 } 94 scp->dmatab[ATA_DEV(device)] = dmatab;
|
95 }
| 95 }
|
96 scp->dmatab[(device == ATA_MASTER) ? 0 : 1] = dmatab;
| |
97 98 switch (scp->chiptype) { 99 100 case 0x71118086: /* Intel PIIX4 */ 101 case 0x71998086: /* Intel PIIX4e */ 102 case 0x24118086: /* Intel ICH */ 103 case 0x24218086: /* Intel ICH0 */ 104 if (udmamode >= 2) { 105 int32_t mask48, new48; 106 107 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 108 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 109 if (bootverbose)
| 96 97 switch (scp->chiptype) { 98 99 case 0x71118086: /* Intel PIIX4 */ 100 case 0x71998086: /* Intel PIIX4e */ 101 case 0x24118086: /* Intel ICH */ 102 case 0x24218086: /* Intel ICH0 */ 103 if (udmamode >= 2) { 104 int32_t mask48, new48; 105 106 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 107 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 108 if (bootverbose)
|
110 printf("ata%d-%s: %s setting up UDMA2 mode on %s chip\n", 111 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 112 (error) ? "failed" : "success", 113 (scp->chiptype == 0x24118086) ? "ICH" : 114 (scp->chiptype == 0x24218086) ? "ICH0" :"PIIX4");
| 109 ata_printf(scp, device, "%s setting up UDMA2 mode on %s chip\n", 110 (error) ? "failed" : "success", 111 (scp->chiptype == 0x24118086) ? "ICH" : 112 (scp->chiptype == 0x24218086) ? "ICH0" :"PIIX4");
|
115 if (!error) { 116 mask48 = (1 << devno) + (3 << (16 + (devno << 2))); 117 new48 = (1 << devno) + (2 << (16 + (devno << 2))); 118 pci_write_config(scp->dev, 0x48, 119 (pci_read_config(scp->dev, 0x48, 4) & 120 ~mask48) | new48, 4);
| 113 if (!error) { 114 mask48 = (1 << devno) + (3 << (16 + (devno << 2))); 115 new48 = (1 << devno) + (2 << (16 + (devno << 2))); 116 pci_write_config(scp->dev, 0x48, 117 (pci_read_config(scp->dev, 0x48, 4) & 118 ~mask48) | new48, 4);
|
121 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 119 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
122 return 0; 123 } 124 } 125 /* FALLTHROUGH */ 126 127 case 0x70108086: /* Intel PIIX3 */ 128 if (wdmamode >= 2 && apiomode >= 4) { 129 int32_t mask40, new40, mask44, new44; 130 131 /* if SITRE not set doit for both channels */ 132 if (!((pci_read_config(scp->dev, 0x40, 4)>>(scp->unit<<8))&0x4000)){ 133 new40 = pci_read_config(scp->dev, 0x40, 4); 134 new44 = pci_read_config(scp->dev, 0x44, 4); 135 if (!(new40 & 0x00004000)) { 136 new44 &= ~0x0000000f; 137 new44 |= ((new40&0x00003000)>>10)|((new40&0x00000300)>>8); 138 } 139 if (!(new40 & 0x40000000)) { 140 new44 &= ~0x000000f0; 141 new44 |= ((new40&0x30000000)>>22)|((new40&0x03000000)>>20); 142 } 143 new40 |= 0x40004000; 144 pci_write_config(scp->dev, 0x40, new40, 4); 145 pci_write_config(scp->dev, 0x44, new44, 4); 146 } 147 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 148 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 149 if (bootverbose)
| 120 return 0; 121 } 122 } 123 /* FALLTHROUGH */ 124 125 case 0x70108086: /* Intel PIIX3 */ 126 if (wdmamode >= 2 && apiomode >= 4) { 127 int32_t mask40, new40, mask44, new44; 128 129 /* if SITRE not set doit for both channels */ 130 if (!((pci_read_config(scp->dev, 0x40, 4)>>(scp->unit<<8))&0x4000)){ 131 new40 = pci_read_config(scp->dev, 0x40, 4); 132 new44 = pci_read_config(scp->dev, 0x44, 4); 133 if (!(new40 & 0x00004000)) { 134 new44 &= ~0x0000000f; 135 new44 |= ((new40&0x00003000)>>10)|((new40&0x00000300)>>8); 136 } 137 if (!(new40 & 0x40000000)) { 138 new44 &= ~0x000000f0; 139 new44 |= ((new40&0x30000000)>>22)|((new40&0x03000000)>>20); 140 } 141 new40 |= 0x40004000; 142 pci_write_config(scp->dev, 0x40, new40, 4); 143 pci_write_config(scp->dev, 0x44, new44, 4); 144 } 145 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 146 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 147 if (bootverbose)
|
150 printf("ata%d-%s: %s setting up WDMA2 mode on %s chip\n", 151 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 152 (error) ? "failed" : "success", 153 (scp->chiptype == 0x70108086) ? "PIIX3" : 154 (scp->chiptype == 0x24118086) ? "ICH" : 155 (scp->chiptype == 0x24218086) ? "ICH0" :"PIIX4");
| 148 ata_printf(scp, device, "%s setting up WDMA2 mode on %s chip\n", 149 (error) ? "failed" : "success", 150 (scp->chiptype == 0x70108086) ? "PIIX3" : 151 (scp->chiptype == 0x24118086) ? "ICH" : 152 (scp->chiptype == 0x24218086) ? "ICH0" :"PIIX4");
|
156 if (!error) { 157 if (device == ATA_MASTER) { 158 mask40 = 0x0000330f; 159 new40 = 0x00002307; 160 mask44 = 0; 161 new44 = 0; 162 } 163 else { 164 mask40 = 0x000000f0; 165 new40 = 0x00000070; 166 mask44 = 0x0000000f; 167 new44 = 0x0000000b; 168 } 169 if (scp->unit) { 170 mask40 <<= 16; 171 new40 <<= 16; 172 mask44 <<= 4; 173 new44 <<= 4; 174 } 175 pci_write_config(scp->dev, 0x40, 176 (pci_read_config(scp->dev, 0x40, 4) & ~mask40)| 177 new40, 4); 178 pci_write_config(scp->dev, 0x44, 179 (pci_read_config(scp->dev, 0x44, 4) & ~mask44)| 180 new44, 4);
| 153 if (!error) { 154 if (device == ATA_MASTER) { 155 mask40 = 0x0000330f; 156 new40 = 0x00002307; 157 mask44 = 0; 158 new44 = 0; 159 } 160 else { 161 mask40 = 0x000000f0; 162 new40 = 0x00000070; 163 mask44 = 0x0000000f; 164 new44 = 0x0000000b; 165 } 166 if (scp->unit) { 167 mask40 <<= 16; 168 new40 <<= 16; 169 mask44 <<= 4; 170 new44 <<= 4; 171 } 172 pci_write_config(scp->dev, 0x40, 173 (pci_read_config(scp->dev, 0x40, 4) & ~mask40)| 174 new40, 4); 175 pci_write_config(scp->dev, 0x44, 176 (pci_read_config(scp->dev, 0x44, 4) & ~mask44)| 177 new44, 4);
|
181 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 178 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
182 return 0; 183 } 184 } 185 /* we could set PIO mode timings, but we assume the BIOS did that */ 186 break; 187 188 case 0x12308086: /* Intel PIIX */ 189 if (wdmamode >= 2 && apiomode >= 4) { 190 int32_t word40; 191 192 word40 = pci_read_config(scp->dev, 0x40, 4); 193 word40 >>= scp->unit * 16; 194 195 /* Check for timing config usable for DMA on controller */ 196 if (!((word40 & 0x3300) == 0x2300 && 197 ((word40 >> (device == ATA_MASTER ? 0 : 4)) & 1) == 1)) 198 break; 199 200 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 201 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 202 if (bootverbose)
| 179 return 0; 180 } 181 } 182 /* we could set PIO mode timings, but we assume the BIOS did that */ 183 break; 184 185 case 0x12308086: /* Intel PIIX */ 186 if (wdmamode >= 2 && apiomode >= 4) { 187 int32_t word40; 188 189 word40 = pci_read_config(scp->dev, 0x40, 4); 190 word40 >>= scp->unit * 16; 191 192 /* Check for timing config usable for DMA on controller */ 193 if (!((word40 & 0x3300) == 0x2300 && 194 ((word40 >> (device == ATA_MASTER ? 0 : 4)) & 1) == 1)) 195 break; 196 197 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 198 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 199 if (bootverbose)
|
203 printf("ata%d-%s: %s setting up WDMA2 mode on PIIX chip\n", 204 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 205 (error) ? "failed" : "success");
| 200 ata_printf(scp, device, 201 "%s setting up WDMA2 mode on PIIX chip\n", 202 (error) ? "failed" : "success");
|
206 if (!error) {
| 203 if (!error) {
|
207 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 204 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
208 return 0; 209 } 210 } 211 break; 212 213 case 0x522910b9: /* AcerLabs Aladdin IV/V */ 214 /* the Aladdin doesn't support ATAPI DMA on both master & slave */ 215 if (scp->devices & ATA_ATAPI_MASTER && scp->devices & ATA_ATAPI_SLAVE) {
| 205 return 0; 206 } 207 } 208 break; 209 210 case 0x522910b9: /* AcerLabs Aladdin IV/V */ 211 /* the Aladdin doesn't support ATAPI DMA on both master & slave */ 212 if (scp->devices & ATA_ATAPI_MASTER && scp->devices & ATA_ATAPI_SLAVE) {
|
216 printf("ata%d: Aladdin: two atapi devices on this channel, " 217 "DMA disabled\n", scp->lun);
| 213 ata_printf(scp, device, 214 "Aladdin: two atapi devices on this channel, no DMA\n");
|
218 break; 219 } 220 if (udmamode >= 2) { 221 int32_t word54 = pci_read_config(scp->dev, 0x54, 4); 222 223 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 224 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 225 if (bootverbose)
| 215 break; 216 } 217 if (udmamode >= 2) { 218 int32_t word54 = pci_read_config(scp->dev, 0x54, 4); 219 220 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 221 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 222 if (bootverbose)
|
226 printf("ata%d-%s: %s setting up UDMA2 mode on Aladdin chip\n", 227 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 228 (error) ? "failed" : "success");
| 223 ata_printf(scp, device, 224 "%s setting up UDMA2 mode on Aladdin chip\n", 225 (error) ? "failed" : "success");
|
229 if (!error) { 230 word54 |= 0x5555; 231 word54 |= (0x0a << (16 + (scp->unit << 3) + (device << 2))); 232 pci_write_config(scp->dev, 0x54, word54, 4); 233 pci_write_config(scp->dev, 0x53, 234 pci_read_config(scp->dev, 0x53, 1) | 0x03, 1); 235 scp->flags |= ATA_ATAPI_DMA_RO;
| 226 if (!error) { 227 word54 |= 0x5555; 228 word54 |= (0x0a << (16 + (scp->unit << 3) + (device << 2))); 229 pci_write_config(scp->dev, 0x54, word54, 4); 230 pci_write_config(scp->dev, 0x53, 231 pci_read_config(scp->dev, 0x53, 1) | 0x03, 1); 232 scp->flags |= ATA_ATAPI_DMA_RO;
|
236 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 233 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
237 return 0; 238 } 239 } 240 if (wdmamode >= 2 && apiomode >= 4) { 241 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 242 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 243 if (bootverbose)
| 234 return 0; 235 } 236 } 237 if (wdmamode >= 2 && apiomode >= 4) { 238 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 239 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 240 if (bootverbose)
|
244 printf("ata%d-%s: %s setting up WDMA2 mode on Aladdin chip\n", 245 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 246 (error) ? "failed" : "success");
| 241 ata_printf(scp, device, 242 "%s setting up WDMA2 mode on Aladdin chip\n", 243 (error) ? "failed" : "success");
|
247 if (!error) { 248 pci_write_config(scp->dev, 0x53, 249 pci_read_config(scp->dev, 0x53, 1) | 0x03, 1); 250 scp->flags |= ATA_ATAPI_DMA_RO;
| 244 if (!error) { 245 pci_write_config(scp->dev, 0x53, 246 pci_read_config(scp->dev, 0x53, 1) | 0x03, 1); 247 scp->flags |= ATA_ATAPI_DMA_RO;
|
251 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 248 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
252 return 0; 253 } 254 } 255 /* we could set PIO mode timings, but we assume the BIOS did that */ 256 break; 257 258 case 0x05711106: /* VIA 82C571, 82C586, 82C596 & 82C686 */ 259 case 0x74091022: /* AMD 756 */ 260 /* UDMA modes on 82C686 */ 261 if (ata_find_dev(scp->dev, 0x06861106)) { 262 if (udmamode >= 4) { 263 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 264 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 265 if (bootverbose)
| 249 return 0; 250 } 251 } 252 /* we could set PIO mode timings, but we assume the BIOS did that */ 253 break; 254 255 case 0x05711106: /* VIA 82C571, 82C586, 82C596 & 82C686 */ 256 case 0x74091022: /* AMD 756 */ 257 /* UDMA modes on 82C686 */ 258 if (ata_find_dev(scp->dev, 0x06861106)) { 259 if (udmamode >= 4) { 260 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 261 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 262 if (bootverbose)
|
266 printf("ata%d-%s: %s setting up UDMA4 mode on VIA chip\n", 267 scp->lun, (device == ATA_MASTER) ? "master":"slave", 268 (error) ? "failed" : "success");
| 263 ata_printf(scp, device, "%s setting up UDMA4 mode on VIA chip\n", 264 (error) ? "failed" : "success");
|
269 if (!error) { 270 pci_write_config(scp->dev, 0x53 - devno, 0xe8, 1);
| 265 if (!error) { 266 pci_write_config(scp->dev, 0x53 - devno, 0xe8, 1);
|
271 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA4;
| 267 scp->mode[ATA_DEV(device)] = ATA_UDMA4;
|
272 return 0; 273 } 274 } 275 if (udmamode >= 2) { 276 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 277 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 278 if (bootverbose)
| 268 return 0; 269 } 270 } 271 if (udmamode >= 2) { 272 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 273 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 274 if (bootverbose)
|
279 printf("ata%d-%s: %s setting up UDMA2 mode on VIA chip\n", 280 scp->lun, (device == ATA_MASTER) ? "master":"slave", 281 (error) ? "failed" : "success");
| 275 ata_printf(scp, device, 276 "%s setting up UDMA2 mode on VIA chip\n", 277 (error) ? "failed" : "success");
|
282 if (!error) { 283 pci_write_config(scp->dev, 0x53 - devno, 0xea, 1);
| 278 if (!error) { 279 pci_write_config(scp->dev, 0x53 - devno, 0xea, 1);
|
284 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 280 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
285 return 0; 286 } 287 } 288 } 289 290 /* UDMA4 mode on AMD 756 */ 291 if (udmamode >= 4 && scp->chiptype == 0x74091022) { 292 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 293 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 294 if (bootverbose)
| 281 return 0; 282 } 283 } 284 } 285 286 /* UDMA4 mode on AMD 756 */ 287 if (udmamode >= 4 && scp->chiptype == 0x74091022) { 288 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 289 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 290 if (bootverbose)
|
295 printf("ata%d-%s: %s setting up UDMA4 mode on AMD chip\n", 296 scp->lun, (device == ATA_MASTER) ? "master":"slave", 297 (error) ? "failed" : "success");
| 291 ata_printf(scp, device, 292 "%s setting up UDMA4 mode on AMD chip\n", 293 (error) ? "failed" : "success");
|
298 if (!error) { 299 pci_write_config(scp->dev, 0x53 - devno, 0xc3, 1);
| 294 if (!error) { 295 pci_write_config(scp->dev, 0x53 - devno, 0xc3, 1);
|
300 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA4;
| 296 scp->mode[ATA_DEV(device)] = ATA_UDMA4;
|
301 return 0; 302 } 303 } 304 305 /* UDMA2 mode only on 82C586 > rev1, 82C596, AMD 756 */ 306 if ((udmamode >= 2 && ata_find_dev(scp->dev, 0x05861106) && 307 pci_read_config(scp->dev, 0x08, 1) >= 0x01) || 308 (udmamode >= 2 && ata_find_dev(scp->dev, 0x05961106)) || 309 (udmamode >= 2 && scp->chiptype == 0x74091022)) { 310 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 311 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 312 if (bootverbose)
| 297 return 0; 298 } 299 } 300 301 /* UDMA2 mode only on 82C586 > rev1, 82C596, AMD 756 */ 302 if ((udmamode >= 2 && ata_find_dev(scp->dev, 0x05861106) && 303 pci_read_config(scp->dev, 0x08, 1) >= 0x01) || 304 (udmamode >= 2 && ata_find_dev(scp->dev, 0x05961106)) || 305 (udmamode >= 2 && scp->chiptype == 0x74091022)) { 306 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 307 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 308 if (bootverbose)
|
313 printf("ata%d-%s: %s setting up UDMA2 mode on %s chip\n", 314 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 315 (error) ? "failed" : "success", 316 (scp->chiptype == 0x74091022) ? "AMD" : "VIA");
| 309 ata_printf(scp, device, "%s setting up UDMA2 mode on %s chip\n", 310 (error) ? "failed" : "success", 311 (scp->chiptype == 0x74091022) ? "AMD" : "VIA");
|
317 if (!error) { 318 pci_write_config(scp->dev, 0x53 - devno, 0xc0, 1);
| 312 if (!error) { 313 pci_write_config(scp->dev, 0x53 - devno, 0xc0, 1);
|
319 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 314 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
320 return 0; 321 } 322 } 323 if (wdmamode >= 2 && apiomode >= 4) { 324 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 325 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 326 if (bootverbose)
| 315 return 0; 316 } 317 } 318 if (wdmamode >= 2 && apiomode >= 4) { 319 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 320 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 321 if (bootverbose)
|
327 printf("ata%d-%s: %s setting up WDMA2 mode on %s chip\n", 328 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 329 (error) ? "failed" : "success", 330 (scp->chiptype == 0x74091022) ? "AMD" : "VIA");
| 322 ata_printf(scp, device, "%s setting up WDMA2 mode on %s chip\n", 323 (error) ? "failed" : "success", 324 (scp->chiptype == 0x74091022) ? "AMD" : "VIA");
|
331 if (!error) { 332 pci_write_config(scp->dev, 0x53 - devno, 0x82, 1); 333 pci_write_config(scp->dev, 0x4b - devno, 0x31, 1);
| 325 if (!error) { 326 pci_write_config(scp->dev, 0x53 - devno, 0x82, 1); 327 pci_write_config(scp->dev, 0x4b - devno, 0x31, 1);
|
334 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 328 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
335 return 0; 336 } 337 } 338 /* we could set PIO mode timings, but we assume the BIOS did that */ 339 break; 340 341 case 0x55131039: /* SiS 5591 */ 342 if (udmamode >= 2) { 343 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 344 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 345 if (bootverbose)
| 329 return 0; 330 } 331 } 332 /* we could set PIO mode timings, but we assume the BIOS did that */ 333 break; 334 335 case 0x55131039: /* SiS 5591 */ 336 if (udmamode >= 2) { 337 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 338 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 339 if (bootverbose)
|
346 printf("ata%d-%s: %s setting up UDMA2 mode on SiS chip\n", 347 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 348 (error) ? "failed" : "success");
| 340 ata_printf(scp, device, 341 "%s setting up UDMA2 mode on SiS chip\n", 342 (error) ? "failed" : "success");
|
349 if (!error) { 350 pci_write_config(scp->dev, 0x40 + (devno << 1), 0xa301, 2);
| 343 if (!error) { 344 pci_write_config(scp->dev, 0x40 + (devno << 1), 0xa301, 2);
|
351 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 345 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
352 return 0; 353 } 354 } 355 if (wdmamode >=2 && apiomode >= 4) { 356 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 357 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 358 if (bootverbose)
| 346 return 0; 347 } 348 } 349 if (wdmamode >=2 && apiomode >= 4) { 350 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 351 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 352 if (bootverbose)
|
359 printf("ata%d-%s: %s setting up WDMA2 mode on SiS chip\n", 360 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 361 (error) ? "failed" : "success");
| 353 ata_printf(scp, device, 354 "%s setting up WDMA2 mode on SiS chip\n", 355 (error) ? "failed" : "success");
|
362 if (!error) { 363 pci_write_config(scp->dev, 0x40 + (devno << 1), 0x0301, 2);
| 356 if (!error) { 357 pci_write_config(scp->dev, 0x40 + (devno << 1), 0x0301, 2);
|
364 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 358 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
365 return 0; 366 } 367 } 368 /* we could set PIO mode timings, but we assume the BIOS did that */ 369 break; 370 371 case 0x4d33105a: /* Promise Ultra33 / FastTrak33 controllers */ 372 case 0x4d38105a: /* Promise Ultra66 / FastTrak66 controllers */ 373 /* the Promise can only do DMA on ATA disks not on ATAPI devices */ 374 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 375 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 376 break; 377 378 if (udmamode >=4 && scp->chiptype == 0x4d38105a && 379 !(pci_read_config(scp->dev, 0x50, 2)&(scp->unit ? 1<<11 : 1<<10))) { 380 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 381 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 382 if (bootverbose)
| 359 return 0; 360 } 361 } 362 /* we could set PIO mode timings, but we assume the BIOS did that */ 363 break; 364 365 case 0x4d33105a: /* Promise Ultra33 / FastTrak33 controllers */ 366 case 0x4d38105a: /* Promise Ultra66 / FastTrak66 controllers */ 367 /* the Promise can only do DMA on ATA disks not on ATAPI devices */ 368 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 369 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 370 break; 371 372 if (udmamode >=4 && scp->chiptype == 0x4d38105a && 373 !(pci_read_config(scp->dev, 0x50, 2)&(scp->unit ? 1<<11 : 1<<10))) { 374 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 375 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 376 if (bootverbose)
|
383 printf("ata%d-%s: %s setting up UDMA4 mode on Promise chip\n", 384 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 385 (error) ? "failed" : "success");
| 377 ata_printf(scp, device, 378 "%s setting up UDMA4 mode on Promise chip\n", 379 (error) ? "failed" : "success");
|
386 if (!error) { 387 outb(scp->bmaddr+0x11, inl(scp->bmaddr+0x11) | scp->unit ? 8:2); 388 promise_timing(scp, devno, ATA_UDMA4);
| 380 if (!error) { 381 outb(scp->bmaddr+0x11, inl(scp->bmaddr+0x11) | scp->unit ? 8:2); 382 promise_timing(scp, devno, ATA_UDMA4);
|
389 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA4;
| 383 scp->mode[ATA_DEV(device)] = ATA_UDMA4;
|
390 return 0; 391 } 392 } 393 if (udmamode >= 2) { 394 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 395 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 396 if (bootverbose)
| 384 return 0; 385 } 386 } 387 if (udmamode >= 2) { 388 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 389 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 390 if (bootverbose)
|
397 printf("ata%d-%s: %s setting up UDMA2 mode on Promise chip\n", 398 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 399 (error) ? "failed" : "success");
| 391 ata_printf(scp, device, 392 "%s setting up UDMA2 mode on Promise chip\n", 393 (error) ? "failed" : "success");
|
400 if (!error) { 401 promise_timing(scp, devno, ATA_UDMA2);
| 394 if (!error) { 395 promise_timing(scp, devno, ATA_UDMA2);
|
402 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 396 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
403 return 0; 404 } 405 } 406 if (wdmamode >= 2 && apiomode >= 4) { 407 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 408 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 409 if (bootverbose)
| 397 return 0; 398 } 399 } 400 if (wdmamode >= 2 && apiomode >= 4) { 401 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 402 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 403 if (bootverbose)
|
410 printf("ata%d-%s: %s setting up WDMA2 mode on Promise chip\n", 411 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 412 (error) ? "failed" : "success");
| 404 ata_printf(scp, device, 405 "%s setting up WDMA2 mode on Promise chip\n", 406 (error) ? "failed" : "success");
|
413 if (!error) { 414 promise_timing(scp, devno, ATA_WDMA2);
| 407 if (!error) { 408 promise_timing(scp, devno, ATA_WDMA2);
|
415 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 409 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
416 return 0; 417 } 418 } 419 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 420 ata_pio2mode(apiomode), 421 ATA_C_F_SETXFER, ATA_WAIT_READY); 422 if (bootverbose)
| 410 return 0; 411 } 412 } 413 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 414 ata_pio2mode(apiomode), 415 ATA_C_F_SETXFER, ATA_WAIT_READY); 416 if (bootverbose)
|
423 printf("ata%d-%s: %s setting up PIO%d mode on Promise chip\n", 424 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 425 (error) ? "failed" : "success", 426 (apiomode >= 0) ? apiomode : 0);
| 417 ata_printf(scp, device, 418 "%s setting up PIO%d mode on Promise chip\n", 419 (error) ? "failed" : "success", 420 (apiomode >= 0) ? apiomode : 0);
|
427 if (!error) { 428 promise_timing(scp, devno, ata_pio2mode(apiomode)); 429 return 0; 430 } 431 break; 432 433 case 0x00041103: /* HighPoint HPT366 controller */ 434 /* no ATAPI devices for now */ 435 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 436 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 437 break; 438 439 if (udmamode >=4 && !(pci_read_config(scp->dev, 0x5a, 1) & 0x2)) { 440 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 441 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 442 if (bootverbose)
| 421 if (!error) { 422 promise_timing(scp, devno, ata_pio2mode(apiomode)); 423 return 0; 424 } 425 break; 426 427 case 0x00041103: /* HighPoint HPT366 controller */ 428 /* no ATAPI devices for now */ 429 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 430 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 431 break; 432 433 if (udmamode >=4 && !(pci_read_config(scp->dev, 0x5a, 1) & 0x2)) { 434 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 435 ATA_UDMA4, ATA_C_F_SETXFER, ATA_WAIT_READY); 436 if (bootverbose)
|
443 printf("ata%d-%s: %s setting up UDMA4 mode on HPT366 chip\n", 444 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 445 (error) ? "failed" : "success");
| 437 ata_printf(scp, device, 438 "%s setting up UDMA4 mode on HPT366 chip\n", 439 (error) ? "failed" : "success");
|
446 if (!error) { 447 hpt366_timing(scp, devno, ATA_UDMA4);
| 440 if (!error) { 441 hpt366_timing(scp, devno, ATA_UDMA4);
|
448 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA4;
| 442 scp->mode[ATA_DEV(device)] = ATA_UDMA4;
|
449 return 0; 450 } 451 } 452 if (udmamode >= 2) { 453 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 454 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 455 if (bootverbose)
| 443 return 0; 444 } 445 } 446 if (udmamode >= 2) { 447 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 448 ATA_UDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 449 if (bootverbose)
|
456 printf("ata%d-%s: %s setting up UDMA2 mode on HPT366 chip\n", 457 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 458 (error) ? "failed" : "success");
| 450 ata_printf(scp, device, 451 "%s setting up UDMA2 mode on HPT366 chip\n", 452 (error) ? "failed" : "success");
|
459 if (!error) { 460 hpt366_timing(scp, devno, ATA_UDMA2);
| 453 if (!error) { 454 hpt366_timing(scp, devno, ATA_UDMA2);
|
461 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_UDMA2;
| 455 scp->mode[ATA_DEV(device)] = ATA_UDMA2;
|
462 return 0; 463 } 464 } 465 if (wdmamode >= 2 && apiomode >= 4) { 466 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 467 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 468 if (bootverbose)
| 456 return 0; 457 } 458 } 459 if (wdmamode >= 2 && apiomode >= 4) { 460 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 461 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 462 if (bootverbose)
|
469 printf("ata%d-%s: %s setting up WDMA2 mode on HPT366 chip\n", 470 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 471 (error) ? "failed" : "success");
| 463 ata_printf(scp, device, 464 "%s setting up WDMA2 mode on HPT366 chip\n", 465 (error) ? "failed" : "success");
|
472 if (!error) { 473 hpt366_timing(scp, devno, ATA_WDMA2);
| 466 if (!error) { 467 hpt366_timing(scp, devno, ATA_WDMA2);
|
474 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 468 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
475 return 0; 476 } 477 } 478 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 479 ata_pio2mode(apiomode), 480 ATA_C_F_SETXFER, ATA_WAIT_READY); 481 if (bootverbose)
| 469 return 0; 470 } 471 } 472 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 473 ata_pio2mode(apiomode), 474 ATA_C_F_SETXFER, ATA_WAIT_READY); 475 if (bootverbose)
|
482 printf("ata%d-%s: %s setting up PIO%d mode on HPT366 chip\n", 483 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 484 (error) ? "failed" : "success", 485 (apiomode >= 0) ? apiomode : 0);
| 476 ata_printf(scp, device, "%s setting up PIO%d mode on HPT366 chip\n", 477 (error) ? "failed" : "success", 478 (apiomode >= 0) ? apiomode : 0);
|
486 if (!error) { 487 hpt366_timing(scp, devno, ata_pio2mode(apiomode)); 488 return 0; 489 } 490 break; 491 492 default: /* unknown controller chip */ 493 /* better not try generic DMA on ATAPI devices it almost never works */ 494 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 495 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 496 break; 497 498 /* well, we have no support for this, but try anyways */ 499 if ((wdmamode >= 2 && apiomode >= 4) && scp->bmaddr) { 500#if MAYBE_NOT 501 && (inb(scp->bmaddr + ATA_BMSTAT_PORT) & 502 ((device == ATA_MASTER) ? 503 ATA_BMSTAT_DMA_MASTER : ATA_BMSTAT_DMA_SLAVE))) { 504#endif 505 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 506 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 507 if (bootverbose)
| 479 if (!error) { 480 hpt366_timing(scp, devno, ata_pio2mode(apiomode)); 481 return 0; 482 } 483 break; 484 485 default: /* unknown controller chip */ 486 /* better not try generic DMA on ATAPI devices it almost never works */ 487 if ((device == ATA_MASTER && scp->devices & ATA_ATAPI_MASTER) || 488 (device == ATA_SLAVE && scp->devices & ATA_ATAPI_SLAVE)) 489 break; 490 491 /* well, we have no support for this, but try anyways */ 492 if ((wdmamode >= 2 && apiomode >= 4) && scp->bmaddr) { 493#if MAYBE_NOT 494 && (inb(scp->bmaddr + ATA_BMSTAT_PORT) & 495 ((device == ATA_MASTER) ? 496 ATA_BMSTAT_DMA_MASTER : ATA_BMSTAT_DMA_SLAVE))) { 497#endif 498 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 499 ATA_WDMA2, ATA_C_F_SETXFER, ATA_WAIT_READY); 500 if (bootverbose)
|
508 printf("ata%d-%s: %s setting up WDMA2 mode on generic chip\n", 509 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 510 (error) ? "failed" : "success");
| 501 ata_printf(scp, device, 502 "%s setting up WDMA2 mode on generic chip\n", 503 (error) ? "failed" : "success");
|
511 if (!error) {
| 504 if (!error) {
|
512 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ATA_WDMA2;
| 505 scp->mode[ATA_DEV(device)] = ATA_WDMA2;
|
513 return 0; 514 } 515 } 516 }
| 506 return 0; 507 } 508 } 509 }
|
517 free(dmatab, M_DEVBUF);
| |
518 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 519 ata_pio2mode(apiomode), ATA_C_F_SETXFER,ATA_WAIT_READY); 520 if (bootverbose)
| 510 error = ata_command(scp, device, ATA_C_SETFEATURES, 0, 0, 0, 511 ata_pio2mode(apiomode), ATA_C_F_SETXFER,ATA_WAIT_READY); 512 if (bootverbose)
|
521 printf("ata%d-%s: %s setting up PIO%d mode on generic chip\n", 522 scp->lun, (device == ATA_MASTER) ? "master" : "slave", 523 (error) ? "failed" : "success", (apiomode >= 0) ? apiomode : 0);
| 513 ata_printf(scp, device, "%s setting up PIO%d mode on generic chip\n", 514 (error) ? "failed" : "success",(apiomode>=0) ? apiomode : 0);
|
524 if (!error)
| 515 if (!error)
|
525 scp->mode[(device == ATA_MASTER) ? 0 : 1] = ata_pio2mode(apiomode);
| 516 scp->mode[ATA_DEV(device)] = ata_pio2mode(apiomode);
|
526 return -1; 527} 528 529int32_t 530ata_dmasetup(struct ata_softc *scp, int32_t device, 531 int8_t *data, int32_t count, int32_t flags) 532{ 533 struct ata_dmaentry *dmatab; 534 u_int32_t dma_count, dma_base; 535 int32_t i = 0; 536 537 if (((uintptr_t)data & 1) || (count & 1)) 538 return -1; 539 540 if (!count) {
| 517 return -1; 518} 519 520int32_t 521ata_dmasetup(struct ata_softc *scp, int32_t device, 522 int8_t *data, int32_t count, int32_t flags) 523{ 524 struct ata_dmaentry *dmatab; 525 u_int32_t dma_count, dma_base; 526 int32_t i = 0; 527 528 if (((uintptr_t)data & 1) || (count & 1)) 529 return -1; 530 531 if (!count) {
|
541 printf("ata%d-%s: zero length DMA transfer attempted\n", 542 scp->lun, ((device == ATA_MASTER) ? "master" : "slave"));
| 532 ata_printf(scp, device, "zero length DMA transfer attempted\n");
|
543 return -1; 544 } 545
| 533 return -1; 534 } 535
|
546 dmatab = scp->dmatab[(device == ATA_MASTER) ? 0 : 1];
| 536 dmatab = scp->dmatab[ATA_DEV(device)];
|
547 dma_base = vtophys(data);
| 537 dma_base = vtophys(data);
|
548 dma_count = MIN(count, (PAGE_SIZE - ((uintptr_t)data & PAGE_MASK)));
| 538 dma_count = min(count, (PAGE_SIZE - ((uintptr_t)data & PAGE_MASK)));
|
549 data += dma_count; 550 count -= dma_count; 551 552 while (count) { 553 dmatab[i].base = dma_base; 554 dmatab[i].count = (dma_count & 0xffff); 555 i++; 556 if (i >= ATA_DMA_ENTRIES) {
| 539 data += dma_count; 540 count -= dma_count; 541 542 while (count) { 543 dmatab[i].base = dma_base; 544 dmatab[i].count = (dma_count & 0xffff); 545 i++; 546 if (i >= ATA_DMA_ENTRIES) {
|
557 printf("ata%d-%s: too many segments in DMA table\n", 558 scp->lun, (device ? "slave" : "master"));
| 547 ata_printf(scp, device, "too many segments in DMA table\n");
|
559 return -1; 560 } 561 dma_base = vtophys(data);
| 548 return -1; 549 } 550 dma_base = vtophys(data);
|
562 dma_count = MIN(count, PAGE_SIZE); 563 data += MIN(count, PAGE_SIZE); 564 count -= MIN(count, PAGE_SIZE);
| 551 dma_count = min(count, PAGE_SIZE); 552 data += min(count, PAGE_SIZE); 553 count -= min(count, PAGE_SIZE);
|
565 } 566 dmatab[i].base = dma_base; 567 dmatab[i].count = (dma_count & 0xffff) | ATA_DMA_EOT; 568 outl(scp->bmaddr + ATA_BMDTP_PORT, vtophys(dmatab)); 569 outb(scp->bmaddr + ATA_BMCMD_PORT, flags ? ATA_BMCMD_WRITE_READ:0); 570 outb(scp->bmaddr + ATA_BMSTAT_PORT, (inb(scp->bmaddr + ATA_BMSTAT_PORT) | 571 (ATA_BMSTAT_INTERRUPT | ATA_BMSTAT_ERROR))); 572 return 0; 573} 574 575void 576ata_dmastart(struct ata_softc *scp) 577{ 578 scp->flags |= ATA_DMA_ACTIVE; 579 outb(scp->bmaddr + ATA_BMCMD_PORT, 580 inb(scp->bmaddr + ATA_BMCMD_PORT) | ATA_BMCMD_START_STOP); 581} 582 583int32_t 584ata_dmadone(struct ata_softc *scp) 585{ 586 outb(scp->bmaddr + ATA_BMCMD_PORT, 587 inb(scp->bmaddr + ATA_BMCMD_PORT) & ~ATA_BMCMD_START_STOP); 588 scp->flags &= ~ATA_DMA_ACTIVE; 589 return inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_MASK; 590} 591 592int32_t 593ata_dmastatus(struct ata_softc *scp) 594{ 595 return inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_MASK; 596} 597 598static void 599promise_timing(struct ata_softc *scp, int32_t devno, int32_t mode) 600{ 601 u_int32_t timing; 602 switch (mode) { 603 default: 604 case ATA_PIO0: timing = 0x004ff329; break; 605 case ATA_PIO1: timing = 0x004fec25; break; 606 case ATA_PIO2: timing = 0x004fe823; break; 607 case ATA_PIO3: timing = 0x004fe622; break; 608 case ATA_PIO4: timing = 0x004fe421; break; 609 case ATA_WDMA2: timing = 0x004367f3; break; 610 case ATA_UDMA2: timing = 0x004127f3; break; 611 case ATA_UDMA4: timing = 0x004127f3; break; 612 } 613 pci_write_config(scp->dev, 0x60 + (devno << 2), timing, 4); 614} 615 616static void 617hpt366_timing(struct ata_softc *scp, int32_t devno, int32_t mode) 618{ 619 u_int32_t timing; 620 621 switch (pci_read_config(scp->dev, 0x41 + (devno << 2), 1)) { 622 case 0x85: /* 25Mhz */ 623 switch (mode) { 624 case ATA_PIO0: timing = 0xc0d08585; break; 625 case ATA_PIO1: timing = 0xc0d08572; break; 626 case ATA_PIO2: timing = 0xc0ca8542; break; 627 case ATA_PIO3: timing = 0xc0ca8532; break; 628 case ATA_PIO4: timing = 0xc0ca8521; break; 629 case ATA_WDMA2: timing = 0xa0ca8521; break; 630 case ATA_UDMA2: timing = 0x90cf8521; break; 631 case ATA_UDMA4: timing = 0x90c98521; break; 632 default: timing = 0x01208585; 633 } 634 break; 635 default: 636 case 0xa7: /* 33MHz */ 637 switch (mode) { 638 case ATA_PIO0: timing = 0xc0d0a7aa; break; 639 case ATA_PIO1: timing = 0xc0d0a7a3; break; 640 case ATA_PIO2: timing = 0xc0d0a753; break; 641 case ATA_PIO3: timing = 0xc0c8a742; break; 642 case ATA_PIO4: timing = 0xc0c8a731; break; 643 case ATA_WDMA2: timing = 0xa0c8a731; break; 644 case ATA_UDMA2: timing = 0x90caa731; break; 645 case ATA_UDMA4: timing = 0x90c9a731; break; 646 default: timing = 0x0120a7a7; 647 } 648 break; 649 case 0xd9: /* 40Mhz */ 650 switch (mode) { 651 case ATA_PIO0: timing = 0xc018d9d9; break; 652 case ATA_PIO1: timing = 0xc010d9c7; break; 653 case ATA_PIO2: timing = 0xc010d997; break; 654 case ATA_PIO3: timing = 0xc010d974; break; 655 case ATA_PIO4: timing = 0xc008d963; break; 656 case ATA_WDMA2: timing = 0xa008d943; break; 657 case ATA_UDMA2: timing = 0x900bd943; break; 658 case ATA_UDMA4: timing = 0x900fd943; break; 659 default: timing = 0x0120d9d9; 660 } 661 } 662 pci_write_config(scp->dev, 0x40 + (devno << 2) , timing, 4); 663} 664 665#else /* NPCI > 0 */ 666 667int32_t 668ata_dmainit(struct ata_softc *scp, int32_t device, 669 int32_t piomode, int32_t wdmamode, int32_t udmamode) 670{ 671 return -1; 672} 673 674int32_t 675ata_dmasetup(struct ata_softc *scp, int32_t device, 676 int8_t *data, int32_t count, int32_t flags) 677{ 678 return -1; 679} 680 681void 682ata_dmastart(struct ata_softc *scp) 683{ 684} 685 686int32_t 687ata_dmadone(struct ata_softc *scp) 688{ 689 return -1; 690} 691 692int32_t 693ata_dmastatus(struct ata_softc *scp) 694{ 695 return -1; 696} 697 698#endif /* NPCI > 0 */
| 554 } 555 dmatab[i].base = dma_base; 556 dmatab[i].count = (dma_count & 0xffff) | ATA_DMA_EOT; 557 outl(scp->bmaddr + ATA_BMDTP_PORT, vtophys(dmatab)); 558 outb(scp->bmaddr + ATA_BMCMD_PORT, flags ? ATA_BMCMD_WRITE_READ:0); 559 outb(scp->bmaddr + ATA_BMSTAT_PORT, (inb(scp->bmaddr + ATA_BMSTAT_PORT) | 560 (ATA_BMSTAT_INTERRUPT | ATA_BMSTAT_ERROR))); 561 return 0; 562} 563 564void 565ata_dmastart(struct ata_softc *scp) 566{ 567 scp->flags |= ATA_DMA_ACTIVE; 568 outb(scp->bmaddr + ATA_BMCMD_PORT, 569 inb(scp->bmaddr + ATA_BMCMD_PORT) | ATA_BMCMD_START_STOP); 570} 571 572int32_t 573ata_dmadone(struct ata_softc *scp) 574{ 575 outb(scp->bmaddr + ATA_BMCMD_PORT, 576 inb(scp->bmaddr + ATA_BMCMD_PORT) & ~ATA_BMCMD_START_STOP); 577 scp->flags &= ~ATA_DMA_ACTIVE; 578 return inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_MASK; 579} 580 581int32_t 582ata_dmastatus(struct ata_softc *scp) 583{ 584 return inb(scp->bmaddr + ATA_BMSTAT_PORT) & ATA_BMSTAT_MASK; 585} 586 587static void 588promise_timing(struct ata_softc *scp, int32_t devno, int32_t mode) 589{ 590 u_int32_t timing; 591 switch (mode) { 592 default: 593 case ATA_PIO0: timing = 0x004ff329; break; 594 case ATA_PIO1: timing = 0x004fec25; break; 595 case ATA_PIO2: timing = 0x004fe823; break; 596 case ATA_PIO3: timing = 0x004fe622; break; 597 case ATA_PIO4: timing = 0x004fe421; break; 598 case ATA_WDMA2: timing = 0x004367f3; break; 599 case ATA_UDMA2: timing = 0x004127f3; break; 600 case ATA_UDMA4: timing = 0x004127f3; break; 601 } 602 pci_write_config(scp->dev, 0x60 + (devno << 2), timing, 4); 603} 604 605static void 606hpt366_timing(struct ata_softc *scp, int32_t devno, int32_t mode) 607{ 608 u_int32_t timing; 609 610 switch (pci_read_config(scp->dev, 0x41 + (devno << 2), 1)) { 611 case 0x85: /* 25Mhz */ 612 switch (mode) { 613 case ATA_PIO0: timing = 0xc0d08585; break; 614 case ATA_PIO1: timing = 0xc0d08572; break; 615 case ATA_PIO2: timing = 0xc0ca8542; break; 616 case ATA_PIO3: timing = 0xc0ca8532; break; 617 case ATA_PIO4: timing = 0xc0ca8521; break; 618 case ATA_WDMA2: timing = 0xa0ca8521; break; 619 case ATA_UDMA2: timing = 0x90cf8521; break; 620 case ATA_UDMA4: timing = 0x90c98521; break; 621 default: timing = 0x01208585; 622 } 623 break; 624 default: 625 case 0xa7: /* 33MHz */ 626 switch (mode) { 627 case ATA_PIO0: timing = 0xc0d0a7aa; break; 628 case ATA_PIO1: timing = 0xc0d0a7a3; break; 629 case ATA_PIO2: timing = 0xc0d0a753; break; 630 case ATA_PIO3: timing = 0xc0c8a742; break; 631 case ATA_PIO4: timing = 0xc0c8a731; break; 632 case ATA_WDMA2: timing = 0xa0c8a731; break; 633 case ATA_UDMA2: timing = 0x90caa731; break; 634 case ATA_UDMA4: timing = 0x90c9a731; break; 635 default: timing = 0x0120a7a7; 636 } 637 break; 638 case 0xd9: /* 40Mhz */ 639 switch (mode) { 640 case ATA_PIO0: timing = 0xc018d9d9; break; 641 case ATA_PIO1: timing = 0xc010d9c7; break; 642 case ATA_PIO2: timing = 0xc010d997; break; 643 case ATA_PIO3: timing = 0xc010d974; break; 644 case ATA_PIO4: timing = 0xc008d963; break; 645 case ATA_WDMA2: timing = 0xa008d943; break; 646 case ATA_UDMA2: timing = 0x900bd943; break; 647 case ATA_UDMA4: timing = 0x900fd943; break; 648 default: timing = 0x0120d9d9; 649 } 650 } 651 pci_write_config(scp->dev, 0x40 + (devno << 2) , timing, 4); 652} 653 654#else /* NPCI > 0 */ 655 656int32_t 657ata_dmainit(struct ata_softc *scp, int32_t device, 658 int32_t piomode, int32_t wdmamode, int32_t udmamode) 659{ 660 return -1; 661} 662 663int32_t 664ata_dmasetup(struct ata_softc *scp, int32_t device, 665 int8_t *data, int32_t count, int32_t flags) 666{ 667 return -1; 668} 669 670void 671ata_dmastart(struct ata_softc *scp) 672{ 673} 674 675int32_t 676ata_dmadone(struct ata_softc *scp) 677{ 678 return -1; 679} 680 681int32_t 682ata_dmastatus(struct ata_softc *scp) 683{ 684 return -1; 685} 686 687#endif /* NPCI > 0 */
|