xref: /openbsd-src/sys/dev/acpi/ccp_acpi.c (revision 471aeecfc619bc9b69519928152daf993376c2a1)
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