1*471aeecfSnaddy /* $OpenBSD: ccp_acpi.c,v 1.4 2022/04/06 18:59:27 naddy Exp $ */
245109afeSkettenis /*
345109afeSkettenis * Copyright (c) 2019 Mark Kettenis
445109afeSkettenis *
545109afeSkettenis * Permission to use, copy, modify, and distribute this software for any
645109afeSkettenis * purpose with or without fee is hereby granted, provided that the above
745109afeSkettenis * copyright notice and this permission notice appear in all copies.
845109afeSkettenis *
945109afeSkettenis * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
1045109afeSkettenis * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
1145109afeSkettenis * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
1245109afeSkettenis * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
1345109afeSkettenis * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
1445109afeSkettenis * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
1545109afeSkettenis * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
1645109afeSkettenis */
1745109afeSkettenis
1845109afeSkettenis #include <sys/param.h>
1945109afeSkettenis #include <sys/systm.h>
2045109afeSkettenis
2145109afeSkettenis #include <dev/acpi/acpireg.h>
2245109afeSkettenis #include <dev/acpi/acpivar.h>
2345109afeSkettenis #include <dev/acpi/acpidev.h>
2445109afeSkettenis #include <dev/acpi/amltypes.h>
2545109afeSkettenis #include <dev/acpi/dsdt.h>
2645109afeSkettenis
2745109afeSkettenis #include <dev/ic/ccpvar.h>
2845109afeSkettenis
2945109afeSkettenis struct ccp_acpi_softc {
3045109afeSkettenis struct ccp_softc sc;
3145109afeSkettenis struct acpi_softc *sc_acpi;
3245109afeSkettenis struct aml_node *sc_node;
3345109afeSkettenis };
3445109afeSkettenis
3545109afeSkettenis int ccp_acpi_match(struct device *, void *, void *);
3645109afeSkettenis void ccp_acpi_attach(struct device *, struct device *, void *);
3745109afeSkettenis
38*471aeecfSnaddy const struct cfattach ccp_acpi_ca = {
3945109afeSkettenis sizeof(struct ccp_acpi_softc), ccp_acpi_match, ccp_acpi_attach
4045109afeSkettenis };
4145109afeSkettenis
4245109afeSkettenis const char *ccp_hids[] = {
4345109afeSkettenis "AMDI0C00",
4445109afeSkettenis NULL
4545109afeSkettenis };
4645109afeSkettenis
4745109afeSkettenis int
ccp_acpi_match(struct device * parent,void * match,void * aux)4845109afeSkettenis ccp_acpi_match(struct device *parent, void *match, void *aux)
4945109afeSkettenis {
5045109afeSkettenis struct acpi_attach_args *aaa = aux;
5145109afeSkettenis struct cfdata *cf = match;
5245109afeSkettenis
5357ec0946Skettenis if (aaa->aaa_naddr < 1)
5457ec0946Skettenis return 0;
5545109afeSkettenis return acpi_matchhids(aaa, ccp_hids, cf->cf_driver->cd_name);
5645109afeSkettenis }
5745109afeSkettenis
5845109afeSkettenis void
ccp_acpi_attach(struct device * parent,struct device * self,void * aux)5945109afeSkettenis ccp_acpi_attach(struct device *parent, struct device *self, void *aux)
6045109afeSkettenis {
6145109afeSkettenis struct ccp_acpi_softc *sc = (struct ccp_acpi_softc *)self;
62f09f3dbfSkettenis struct acpi_attach_args *aaa = aux;
6345109afeSkettenis
6445109afeSkettenis sc->sc_acpi = (struct acpi_softc *)parent;
6545109afeSkettenis sc->sc_node = aaa->aaa_node;
6645109afeSkettenis printf(" %s", sc->sc_node->name);
6745109afeSkettenis
68f09f3dbfSkettenis printf(" addr 0x%llx/0x%llx", aaa->aaa_addr[0], aaa->aaa_size[0]);
6945109afeSkettenis
70f09f3dbfSkettenis sc->sc.sc_iot = aaa->aaa_bst[0];
71f09f3dbfSkettenis if (bus_space_map(sc->sc.sc_iot, aaa->aaa_addr[0], aaa->aaa_size[0],
72f09f3dbfSkettenis 0, &sc->sc.sc_ioh)) {
7345109afeSkettenis printf(": can't map registers\n");
7445109afeSkettenis return;
7545109afeSkettenis }
7645109afeSkettenis
7745109afeSkettenis ccp_attach(&sc->sc);
7845109afeSkettenis }
79