xref: /freebsd/sys/dev/ata/ata-all.c (revision 77b7cdf1999ee965ad494fddd184b18f532ac91a)
1 /*-
2  * Copyright (c) 1998 - 2003 S�ren Schmidt <sos@FreeBSD.org>
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$
29  */
30 
31 #include "opt_ata.h"
32 #include <sys/param.h>
33 #include <sys/systm.h>
34 #include <sys/ata.h>
35 #include <sys/kernel.h>
36 #include <sys/conf.h>
37 #include <sys/module.h>
38 #include <sys/bus.h>
39 #include <sys/bio.h>
40 #include <sys/malloc.h>
41 #include <sys/sysctl.h>
42 #include <machine/stdarg.h>
43 #include <machine/resource.h>
44 #include <machine/bus.h>
45 #include <sys/rman.h>
46 #ifdef __alpha__
47 #include <machine/md_var.h>
48 #endif
49 #include <geom/geom_disk.h>
50 #include <dev/ata/ata-all.h>
51 #include <dev/ata/ata-disk.h>
52 #include <dev/ata/ata-raid.h>
53 #include <dev/ata/atapi-all.h>
54 
55 /* device structures */
56 static	d_ioctl_t	ataioctl;
57 static struct cdevsw ata_cdevsw = {
58 	.d_open =	nullopen,
59 	.d_close =	nullclose,
60 	.d_ioctl =	ataioctl,
61 	.d_name =	"ata",
62 	.d_maj =	159,
63 };
64 
65 /* prototypes */
66 static void ata_boot_attach(void);
67 static void ata_intr(void *);
68 static int ata_getparam(struct ata_device *, u_int8_t);
69 static int ata_service(struct ata_channel *);
70 static void ata_flush(struct ata_device *);
71 static void bswap(int8_t *, int);
72 static void btrim(int8_t *, int);
73 static void bpack(int8_t *, int8_t *, int);
74 static void ata_change_mode(struct ata_device *, int);
75 static u_int8_t ata_enclosure_sensor(struct ata_device *, int, u_int8_t, u_int8_t);
76 static int ata_enclosure_status(struct ata_device *, int *, int *, int *, int *);
77 
78 /* sysctl vars */
79 SYSCTL_NODE(_hw, OID_AUTO, ata, CTLFLAG_RD, 0, "ATA driver parameters");
80 
81 /* global vars */
82 struct intr_config_hook *ata_delayed_attach = NULL;
83 devclass_t ata_devclass;
84 
85 /* local vars */
86 static MALLOC_DEFINE(M_ATA, "ATA generic", "ATA driver generic layer");
87 
88 /* misc defines */
89 #define DEV_ATAPIALL	defined(DEV_ATAPICD) || defined(DEV_ATAPIFD) || \
90 			defined(DEV_ATAPIST) || defined(DEV_ATAPICAM)
91 
92 int
93 ata_probe(device_t dev)
94 {
95     struct ata_channel *ch;
96 
97     if (!dev || !(ch = device_get_softc(dev)))
98 	return ENXIO;
99 
100     if (ch->r_irq)
101 	return EEXIST;
102 
103     /* initialize the softc basics */
104     ch->active = ATA_IDLE;
105     ch->dev = dev;
106     ch->device[MASTER].channel = ch;
107     ch->device[MASTER].unit = ATA_MASTER;
108     ch->device[MASTER].mode = ATA_PIO;
109     ch->device[SLAVE].channel = ch;
110     ch->device[SLAVE].unit = ATA_SLAVE;
111     ch->device[SLAVE].mode = ATA_PIO;
112     TAILQ_INIT(&ch->ata_queue);
113     TAILQ_INIT(&ch->atapi_queue);
114 
115     /* initialise device(s) on this channel */
116     ch->locking(ch, ATA_LF_LOCK);
117     ata_reset(ch);
118     ch->locking(ch, ATA_LF_UNLOCK);
119     return 0;
120 }
121 
122 int
123 ata_attach(device_t dev)
124 {
125     struct ata_channel *ch;
126     int error, rid;
127 
128     if (!dev || !(ch = device_get_softc(dev)))
129 	return ENXIO;
130 
131     rid = ATA_IRQ_RID;
132     ch->r_irq = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, 0, ~0, 1,
133 				   RF_SHAREABLE | RF_ACTIVE);
134     if (!ch->r_irq) {
135 	ata_printf(ch, -1, "unable to allocate interrupt\n");
136 	return ENXIO;
137     }
138     if ((error = bus_setup_intr(dev, ch->r_irq, INTR_TYPE_BIO | INTR_ENTROPY,
139 				ata_intr, ch, &ch->ih))) {
140 	ata_printf(ch, -1, "unable to setup interrupt\n");
141 	return error;
142     }
143 
144     if (ch->dma)
145 	ch->dma->alloc(ch);
146 
147     /*
148      * do not attach devices if we are in early boot, this is done later
149      * when interrupts are enabled by a hook into the boot process.
150      * otherwise attach what the probe has found in ch->devices.
151      */
152     if (!ata_delayed_attach) {
153 	ch->locking(ch, ATA_LF_LOCK);
154 	if (ch->devices & ATA_ATA_SLAVE)
155 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATA_IDENTIFY))
156 		ch->devices &= ~ATA_ATA_SLAVE;
157 	if (ch->devices & ATA_ATAPI_SLAVE)
158 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATAPI_IDENTIFY))
159 		ch->devices &= ~ATA_ATAPI_SLAVE;
160 	if (ch->devices & ATA_ATA_MASTER)
161 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATA_IDENTIFY))
162 		ch->devices &= ~ATA_ATA_MASTER;
163 	if (ch->devices & ATA_ATAPI_MASTER)
164 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATAPI_IDENTIFY))
165 		ch->devices &= ~ATA_ATAPI_MASTER;
166 #ifdef DEV_ATADISK
167 	if (ch->devices & ATA_ATA_MASTER)
168 	    ad_attach(&ch->device[MASTER]);
169 	if (ch->devices & ATA_ATA_SLAVE)
170 	    ad_attach(&ch->device[SLAVE]);
171 #endif
172 #if DEV_ATAPIALL
173 	if (ch->devices & ATA_ATAPI_MASTER)
174 	    atapi_attach(&ch->device[MASTER]);
175 	if (ch->devices & ATA_ATAPI_SLAVE)
176 	    atapi_attach(&ch->device[SLAVE]);
177 #endif
178 #ifdef DEV_ATAPICAM
179 	atapi_cam_attach_bus(ch);
180 #endif
181 	ch->locking(ch, ATA_LF_UNLOCK);
182     }
183     return 0;
184 }
185 
186 int
187 ata_detach(device_t dev)
188 {
189     struct ata_channel *ch;
190     int s;
191 
192     if (!dev || !(ch = device_get_softc(dev)) || !ch->r_irq)
193 	return ENXIO;
194 
195     /* make sure channel is not busy */
196     ch->locking(ch, ATA_LF_LOCK);
197     ATA_SLEEPLOCK_CH(ch, ATA_CONTROL);
198 
199     s = splbio();
200 #ifdef DEV_ATADISK
201     if (ch->devices & ATA_ATA_MASTER && ch->device[MASTER].driver)
202 	ad_detach(&ch->device[MASTER]);
203     if (ch->devices & ATA_ATA_SLAVE && ch->device[SLAVE].driver)
204 	ad_detach(&ch->device[SLAVE]);
205 #endif
206 #if DEV_ATAPIALL
207     if (ch->devices & ATA_ATAPI_MASTER && ch->device[MASTER].driver)
208 	atapi_detach(&ch->device[MASTER]);
209     if (ch->devices & ATA_ATAPI_SLAVE && ch->device[SLAVE].driver)
210 	atapi_detach(&ch->device[SLAVE]);
211 #endif
212 #ifdef DEV_ATAPICAM
213     atapi_cam_detach_bus(ch);
214 #endif
215     splx(s);
216 
217     if (ch->device[MASTER].param) {
218 	ata_flush(&ch->device[MASTER]);
219 	free(ch->device[MASTER].param, M_ATA);
220 	ch->device[MASTER].param = NULL;
221     }
222     if (ch->device[SLAVE].param) {
223 	ata_flush(&ch->device[SLAVE]);
224 	free(ch->device[SLAVE].param, M_ATA);
225 	ch->device[SLAVE].param = NULL;
226     }
227     ch->device[MASTER].driver = NULL;
228     ch->device[SLAVE].driver = NULL;
229     ch->device[MASTER].mode = ATA_PIO;
230     ch->device[SLAVE].mode = ATA_PIO;
231     ch->devices = 0;
232     if (ch->dma)
233 	ch->dma->free(ch);
234 
235     bus_teardown_intr(dev, ch->r_irq, ch->ih);
236     bus_release_resource(dev, SYS_RES_IRQ, ATA_IRQ_RID, ch->r_irq);
237     ch->r_irq = NULL;
238     ATA_UNLOCK_CH(ch);
239     ch->locking(ch, ATA_LF_UNLOCK);
240     return 0;
241 }
242 
243 int
244 ata_resume(device_t dev)
245 {
246     struct ata_channel *ch;
247     int error;
248 
249     if (!dev || !(ch = device_get_softc(dev)))
250 	return ENXIO;
251 
252     ch->locking(ch, ATA_LF_LOCK);
253     error = ata_reinit(ch);
254     ch->locking(ch, ATA_LF_UNLOCK);
255     return error;
256 }
257 
258 static int
259 ataioctl(dev_t dev, u_long cmd, caddr_t addr, int32_t flag, struct thread *td)
260 {
261     struct ata_cmd *iocmd = (struct ata_cmd *)addr;
262     struct ata_channel *ch;
263     device_t device = devclass_get_device(ata_devclass, iocmd->channel);
264     int error;
265 
266     if (cmd != IOCATA)
267 	return ENOTTY;
268 
269     if (iocmd->cmd == ATAGMAXCHANNEL) {
270 	iocmd->u.maxchan = devclass_get_maxunit(ata_devclass);
271 	return 0;
272     }
273 
274     if (iocmd->channel < -1 || iocmd->device < -1 || iocmd->device > SLAVE)
275 	return ENXIO;
276 
277     switch (iocmd->cmd) {
278 	case ATAATTACH:
279 	    /* should enable channel HW on controller that can SOS XXX */
280 	    error = ata_probe(device);
281 	    if (!error)
282 		error = ata_attach(device);
283 	    return error;
284 
285 	case ATADETACH:
286 	    error = ata_detach(device);
287 	    /* should disable channel HW on controller that can SOS XXX */
288 	    return error;
289 
290 	case ATAREINIT:
291 	    if (!device || !(ch = device_get_softc(device)))
292 		return ENXIO;
293 	    ch->locking(ch, ATA_LF_LOCK);
294 	    ATA_SLEEPLOCK_CH(ch, ATA_ACTIVE);
295 	    error = ata_reinit(ch);
296 	    ch->locking(ch, ATA_LF_UNLOCK);
297 	    return error;
298 
299 	case ATAGMODE:
300 	    if (!device || !(ch = device_get_softc(device)))
301 		return ENXIO;
302 
303 	    if ((iocmd->device == MASTER || iocmd->device == -1) &&
304 		ch->device[MASTER].driver)
305 		iocmd->u.mode.mode[MASTER] = ch->device[MASTER].mode;
306 	    else
307 		iocmd->u.mode.mode[MASTER] = -1;
308 
309 	    if ((iocmd->device == SLAVE || iocmd->device == -1) &&
310 		ch->device[SLAVE].param)
311 		iocmd->u.mode.mode[SLAVE] = ch->device[SLAVE].mode;
312 	    else
313 		iocmd->u.mode.mode[SLAVE] = -1;
314 	    return 0;
315 
316 	case ATASMODE:
317 	    if (!device || !(ch = device_get_softc(device)))
318 		return ENXIO;
319 
320 	    ch->locking(ch, ATA_LF_LOCK);
321 	    if ((iocmd->device == MASTER || iocmd->device == -1) &&
322 		iocmd->u.mode.mode[MASTER] >= 0 && ch->device[MASTER].param) {
323 		ata_change_mode(&ch->device[MASTER],iocmd->u.mode.mode[MASTER]);
324 		iocmd->u.mode.mode[MASTER] = ch->device[MASTER].mode;
325 	    }
326 	    else
327 		iocmd->u.mode.mode[MASTER] = -1;
328 
329 	    if ((iocmd->device == SLAVE || iocmd->device == -1) &&
330 		iocmd->u.mode.mode[SLAVE] >= 0 && ch->device[SLAVE].param) {
331 		ata_change_mode(&ch->device[SLAVE], iocmd->u.mode.mode[SLAVE]);
332 		iocmd->u.mode.mode[SLAVE] = ch->device[SLAVE].mode;
333 	    }
334 	    else
335 		iocmd->u.mode.mode[SLAVE] = -1;
336 	    ch->locking(ch, ATA_LF_UNLOCK);
337 	    return 0;
338 
339 	case ATAGPARM:
340 	    if (!device || !(ch = device_get_softc(device)))
341 		return ENXIO;
342 
343 	    iocmd->u.param.type[MASTER] =
344 		ch->devices & (ATA_ATA_MASTER | ATA_ATAPI_MASTER);
345 	    iocmd->u.param.type[SLAVE] =
346 		ch->devices & (ATA_ATA_SLAVE | ATA_ATAPI_SLAVE);
347 
348 	    if (ch->device[MASTER].name)
349 		strcpy(iocmd->u.param.name[MASTER], ch->device[MASTER].name);
350 	    if (ch->device[SLAVE].name)
351 		strcpy(iocmd->u.param.name[SLAVE], ch->device[SLAVE].name);
352 
353 	    if (ch->device[MASTER].param)
354 		bcopy(ch->device[MASTER].param, &iocmd->u.param.params[MASTER],
355 		      sizeof(struct ata_params));
356 	    if (ch->device[SLAVE].param)
357 		bcopy(ch->device[SLAVE].param, &iocmd->u.param.params[SLAVE],
358 		      sizeof(struct ata_params));
359 	    return 0;
360 
361 	case ATAENCSTAT: {
362 	    struct ata_device *atadev;
363 
364 	    if (!device || !(ch = device_get_softc(device)))
365 		return ENXIO;
366 
367 	    if (iocmd->device == SLAVE)
368 		atadev = &ch->device[SLAVE];
369 	    else
370 		atadev = &ch->device[MASTER];
371 
372 	    return ata_enclosure_status(atadev,
373 					&iocmd->u.enclosure.fan,
374 					&iocmd->u.enclosure.temp,
375 					&iocmd->u.enclosure.v05,
376 					&iocmd->u.enclosure.v12);
377 	}
378 
379 #ifdef DEV_ATADISK
380 	case ATARAIDREBUILD:
381 	    return ata_raid_rebuild(iocmd->channel);
382 
383 	case ATARAIDCREATE:
384 	    return ata_raid_create(&iocmd->u.raid_setup);
385 
386 	case ATARAIDDELETE:
387 	    return ata_raid_delete(iocmd->channel);
388 
389 	case ATARAIDADDSPARE:
390 	    return ata_raid_addspare(iocmd->channel, iocmd->u.raid_spare.disk);
391 
392 	case ATARAIDSTATUS:
393 	    return ata_raid_status(iocmd->channel, &iocmd->u.raid_status);
394 #endif
395 #if DEV_ATAPIALL
396 	case ATAPICMD: {
397 	    struct ata_device *atadev;
398 	    caddr_t buf;
399 
400 	    if (!device || !(ch = device_get_softc(device)))
401 		return ENXIO;
402 
403 	    if (!(atadev = &ch->device[iocmd->device]) ||
404 		!(ch->devices & (iocmd->device == MASTER ?
405 				 ATA_ATAPI_MASTER : ATA_ATAPI_SLAVE)))
406 		return ENODEV;
407 
408 	    if (!(buf = malloc(iocmd->u.atapi.count, M_ATA, M_NOWAIT)))
409 		return ENOMEM;
410 
411 	    if (iocmd->u.atapi.flags & ATAPI_CMD_WRITE) {
412 		error = copyin(iocmd->u.atapi.data, buf, iocmd->u.atapi.count);
413 		if (error) {
414 		    free(buf, M_ATA);
415 		    return error;
416 		}
417 	    }
418 	    error = atapi_queue_cmd(atadev, iocmd->u.atapi.ccb,
419 				    buf, iocmd->u.atapi.count,
420 				    (iocmd->u.atapi.flags == ATAPI_CMD_READ ?
421 				     ATPR_F_READ : 0) | ATPR_F_QUIET,
422 				    iocmd->u.atapi.timeout, NULL, NULL);
423 	    if (error) {
424 		iocmd->u.atapi.error = error;
425 		bcopy(&atadev->result, iocmd->u.atapi.sense_data,
426 		      sizeof(struct atapi_reqsense));
427 		error = 0;
428 	    }
429 	    else if (iocmd->u.atapi.flags & ATAPI_CMD_READ)
430 		error = copyout(buf, iocmd->u.atapi.data, iocmd->u.atapi.count);
431 
432 	    free(buf, M_ATA);
433 	    return error;
434 	}
435 #endif
436 	default:
437 	    break;
438     }
439     return ENOTTY;
440 }
441 
442 static int
443 ata_getparam(struct ata_device *atadev, u_int8_t command)
444 {
445     struct ata_params *ata_parm;
446     int retry = 0;
447 
448     if (!(ata_parm = malloc(sizeof(struct ata_params), M_ATA, M_NOWAIT))) {
449 	ata_prtdev(atadev, "malloc for identify data failed\n");
450 	return -1;
451     }
452 
453     /* apparently some devices needs this repeated */
454     do {
455 	if (ata_command(atadev, command, 0, 0, 0,
456 		dumping ? ATA_WAIT_READY : ATA_WAIT_INTR)) {
457 	    ata_prtdev(atadev, "%s identify failed\n",
458 		       command == ATA_C_ATAPI_IDENTIFY ? "ATAPI" : "ATA");
459 	    free(ata_parm, M_ATA);
460 	    return -1;
461 	}
462 	if (retry++ > 4) {
463 	    ata_prtdev(atadev, "%s identify retries exceeded\n",
464 		       command == ATA_C_ATAPI_IDENTIFY ? "ATAPI" : "ATA");
465 	    free(ata_parm, M_ATA);
466 	    return -1;
467 	}
468     } while (ata_wait(atadev, ((command == ATA_C_ATAPI_IDENTIFY) ?
469 			       ATA_S_DRQ : (ATA_S_READY|ATA_S_DSC|ATA_S_DRQ))));
470     ATA_IDX_INSW(atadev->channel, ATA_DATA, (int16_t *)ata_parm,
471 	     sizeof(struct ata_params)/sizeof(int16_t));
472 
473     if (command == ATA_C_ATA_IDENTIFY ||
474 	!((ata_parm->model[0] == 'N' && ata_parm->model[1] == 'E') ||
475 	  (ata_parm->model[0] == 'F' && ata_parm->model[1] == 'X') ||
476 	  (ata_parm->model[0] == 'P' && ata_parm->model[1] == 'i')))
477 	bswap(ata_parm->model, sizeof(ata_parm->model));
478     btrim(ata_parm->model, sizeof(ata_parm->model));
479     bpack(ata_parm->model, ata_parm->model, sizeof(ata_parm->model));
480     bswap(ata_parm->revision, sizeof(ata_parm->revision));
481     btrim(ata_parm->revision, sizeof(ata_parm->revision));
482     bpack(ata_parm->revision, ata_parm->revision, sizeof(ata_parm->revision));
483     bswap(ata_parm->serial, sizeof(ata_parm->serial));
484     btrim(ata_parm->serial, sizeof(ata_parm->serial));
485     bpack(ata_parm->serial, ata_parm->serial, sizeof(ata_parm->serial));
486     atadev->param = ata_parm;
487     return 0;
488 }
489 
490 static void
491 ata_boot_attach(void)
492 {
493     struct ata_channel *ch;
494     int ctlr;
495 
496     /*
497      * run through all ata devices and look for real ATA & ATAPI devices
498      * using the hints we found in the early probe, this avoids some of
499      * the delays probing of non-exsistent devices can cause.
500      */
501     for (ctlr=0; ctlr<devclass_get_maxunit(ata_devclass); ctlr++) {
502 	if (!(ch = devclass_get_softc(ata_devclass, ctlr)))
503 	    continue;
504 	ch->locking(ch, ATA_LF_LOCK);
505 	if (ch->devices & ATA_ATA_SLAVE)
506 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATA_IDENTIFY))
507 		ch->devices &= ~ATA_ATA_SLAVE;
508 	if (ch->devices & ATA_ATAPI_SLAVE)
509 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATAPI_IDENTIFY))
510 		ch->devices &= ~ATA_ATAPI_SLAVE;
511 	if (ch->devices & ATA_ATA_MASTER)
512 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATA_IDENTIFY))
513 		ch->devices &= ~ATA_ATA_MASTER;
514 	if (ch->devices & ATA_ATAPI_MASTER)
515 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATAPI_IDENTIFY))
516 		ch->devices &= ~ATA_ATAPI_MASTER;
517 	ch->locking(ch, ATA_LF_UNLOCK);
518     }
519 #ifdef DEV_ATADISK
520     /* now we know whats there, do the real attach, first the ATA disks */
521     for (ctlr=0; ctlr<devclass_get_maxunit(ata_devclass); ctlr++) {
522 	if (!(ch = devclass_get_softc(ata_devclass, ctlr)))
523 	    continue;
524 	ch->locking(ch, ATA_LF_LOCK);
525 	if (ch->devices & ATA_ATA_MASTER)
526 	    ad_attach(&ch->device[MASTER]);
527 	if (ch->devices & ATA_ATA_SLAVE)
528 	    ad_attach(&ch->device[SLAVE]);
529 	ch->locking(ch, ATA_LF_UNLOCK);
530     }
531 #endif
532     /* then the atapi devices */
533     for (ctlr=0; ctlr<devclass_get_maxunit(ata_devclass); ctlr++) {
534 	if (!(ch = devclass_get_softc(ata_devclass, ctlr)))
535 	    continue;
536 	ch->locking(ch, ATA_LF_LOCK);
537 #if DEV_ATAPIALL
538 	if (ch->devices & ATA_ATAPI_MASTER)
539 	    atapi_attach(&ch->device[MASTER]);
540 	if (ch->devices & ATA_ATAPI_SLAVE)
541 	    atapi_attach(&ch->device[SLAVE]);
542 #endif
543 #ifdef DEV_ATAPICAM
544 	atapi_cam_attach_bus(ch);
545 #endif
546 	ch->locking(ch, ATA_LF_UNLOCK);
547     }
548     if (ata_delayed_attach) {
549 	config_intrhook_disestablish(ata_delayed_attach);
550 	free(ata_delayed_attach, M_TEMP);
551 	ata_delayed_attach = NULL;
552     }
553 #ifdef DEV_ATADISK
554     ata_raid_attach();
555 #endif
556 }
557 
558 static void
559 ata_intr(void *data)
560 {
561     struct ata_channel *ch = (struct ata_channel *)data;
562 
563     /* if device is busy it didn't interrupt */
564     if (ATA_IDX_INB(ch, ATA_ALTSTAT) & ATA_S_BUSY) {
565 	DELAY(100);
566 	if (!(ATA_IDX_INB(ch, ATA_ALTSTAT) & ATA_S_DRQ))
567 	    return;
568     }
569 
570     /* clear interrupt and get status */
571     ch->status = ATA_IDX_INB(ch, ATA_STATUS);
572 
573     if (ch->status & ATA_S_ERROR)
574 	ch->error = ATA_IDX_INB(ch, ATA_ERROR);
575 
576     /* find & call the responsible driver to process this interrupt */
577     switch (ch->active) {
578 #ifdef DEV_ATADISK
579     case ATA_ACTIVE_ATA:
580 	if (!ch->running || ad_interrupt(ch->running) == ATA_OP_CONTINUES)
581 	    return;
582 	break;
583 #endif
584 #if DEV_ATAPIALL
585     case ATA_ACTIVE_ATAPI:
586 	if (!ch->running || atapi_interrupt(ch->running) == ATA_OP_CONTINUES)
587 	    return;
588 	break;
589 #endif
590     default:
591 	if (ch->active & ATA_WAIT_INTR)
592 	    wakeup(ch);
593     }
594 
595     if (ch->active & ATA_CONTROL) {
596 	ATA_FORCELOCK_CH(ch, ATA_CONTROL);
597 	return;
598     }
599 
600     if (ch->active & ATA_WAIT_INTR) {
601 	ATA_UNLOCK_CH(ch);
602 	return;
603     }
604 
605     if ((ch->flags & ATA_QUEUED) &&
606 	ATA_IDX_INB(ch, ATA_ALTSTAT) & ATA_S_SERVICE) {
607 	ATA_FORCELOCK_CH(ch, ATA_ACTIVE);
608 	if (ata_service(ch) == ATA_OP_CONTINUES)
609 	    return;
610     }
611     ch->running = NULL;
612     ATA_UNLOCK_CH(ch);
613     ch->locking(ch, ATA_LF_UNLOCK);
614     ata_start(ch);
615     return;
616 }
617 
618 void
619 ata_start(struct ata_channel *ch)
620 {
621 #ifdef DEV_ATADISK
622     struct ad_request *ad_request;
623 #endif
624 #if DEV_ATAPIALL
625     struct atapi_request *atapi_request;
626 #endif
627     int s;
628 
629     ch->locking(ch, ATA_LF_LOCK);
630     if (!ATA_LOCK_CH(ch, ATA_ACTIVE))
631 	return;
632 
633     s = splbio();
634 #ifdef DEV_ATADISK
635     /* find & call the responsible driver if anything on the ATA queue */
636     if (TAILQ_EMPTY(&ch->ata_queue)) {
637 	if (ch->devices & (ATA_ATA_MASTER) && ch->device[MASTER].driver)
638 	    ad_start(&ch->device[MASTER]);
639 	if (ch->devices & (ATA_ATA_SLAVE) && ch->device[SLAVE].driver)
640 	    ad_start(&ch->device[SLAVE]);
641     }
642     if ((ad_request = TAILQ_FIRST(&ch->ata_queue))) {
643 	TAILQ_REMOVE(&ch->ata_queue, ad_request, chain);
644 	ch->active = ATA_ACTIVE_ATA;
645 	ch->running = ad_request;
646 	if (ad_transfer(ad_request) == ATA_OP_CONTINUES) {
647 	    splx(s);
648 	    return;
649 	}
650     }
651 
652 #endif
653 #if DEV_ATAPIALL
654     /* find & call the responsible driver if anything on the ATAPI queue */
655     if (TAILQ_EMPTY(&ch->atapi_queue)) {
656 	if (ch->devices & (ATA_ATAPI_MASTER) && ch->device[MASTER].driver)
657 	    atapi_start(&ch->device[MASTER]);
658 	if (ch->devices & (ATA_ATAPI_SLAVE) && ch->device[SLAVE].driver)
659 	    atapi_start(&ch->device[SLAVE]);
660     }
661     if ((atapi_request = TAILQ_FIRST(&ch->atapi_queue))) {
662 	TAILQ_REMOVE(&ch->atapi_queue, atapi_request, chain);
663 	ch->active = ATA_ACTIVE_ATAPI;
664 	ch->running = atapi_request;
665 	if (atapi_transfer(atapi_request) == ATA_OP_CONTINUES) {
666 	    splx(s);
667 	    return;
668 	}
669     }
670 #endif
671     ATA_UNLOCK_CH(ch);
672     ch->locking(ch, ATA_LF_UNLOCK);
673     splx(s);
674 }
675 
676 void
677 ata_reset(struct ata_channel *ch)
678 {
679     u_int8_t lsb, msb, ostat0, ostat1;
680     u_int8_t stat0 = 0, stat1 = 0;
681     int mask = 0, timeout;
682 
683     /* do we have any signs of ATA/ATAPI HW being present ? */
684     ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_MASTER);
685     DELAY(10);
686     ostat0 = ATA_IDX_INB(ch, ATA_STATUS);
687     if ((ostat0 & 0xf8) != 0xf8 && ostat0 != 0xa5) {
688 	stat0 = ATA_S_BUSY;
689 	mask |= 0x01;
690     }
691     ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_SLAVE);
692     DELAY(10);
693     ostat1 = ATA_IDX_INB(ch, ATA_STATUS);
694     if ((ostat1 & 0xf8) != 0xf8 && ostat1 != 0xa5) {
695 	stat1 = ATA_S_BUSY;
696 	mask |= 0x02;
697     }
698 
699     ch->devices = 0;
700     if (!mask)
701 	return;
702 
703     /* in some setups we dont want to test for a slave */
704     if (ch->flags & ATA_NO_SLAVE) {
705 	stat1 = 0x0;
706 	mask &= ~0x02;
707     }
708 
709     if (bootverbose)
710 	ata_printf(ch, -1, "pre reset mask=%02x ostat0=%02x ostat2=%02x\n",
711 		   mask, ostat0, ostat1);
712 
713     /* reset channel */
714     ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_MASTER);
715     DELAY(10);
716     ATA_IDX_OUTB(ch, ATA_ALTSTAT, ATA_A_IDS | ATA_A_RESET);
717     DELAY(10000);
718     ATA_IDX_OUTB(ch, ATA_ALTSTAT, ATA_A_IDS);
719     DELAY(100000);
720     ATA_IDX_INB(ch, ATA_ERROR);
721 
722     /* wait for BUSY to go inactive */
723     for (timeout = 0; timeout < 310000; timeout++) {
724 	if (stat0 & ATA_S_BUSY) {
725 	    ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_MASTER);
726 	    DELAY(10);
727 
728 	    /* check for ATAPI signature while its still there */
729 	    lsb = ATA_IDX_INB(ch, ATA_CYL_LSB);
730 	    msb = ATA_IDX_INB(ch, ATA_CYL_MSB);
731 	    stat0 = ATA_IDX_INB(ch, ATA_STATUS);
732 	    if (!(stat0 & ATA_S_BUSY)) {
733 		if (bootverbose)
734 		    ata_printf(ch, ATA_MASTER, "ATAPI %02x %02x\n", lsb, msb);
735 		if (lsb == ATAPI_MAGIC_LSB && msb == ATAPI_MAGIC_MSB)
736 		    ch->devices |= ATA_ATAPI_MASTER;
737 	    }
738 	}
739 	if (stat1 & ATA_S_BUSY) {
740 	    ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_SLAVE);
741 	    DELAY(10);
742 
743 	    /* check for ATAPI signature while its still there */
744 	    lsb = ATA_IDX_INB(ch, ATA_CYL_LSB);
745 	    msb = ATA_IDX_INB(ch, ATA_CYL_MSB);
746 	    stat1 = ATA_IDX_INB(ch, ATA_STATUS);
747 	    if (!(stat1 & ATA_S_BUSY)) {
748 		if (bootverbose)
749 		    ata_printf(ch, ATA_SLAVE, "ATAPI %02x %02x\n", lsb, msb);
750 		if (lsb == ATAPI_MAGIC_LSB && msb == ATAPI_MAGIC_MSB)
751 		    ch->devices |= ATA_ATAPI_SLAVE;
752 	    }
753 	}
754 	if (mask == 0x01)      /* wait for master only */
755 	    if (!(stat0 & ATA_S_BUSY))
756 		break;
757 	if (mask == 0x02)      /* wait for slave only */
758 	    if (!(stat1 & ATA_S_BUSY))
759 		break;
760 	if (mask == 0x03)      /* wait for both master & slave */
761 	    if (!(stat0 & ATA_S_BUSY) && !(stat1 & ATA_S_BUSY))
762 		break;
763 	DELAY(100);
764     }
765     DELAY(10);
766     ATA_IDX_OUTB(ch, ATA_ALTSTAT, ATA_A_4BIT);
767 
768     if (stat0 & ATA_S_BUSY)
769 	mask &= ~0x01;
770     if (stat1 & ATA_S_BUSY)
771 	mask &= ~0x02;
772     if (bootverbose)
773 	ata_printf(ch, -1, "after reset mask=%02x stat0=%02x stat1=%02x\n",
774 		   mask, stat0, stat1);
775     if (!mask)
776 	return;
777 
778     if (mask & 0x01 && ostat0 != 0x00 && !(ch->devices & ATA_ATAPI_MASTER)) {
779 	ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_MASTER);
780 	DELAY(10);
781 	ATA_IDX_OUTB(ch, ATA_ERROR, 0x58);
782 	ATA_IDX_OUTB(ch, ATA_CYL_LSB, 0xa5);
783 	lsb = ATA_IDX_INB(ch, ATA_ERROR);
784 	msb = ATA_IDX_INB(ch, ATA_CYL_LSB);
785 	if (bootverbose)
786 	    ata_printf(ch, ATA_MASTER, "ATA %02x %02x\n", lsb, msb);
787 	if (lsb != 0x58 && msb == 0xa5)
788 	    ch->devices |= ATA_ATA_MASTER;
789     }
790     if (mask & 0x02 && ostat1 != 0x00 && !(ch->devices & ATA_ATAPI_SLAVE)) {
791 	ATA_IDX_OUTB(ch, ATA_DRIVE, ATA_D_IBM | ATA_SLAVE);
792 	DELAY(10);
793 	ATA_IDX_OUTB(ch, ATA_ERROR, 0x58);
794 	ATA_IDX_OUTB(ch, ATA_CYL_LSB, 0xa5);
795 	lsb = ATA_IDX_INB(ch, ATA_ERROR);
796 	msb = ATA_IDX_INB(ch, ATA_CYL_LSB);
797 	if (bootverbose)
798 	    ata_printf(ch, ATA_SLAVE, "ATA %02x %02x\n", lsb, msb);
799 	if (lsb != 0x58 && msb == 0xa5)
800 	    ch->devices |= ATA_ATA_SLAVE;
801     }
802     if (bootverbose)
803 	ata_printf(ch, -1, "devices=%02x\n", ch->devices);
804 }
805 
806 int
807 ata_reinit(struct ata_channel *ch)
808 {
809     int devices, misdev, newdev;
810 
811 
812     if (!ch->r_irq)
813 	return ENXIO;
814 
815     ATA_FORCELOCK_CH(ch, ATA_CONTROL);
816     ch->running = NULL;
817     devices = ch->devices;
818     ata_printf(ch, -1, "resetting devices ..\n");
819     ata_reset(ch);
820 
821     if ((misdev = devices & ~ch->devices)) {
822 #ifdef DEV_ATADISK
823 	if (misdev & ATA_ATA_MASTER && ch->device[MASTER].driver)
824 	    ad_detach(&ch->device[MASTER]);
825 	if (misdev & ATA_ATA_SLAVE && ch->device[SLAVE].driver)
826 	    ad_detach(&ch->device[SLAVE]);
827 #endif
828 #if DEV_ATAPIALL
829 	if (misdev & ATA_ATAPI_MASTER && ch->device[MASTER].driver)
830 	    atapi_detach(&ch->device[MASTER]);
831 	if (misdev & ATA_ATAPI_SLAVE && ch->device[SLAVE].driver)
832 	    atapi_detach(&ch->device[SLAVE]);
833 #endif
834 	if (misdev & ATA_ATA_MASTER || misdev & ATA_ATAPI_MASTER) {
835 	    if (ch->device[MASTER].param)
836 		free(ch->device[MASTER].param, M_ATA);
837 	    ch->device[MASTER].param = NULL;
838 	}
839 	if (misdev & ATA_ATA_SLAVE || misdev & ATA_ATAPI_SLAVE) {
840 	    if (ch->device[SLAVE].param)
841 		free(ch->device[SLAVE].param, M_ATA);
842 	    ch->device[SLAVE].param = NULL;
843 	}
844     }
845     if ((newdev = ~devices & ch->devices)) {
846 	if (newdev & ATA_ATA_MASTER)
847 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATA_IDENTIFY))
848 		ch->devices &= ~ATA_ATA_MASTER;
849 	if (newdev & ATA_ATA_SLAVE)
850 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATA_IDENTIFY))
851 		ch->devices &= ~ATA_ATA_SLAVE;
852 	if (newdev & ATA_ATAPI_MASTER)
853 	    if (ata_getparam(&ch->device[MASTER], ATA_C_ATAPI_IDENTIFY))
854 		ch->devices &= ~ATA_ATAPI_MASTER;
855 	if (newdev & ATA_ATAPI_SLAVE)
856 	    if (ata_getparam(&ch->device[SLAVE], ATA_C_ATAPI_IDENTIFY))
857 		ch->devices &= ~ATA_ATAPI_SLAVE;
858     }
859     newdev = ~devices & ch->devices;
860 #ifdef DEV_ATADISK
861     if (newdev & ATA_ATA_SLAVE && !ch->device[SLAVE].driver) {
862 	ATA_UNLOCK_CH(ch);
863 	ad_attach(&ch->device[SLAVE]);
864 	ATA_SLEEPLOCK_CH(ch, ATA_CONTROL);
865     }
866     else if (ch->devices & (ATA_ATA_SLAVE) && ch->device[SLAVE].driver) {
867 	ata_getparam(&ch->device[SLAVE], ATA_C_ATA_IDENTIFY);
868 	ad_reinit(&ch->device[SLAVE]);
869     }
870     if (newdev & ATA_ATA_MASTER && !ch->device[MASTER].driver) {
871 	ATA_UNLOCK_CH(ch);
872 	ad_attach(&ch->device[MASTER]);
873 	ATA_SLEEPLOCK_CH(ch, ATA_CONTROL);
874     }
875     else if (ch->devices & ATA_ATA_MASTER && ch->device[MASTER].driver) {
876 	ata_getparam(&ch->device[MASTER], ATA_C_ATA_IDENTIFY);
877 	ad_reinit(&ch->device[MASTER]);
878     }
879 #endif
880 #if DEV_ATAPIALL
881     if (newdev & ATA_ATAPI_SLAVE && !ch->device[SLAVE].driver) {
882 	ATA_UNLOCK_CH(ch);
883 	atapi_attach(&ch->device[SLAVE]);
884 	ATA_SLEEPLOCK_CH(ch, ATA_CONTROL);
885     }
886     else if (ch->devices & (ATA_ATAPI_SLAVE) && ch->device[SLAVE].driver) {
887 	ata_getparam(&ch->device[SLAVE], ATA_C_ATAPI_IDENTIFY);
888 	atapi_reinit(&ch->device[SLAVE]);
889     }
890     if (newdev & ATA_ATAPI_MASTER && !ch->device[MASTER].driver) {
891 	ATA_UNLOCK_CH(ch);
892 	atapi_attach(&ch->device[MASTER]);
893 	ATA_SLEEPLOCK_CH(ch, ATA_CONTROL);
894     }
895     else if (ch->devices & (ATA_ATAPI_MASTER) && ch->device[MASTER].driver) {
896 	ata_getparam(&ch->device[MASTER], ATA_C_ATAPI_IDENTIFY);
897 	atapi_reinit(&ch->device[MASTER]);
898     }
899 #endif
900 #ifdef DEV_ATAPICAM
901     atapi_cam_reinit_bus(ch);
902 #endif
903     printf("done\n");
904     ATA_UNLOCK_CH(ch);
905     ata_start(ch);
906     return 0;
907 }
908 
909 static int
910 ata_service(struct ata_channel *ch)
911 {
912     /* do we have a SERVICE request from the drive ? */
913     if ((ch->status & (ATA_S_SERVICE|ATA_S_ERROR|ATA_S_DRQ)) == ATA_S_SERVICE) {
914 #if 0 /* XXX */
915 	ATA_IDX_OUTB(ch->r_bmio, ATA_BMSTAT_PORT,
916 		 ch->dma->status(ch) | ATA_BMSTAT_INTERRUPT);
917 #endif
918 #ifdef DEV_ATADISK
919 	if ((ATA_IDX_INB(ch, ATA_DRIVE) & ATA_SLAVE) == ATA_MASTER) {
920 	    if ((ch->devices & ATA_ATA_MASTER) && ch->device[MASTER].driver)
921 		return ad_service((struct ad_softc *)
922 				  ch->device[MASTER].driver, 0);
923 	}
924 	else {
925 	    if ((ch->devices & ATA_ATA_SLAVE) && ch->device[SLAVE].driver)
926 		return ad_service((struct ad_softc *)
927 				  ch->device[SLAVE].driver, 0);
928 	}
929 #endif
930     }
931     return ATA_OP_FINISHED;
932 }
933 
934 static void
935 ata_flush(struct ata_device *atadev)
936 {
937     if (ata_command(atadev, ATA_C_FLUSHCACHE, 0, 0, 0, ATA_WAIT_READY))
938 	ata_prtdev(atadev, "flushing device failed\n");
939 }
940 
941 static void
942 ata_shutdown(void *arg, int howto)
943 {
944     struct ata_channel *ch;
945     int ctlr;
946 
947     /* flush cache on all devices */
948     for (ctlr = 0; ctlr < devclass_get_maxunit(ata_devclass); ctlr++) {
949 	if (!(ch = devclass_get_softc(ata_devclass, ctlr)))
950 	    continue;
951 	ch->locking(ch, ATA_LF_LOCK);
952 	if (ch->device[MASTER].param)
953 	    ata_flush(&ch->device[MASTER]);
954 	if (ch->device[SLAVE].param)
955 	    ata_flush(&ch->device[SLAVE]);
956 	ch->locking(ch, ATA_LF_UNLOCK);
957     }
958 }
959 
960 int
961 ata_wait(struct ata_device *atadev, u_int8_t mask)
962 {
963     int timeout = 0;
964 
965     DELAY(1);
966     while (timeout < 5000000) { /* timeout 5 secs */
967 	atadev->channel->status = ATA_IDX_INB(atadev->channel, ATA_STATUS);
968 
969 	/* if drive fails status, reselect the drive just to be sure */
970 	if (atadev->channel->status == 0xff) {
971 	    ata_prtdev(atadev, "no status, reselecting device\n");
972 	    ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM|atadev->unit);
973 	    DELAY(10);
974 	    atadev->channel->status = ATA_IDX_INB(atadev->channel, ATA_STATUS);
975 	    if (atadev->channel->status == 0xff)
976 		return -1;
977 	}
978 
979 	/* are we done ? */
980 	if (!(atadev->channel->status & ATA_S_BUSY))
981 	    break;
982 
983 	if (timeout > 1000) {
984 	    timeout += 1000;
985 	    DELAY(1000);
986 	}
987 	else {
988 	    timeout += 10;
989 	    DELAY(10);
990 	}
991     }
992     if (atadev->channel->status & ATA_S_ERROR)
993 	atadev->channel->error = ATA_IDX_INB(atadev->channel, ATA_ERROR);
994     if (timeout >= 5000000)
995 	return -1;
996     if (!mask)
997 	return (atadev->channel->status & ATA_S_ERROR);
998 
999     /* Wait 50 msec for bits wanted. */
1000     timeout = 5000;
1001     while (timeout--) {
1002 	atadev->channel->status = ATA_IDX_INB(atadev->channel, ATA_STATUS);
1003 	if ((atadev->channel->status & mask) == mask) {
1004 	    if (atadev->channel->status & ATA_S_ERROR)
1005 		atadev->channel->error=ATA_IDX_INB(atadev->channel, ATA_ERROR);
1006 	    return (atadev->channel->status & ATA_S_ERROR);
1007 	}
1008 	DELAY (10);
1009     }
1010     return -1;
1011 }
1012 
1013 int
1014 ata_command(struct ata_device *atadev, u_int8_t command,
1015 	   u_int64_t lba, u_int16_t count, u_int16_t feature, int flags)
1016 {
1017     int error = 0;
1018 #ifdef ATA_DEBUG
1019     ata_prtdev(atadev, "ata_command: addr=%04lx, cmd=%02x, "
1020 	       "lba=%jd, count=%d, feature=%d, flags=%02x\n",
1021 	       rman_get_start(atadev->channel->r_io[ATA_DATA].res),
1022 	       command, (intmax_t)lba, count, feature, flags);
1023 #endif
1024 
1025     /* select device */
1026     ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM | atadev->unit);
1027 
1028     /* disable interrupt from device */
1029     if (atadev->channel->flags & ATA_QUEUED)
1030 	ATA_IDX_OUTB(atadev->channel, ATA_ALTSTAT, ATA_A_IDS | ATA_A_4BIT);
1031 
1032     /* ready to issue command ? */
1033     if (ata_wait(atadev, 0) < 0) {
1034 	ata_prtdev(atadev, "timeout sending command=%02x s=%02x e=%02x\n",
1035 		   command, atadev->channel->status, atadev->channel->error);
1036 	return -1;
1037     }
1038 
1039     /* only use 48bit addressing if needed because of the overhead */
1040     if ((lba > 268435455 || count > 256) && atadev->param &&
1041 	atadev->param->support.address48) {
1042 	ATA_IDX_OUTB(atadev->channel, ATA_FEATURE, (feature>>8) & 0xff);
1043 	ATA_IDX_OUTB(atadev->channel, ATA_FEATURE, feature);
1044 	ATA_IDX_OUTB(atadev->channel, ATA_COUNT, (count>>8) & 0xff);
1045 	ATA_IDX_OUTB(atadev->channel, ATA_COUNT, count & 0xff);
1046 	ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, (lba>>24) & 0xff);
1047 	ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, lba & 0xff);
1048 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_LSB, (lba>>32) & 0xff);
1049 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_LSB, (lba>>8) & 0xff);
1050 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_MSB, (lba>>40) & 0xff);
1051 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_MSB, (lba>>16) & 0xff);
1052 	ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_LBA | atadev->unit);
1053 
1054 	/* translate command into 48bit version */
1055 	switch (command) {
1056 	case ATA_C_READ:
1057 	    command = ATA_C_READ48; break;
1058 	case ATA_C_READ_MUL:
1059 	    command = ATA_C_READ_MUL48; break;
1060 	case ATA_C_READ_DMA:
1061 	    command = ATA_C_READ_DMA48; break;
1062 	case ATA_C_READ_DMA_QUEUED:
1063 	    command = ATA_C_READ_DMA_QUEUED48; break;
1064 	case ATA_C_WRITE:
1065 	    command = ATA_C_WRITE48; break;
1066 	case ATA_C_WRITE_MUL:
1067 	    command = ATA_C_WRITE_MUL48; break;
1068 	case ATA_C_WRITE_DMA:
1069 	    command = ATA_C_WRITE_DMA48; break;
1070 	case ATA_C_WRITE_DMA_QUEUED:
1071 	    command = ATA_C_WRITE_DMA_QUEUED48; break;
1072 	case ATA_C_FLUSHCACHE:
1073 	    command = ATA_C_FLUSHCACHE48; break;
1074 	default:
1075 	    ata_prtdev(atadev, "can't translate cmd to 48bit version\n");
1076 	    return -1;
1077 	}
1078 	atadev->channel->flags |= ATA_48BIT_ACTIVE;
1079     }
1080     else {
1081 	ATA_IDX_OUTB(atadev->channel, ATA_FEATURE, feature);
1082 	ATA_IDX_OUTB(atadev->channel, ATA_COUNT, count);
1083 	ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, lba & 0xff);
1084 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_LSB, (lba>>8) & 0xff);
1085 	ATA_IDX_OUTB(atadev->channel, ATA_CYL_MSB, (lba>>16) & 0xff);
1086 	if (atadev->flags & ATA_D_USE_CHS)
1087 	    ATA_IDX_OUTB(atadev->channel, ATA_DRIVE,
1088 		     ATA_D_IBM | atadev->unit | ((lba>>24) & 0xf));
1089 	else
1090 	    ATA_IDX_OUTB(atadev->channel, ATA_DRIVE,
1091 		     ATA_D_IBM | ATA_D_LBA | atadev->unit | ((lba>>24) &0xf));
1092 	atadev->channel->flags &= ~ATA_48BIT_ACTIVE;
1093     }
1094 
1095     switch (flags & ATA_WAIT_MASK) {
1096     case ATA_IMMEDIATE:
1097 	ATA_IDX_OUTB(atadev->channel, ATA_CMD, command);
1098 
1099 	/* enable interrupt */
1100 	if (atadev->channel->flags & ATA_QUEUED)
1101 	    ATA_IDX_OUTB(atadev->channel, ATA_ALTSTAT, ATA_A_4BIT);
1102 	break;
1103 
1104     case ATA_WAIT_INTR:
1105 	atadev->channel->active |= ATA_WAIT_INTR;
1106 	ATA_IDX_OUTB(atadev->channel, ATA_CMD, command);
1107 
1108 	/* enable interrupt */
1109 	if (atadev->channel->flags & ATA_QUEUED)
1110 	    ATA_IDX_OUTB(atadev->channel, ATA_ALTSTAT, ATA_A_4BIT);
1111 
1112 	if (tsleep(atadev->channel, PRIBIO, "atacmd", 10 * hz)) {
1113 	    ata_prtdev(atadev, "timeout waiting for interrupt\n");
1114 	    atadev->channel->active &= ~ATA_WAIT_INTR;
1115 	    error = -1;
1116 	}
1117 	break;
1118 
1119     case ATA_WAIT_READY:
1120 	atadev->channel->active |= ATA_WAIT_READY;
1121 	ATA_IDX_OUTB(atadev->channel, ATA_CMD, command);
1122 	if (ata_wait(atadev, ATA_S_READY) < 0) {
1123 	    ata_prtdev(atadev, "timeout waiting for cmd=%02x s=%02x e=%02x\n",
1124 		       command, atadev->channel->status,atadev->channel->error);
1125 	    error = -1;
1126 	}
1127 	atadev->channel->active &= ~ATA_WAIT_READY;
1128 	break;
1129     }
1130     return error;
1131 }
1132 
1133 static void
1134 ata_enclosure_start(struct ata_device *atadev)
1135 {
1136     ATA_IDX_INB(atadev->channel, ATA_DRIVE);
1137     DELAY(1);
1138     ATA_IDX_INB(atadev->channel, ATA_DRIVE);
1139     DELAY(1);
1140     ATA_IDX_INB(atadev->channel, ATA_CMD);
1141     DELAY(1);
1142     ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM | atadev->unit);
1143     DELAY(1);
1144     ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM | atadev->unit);
1145     DELAY(1);
1146     ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM | atadev->unit);
1147     DELAY(1);
1148     ATA_IDX_INB(atadev->channel, ATA_COUNT);
1149     DELAY(1);
1150     ATA_IDX_INB(atadev->channel, ATA_DRIVE);
1151     DELAY(1);
1152 }
1153 
1154 static void
1155 ata_enclosure_end(struct ata_device *atadev)
1156 {
1157     ATA_IDX_OUTB(atadev->channel, ATA_DRIVE, ATA_D_IBM | atadev->unit);
1158     DELAY(1);
1159 }
1160 
1161 static void
1162 ata_enclosure_chip_start(struct ata_device *atadev)
1163 {
1164     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x0b);
1165     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x0a);
1166     DELAY(25);
1167     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x08);
1168 }
1169 
1170 static void
1171 ata_enclosure_chip_end(struct ata_device *atadev)
1172 {
1173     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x08);
1174     DELAY(64);
1175     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x0a);
1176     DELAY(25);
1177     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x0b);
1178     DELAY(64);
1179 }
1180 
1181 static u_int8_t
1182 ata_enclosure_chip_rdbit(struct ata_device *atadev)
1183 {
1184     u_int8_t val;
1185 
1186     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0);
1187     DELAY(64);
1188     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x02);
1189     DELAY(25);
1190     val = ATA_IDX_INB(atadev->channel, ATA_SECTOR) & 0x01;
1191     DELAY(38);
1192     return val;
1193 }
1194 
1195 static void
1196 ata_enclosure_chip_wrbit(struct ata_device *atadev, u_int8_t data)
1197 {
1198     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x08 | (data & 0x01));
1199     DELAY(64);
1200     ATA_IDX_OUTB(atadev->channel, ATA_SECTOR, 0x08 | 0x02 | (data & 0x01));
1201     DELAY(64);
1202 }
1203 
1204 static u_int8_t
1205 ata_enclosure_chip_rw(struct ata_device *atadev, int rw, u_int8_t val)
1206 {
1207     int i;
1208 
1209     if (rw) {
1210 	for (i = 0; i < 8; i++)
1211 	    ata_enclosure_chip_wrbit(atadev, (val & (0x80 >> i)) ? 1 : 0);
1212     }
1213     else {
1214 	for (i = 0; i < 8; i++)
1215 	    val = (val << 1) | ata_enclosure_chip_rdbit(atadev);
1216     }
1217     ata_enclosure_chip_wrbit(atadev, 0);
1218     return val;
1219 }
1220 
1221 static u_int8_t
1222 ata_enclosure_sensor(struct ata_device *atadev,
1223 		     int rw, u_int8_t idx, u_int8_t data)
1224 {
1225     ata_enclosure_start(atadev);
1226     ata_enclosure_chip_start(atadev);
1227     ata_enclosure_chip_rw(atadev, 1, 0x5a);
1228     ata_enclosure_chip_rw(atadev, 1, idx);
1229     if (rw) {
1230 	ata_enclosure_chip_rw(atadev, 1, data);
1231     }
1232     else {
1233 	ata_enclosure_chip_end(atadev);
1234 	ata_enclosure_chip_start(atadev);
1235 	ata_enclosure_chip_rw(atadev, 1, 0x5b);
1236 	data = ata_enclosure_chip_rw(atadev, 0, 0);
1237     }
1238     ata_enclosure_chip_end(atadev);
1239     ata_enclosure_end(atadev);
1240     return data;
1241 }
1242 
1243 static int
1244 ata_enclosure_status(struct ata_device *atadev,
1245 		     int *fan, int *temp, int *v05, int *v12)
1246 {
1247     u_int8_t id1, id2, cnt, div;
1248     int error = ENXIO;
1249 
1250     if (atadev->flags & ATA_D_ENC_PRESENT) {
1251 	atadev->channel->locking(atadev->channel, ATA_LF_LOCK);
1252 	ATA_SLEEPLOCK_CH(atadev->channel, ATA_CONTROL);
1253 	ata_enclosure_sensor(atadev, 1, 0x4e, 0);
1254 	id1 = ata_enclosure_sensor(atadev, 0, 0x4f, 0);
1255 	ata_enclosure_sensor(atadev, 1, 0x4e, 0x80);
1256 	id2 = ata_enclosure_sensor(atadev, 0, 0x4f, 0);
1257 	if (id1 == 0xa3 && id2 == 0x5c) {
1258 	    div = 1 << (((ata_enclosure_sensor(atadev, 0, 0x5d, 0)&0x20)>>3)+
1259 			((ata_enclosure_sensor(atadev, 0, 0x47, 0)&0x30)>>4)+1);
1260 	    cnt = ata_enclosure_sensor(atadev, 0, 0x28, 0);
1261 	    if (cnt == 0xff)
1262 		*fan = 0;
1263 	    else
1264 		*fan = 1350000 / cnt / div;
1265 	    ata_enclosure_sensor(atadev, 1, 0x4e, 0x01);
1266 	    *temp = (ata_enclosure_sensor(atadev, 0, 0x50, 0) * 10) +
1267 		    (ata_enclosure_sensor(atadev, 0, 0x50, 0) & 0x80 ? 5 : 0);
1268 	    *v05 = ata_enclosure_sensor(atadev, 0, 0x23, 0) * 27;
1269 	    *v12 = ata_enclosure_sensor(atadev, 0, 0x24, 0) * 61;
1270 	    error = 0;
1271 	}
1272 	ATA_UNLOCK_CH(atadev->channel);
1273 	atadev->channel->locking(atadev->channel, ATA_LF_UNLOCK);
1274     }
1275     return error;
1276 }
1277 
1278 void
1279 ata_enclosure_print(struct ata_device *atadev)
1280 {
1281     u_int8_t id, st;
1282     int fan, temp, v05, v12;
1283 
1284     atadev->channel->locking(atadev->channel, ATA_LF_LOCK);
1285     ATA_SLEEPLOCK_CH(atadev->channel, ATA_CONTROL);
1286     ata_enclosure_start(atadev);
1287     id = ATA_IDX_INB(atadev->channel, ATA_DRIVE);
1288     DELAY(1);
1289     st = ATA_IDX_INB(atadev->channel, ATA_COUNT);
1290     DELAY(1);
1291     ata_enclosure_end(atadev);
1292     ATA_UNLOCK_CH(atadev->channel);
1293     atadev->channel->locking(atadev->channel, ATA_LF_UNLOCK);
1294 
1295     switch (id & 0x93) {
1296     case 0x00:
1297 	ata_prtdev(atadev, "Universal enclosure");
1298 	break;
1299     case 0x01:
1300 	ata_prtdev(atadev, "FastSwap enclosure");
1301 	break;
1302     case 0x10:
1303     case 0x11:
1304 	ata_prtdev(atadev, "SuperSwap enclosure");
1305 	break;
1306     default:
1307 	atadev->flags &= ~ATA_D_ENC_PRESENT;
1308 	return;
1309     }
1310     atadev->flags |= ATA_D_ENC_PRESENT;
1311 
1312     ata_enclosure_leds(atadev, ATA_LED_GREEN);
1313     if (ata_enclosure_status(atadev, &fan, &temp, &v05, &v12))
1314 	printf(" detected\n");
1315     else
1316 	printf(" [FAN:%drpm TEMP:%d.%01dC %d.%03dV %d.%03dV]\n",
1317 	       fan, temp/10, temp%10, v05/1000, v05%1000, v12/1000, v12%1000);
1318 }
1319 
1320 void
1321 ata_enclosure_leds(struct ata_device *atadev, u_int8_t color)
1322 {
1323     if (atadev->flags & ATA_D_ENC_PRESENT) {
1324 	u_int8_t reg;
1325 
1326 	ata_enclosure_start(atadev);
1327 	reg = ATA_IDX_INB(atadev->channel, ATA_COUNT);
1328 	DELAY(1);
1329 	ATA_IDX_OUTB(atadev->channel, ATA_COUNT,
1330 		 (color & ATA_LED_MASK) | (reg & ~ATA_LED_MASK));
1331 	DELAY(1);
1332 	ata_enclosure_end(atadev);
1333     }
1334 }
1335 
1336 static void
1337 ata_change_mode(struct ata_device *atadev, int mode)
1338 {
1339     ATA_SLEEPLOCK_CH(atadev->channel, ATA_ACTIVE);
1340     atadev->setmode(atadev, mode);
1341     ATA_UNLOCK_CH(atadev->channel);
1342     ata_start(atadev->channel);
1343 }
1344 
1345 int
1346 ata_printf(struct ata_channel *ch, int device, const char * fmt, ...)
1347 {
1348     va_list ap;
1349     int ret;
1350 
1351     if (device == -1)
1352 	ret = printf("ata%d: ", device_get_unit(ch->dev));
1353     else {
1354 	if (ch->device[ATA_DEV(device)].name)
1355 	    ret = printf("%s: ", ch->device[ATA_DEV(device)].name);
1356 	else
1357 	    ret = printf("ata%d-%s: ", device_get_unit(ch->dev),
1358 			 (device == ATA_MASTER) ? "master" : "slave");
1359     }
1360     va_start(ap, fmt);
1361     ret += vprintf(fmt, ap);
1362     va_end(ap);
1363     return ret;
1364 }
1365 
1366 int
1367 ata_prtdev(struct ata_device *atadev, const char * fmt, ...)
1368 {
1369     va_list ap;
1370     int ret;
1371 
1372     if (atadev->name)
1373 	ret = printf("%s: ", atadev->name);
1374     else
1375 	ret = printf("ata%d-%s: ", device_get_unit(atadev->channel->dev),
1376 		     (atadev->unit == ATA_MASTER) ? "master" : "slave");
1377     va_start(ap, fmt);
1378     ret += vprintf(fmt, ap);
1379     va_end(ap);
1380     return ret;
1381 }
1382 
1383 void
1384 ata_set_name(struct ata_device *atadev, char *name, int lun)
1385 {
1386     atadev->name = malloc(strlen(name) + 4, M_ATA, M_NOWAIT);
1387     if (atadev->name)
1388 	sprintf(atadev->name, "%s%d", name, lun);
1389 }
1390 
1391 void
1392 ata_free_name(struct ata_device *atadev)
1393 {
1394     if (atadev->name)
1395 	free(atadev->name, M_ATA);
1396     atadev->name = NULL;
1397 }
1398 
1399 int
1400 ata_get_lun(u_int32_t *map)
1401 {
1402     int lun = ffs(~*map) - 1;
1403 
1404     *map |= (1 << lun);
1405     return lun;
1406 }
1407 
1408 int
1409 ata_test_lun(u_int32_t *map, int lun)
1410 {
1411     return (*map & (1 << lun));
1412 }
1413 
1414 void
1415 ata_free_lun(u_int32_t *map, int lun)
1416 {
1417     *map &= ~(1 << lun);
1418 }
1419 
1420 char *
1421 ata_mode2str(int mode)
1422 {
1423     switch (mode) {
1424     case ATA_PIO: return "BIOSPIO";
1425     case ATA_PIO0: return "PIO0";
1426     case ATA_PIO1: return "PIO1";
1427     case ATA_PIO2: return "PIO2";
1428     case ATA_PIO3: return "PIO3";
1429     case ATA_PIO4: return "PIO4";
1430     case ATA_DMA: return "BIOSDMA";
1431     case ATA_WDMA0: return "WDMA0";
1432     case ATA_WDMA1: return "WDMA1";
1433     case ATA_WDMA2: return "WDMA2";
1434     case ATA_UDMA0: return "UDMA16";
1435     case ATA_UDMA1: return "UDMA25";
1436     case ATA_UDMA2: return "UDMA33";
1437     case ATA_UDMA3: return "UDMA40";
1438     case ATA_UDMA4: return "UDMA66";
1439     case ATA_UDMA5: return "UDMA100";
1440     case ATA_UDMA6: return "UDMA133";
1441     default: return "???";
1442     }
1443 }
1444 
1445 int
1446 ata_pmode(struct ata_params *ap)
1447 {
1448     if (ap->atavalid & ATA_FLAG_64_70) {
1449 	if (ap->apiomodes & 0x02)
1450 	    return ATA_PIO4;
1451 	if (ap->apiomodes & 0x01)
1452 	    return ATA_PIO3;
1453     }
1454     if (ap->retired_piomode == 2)
1455 	return ATA_PIO2;
1456     if (ap->retired_piomode == 1)
1457 	return ATA_PIO1;
1458     if (ap->retired_piomode == 0)
1459 	return ATA_PIO0;
1460     if (ap->support_dma)
1461 	return ATA_PIO4;
1462     return ATA_PIO0;
1463 }
1464 
1465 int
1466 ata_wmode(struct ata_params *ap)
1467 {
1468     if (ap->mwdmamodes & 0x04)
1469 	return ATA_WDMA2;
1470     if (ap->mwdmamodes & 0x02)
1471 	return ATA_WDMA1;
1472     if (ap->mwdmamodes & 0x01)
1473 	return ATA_WDMA0;
1474     if (ap->support_dma)
1475 	return ATA_WDMA2;
1476     return -1;
1477 }
1478 
1479 int
1480 ata_umode(struct ata_params *ap)
1481 {
1482     if (ap->atavalid & ATA_FLAG_88) {
1483 	if (ap->udmamodes & 0x40)
1484 	    return ATA_UDMA6;
1485 	if (ap->udmamodes & 0x20)
1486 	    return ATA_UDMA5;
1487 	if (ap->udmamodes & 0x10)
1488 	    return ATA_UDMA4;
1489 	if (ap->udmamodes & 0x08)
1490 	    return ATA_UDMA3;
1491 	if (ap->udmamodes & 0x04)
1492 	    return ATA_UDMA2;
1493 	if (ap->udmamodes & 0x02)
1494 	    return ATA_UDMA1;
1495 	if (ap->udmamodes & 0x01)
1496 	    return ATA_UDMA0;
1497     }
1498     return -1;
1499 }
1500 
1501 int
1502 ata_limit_mode(struct ata_device *atadev, int mode, int maxmode)
1503 {
1504     if (maxmode && mode > maxmode)
1505 	mode = maxmode;
1506 
1507     if (mode >= ATA_UDMA0 && ata_umode(atadev->param) > 0)
1508 	return min(mode, ata_umode(atadev->param));
1509 
1510     if (mode >= ATA_WDMA0 && ata_wmode(atadev->param) > 0)
1511 	return min(mode, ata_wmode(atadev->param));
1512 
1513     if (mode > ata_pmode(atadev->param))
1514 	return min(mode, ata_pmode(atadev->param));
1515 
1516     return mode;
1517 }
1518 
1519 static void
1520 bswap(int8_t *buf, int len)
1521 {
1522     u_int16_t *ptr = (u_int16_t*)(buf + len);
1523 
1524     while (--ptr >= (u_int16_t*)buf)
1525 	*ptr = ntohs(*ptr);
1526 }
1527 
1528 static void
1529 btrim(int8_t *buf, int len)
1530 {
1531     int8_t *ptr;
1532 
1533     for (ptr = buf; ptr < buf+len; ++ptr)
1534 	if (!*ptr)
1535 	    *ptr = ' ';
1536     for (ptr = buf + len - 1; ptr >= buf && *ptr == ' '; --ptr)
1537 	*ptr = 0;
1538 }
1539 
1540 static void
1541 bpack(int8_t *src, int8_t *dst, int len)
1542 {
1543     int i, j, blank;
1544 
1545     for (i = j = blank = 0 ; i < len; i++) {
1546 	if (blank && src[i] == ' ') continue;
1547 	if (blank && src[i] != ' ') {
1548 	    dst[j++] = src[i];
1549 	    blank = 0;
1550 	    continue;
1551 	}
1552 	if (src[i] == ' ') {
1553 	    blank = 1;
1554 	    if (i == 0)
1555 		continue;
1556 	}
1557 	dst[j++] = src[i];
1558     }
1559     if (j < len)
1560 	dst[j] = 0x00;
1561 }
1562 
1563 static void
1564 ata_init(void)
1565 {
1566     /* register controlling device */
1567     make_dev(&ata_cdevsw, 0, UID_ROOT, GID_OPERATOR, 0600, "ata");
1568 
1569     /* register boot attach to be run when interrupts are enabled */
1570     if (!(ata_delayed_attach = (struct intr_config_hook *)
1571 			       malloc(sizeof(struct intr_config_hook),
1572 				      M_TEMP, M_NOWAIT | M_ZERO))) {
1573 	printf("ata: malloc of delayed attach hook failed\n");
1574 	return;
1575     }
1576 
1577     ata_delayed_attach->ich_func = (void*)ata_boot_attach;
1578     if (config_intrhook_establish(ata_delayed_attach) != 0) {
1579 	printf("ata: config_intrhook_establish failed\n");
1580 	free(ata_delayed_attach, M_TEMP);
1581     }
1582     /* Register a handler to flush write caches on shutdown */
1583     if ((EVENTHANDLER_REGISTER(shutdown_post_sync, ata_shutdown,
1584 			       NULL, SHUTDOWN_PRI_DEFAULT)) == NULL)
1585 	printf("ata: shutdown event registration failed!\n");
1586 
1587 }
1588 SYSINIT(atadev, SI_SUB_DRIVERS, SI_ORDER_SECOND, ata_init, NULL)
1589