summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/ahci.c38
1 files changed, 37 insertions, 1 deletions
diff --git a/sys/dev/pci/ahci.c b/sys/dev/pci/ahci.c
index 2c4e9d206f2..df65697cd68 100644
--- a/sys/dev/pci/ahci.c
+++ b/sys/dev/pci/ahci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ahci.c,v 1.42 2007/02/18 01:27:55 dlg Exp $ */
+/* $OpenBSD: ahci.c,v 1.43 2007/02/19 13:54:07 dlg Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -31,6 +31,8 @@
#include <dev/pci/pcivar.h>
#include <dev/pci/pcidevs.h>
+#include <dev/ata/atascsi.h>
+
#define AHCI_DEBUG
#ifdef AHCI_DEBUG
@@ -339,6 +341,8 @@ struct ahci_softc {
u_int sc_ncmds;
struct ahci_port *sc_ports[AHCI_MAX_PORTS];
+
+ struct atascsi *sc_atascsi;
};
#define DEVNAME(_s) ((_s)->sc_dev.dv_xname)
@@ -380,6 +384,15 @@ int ahci_wait_eq(struct ahci_softc *, bus_size_t,
int ahci_wait_ne(struct ahci_softc *, bus_size_t,
u_int32_t, u_int32_t);
+/* provide methods for atascsi to call */
+int ahci_ata_probe(void *, int);
+int ahci_ata_cmd(void *, struct ata_xfer *);
+
+struct atascsi_methods ahci_atascsi_methods = {
+ ahci_ata_probe,
+ ahci_ata_cmd
+};
+
int
ahci_match(struct device *parent, void *match, void *aux)
{
@@ -392,6 +405,7 @@ ahci_attach(struct device *parent, struct device *self, void *aux)
{
struct ahci_softc *sc = (struct ahci_softc *)self;
struct pci_attach_args *pa = aux;
+ struct atascsi_attach_args aaa;
u_int32_t reg;
int i;
@@ -451,6 +465,15 @@ ahci_attach(struct device *parent, struct device *self, void *aux)
goto freeports;
}
+ bzero(&aaa, sizeof(aaa));
+ aaa.aaa_cookie = sc;
+ aaa.aaa_methods = &ahci_atascsi_methods;
+ aaa.aaa_minphys = minphys;
+ aaa.aaa_nports = AHCI_MAX_PORTS;
+ aaa.aaa_ncmds = sc->sc_ncmds;
+
+ sc->sc_atascsi = atascsi_attach(self, &aaa);
+
return;
freeports:
@@ -685,6 +708,19 @@ ahci_intr(void *arg)
return (0);
}
+int
+ahci_ata_probe(void *xsc, int port)
+{
+ return (0);
+}
+
+int
+ahci_ata_cmd(void *xsc, struct ata_xfer *xa)
+{
+ return (0);
+}
+
+
struct ahci_ccb *
ahci_get_ccb(struct ahci_port *ap)
{