Module Name: src Committed By: jruoho Date: Tue Oct 26 04:24:21 UTC 2010
Modified Files: src/sys/dev/acpi: atk0110.c Log Message: Use kmem(9) instead of malloc(9). To generate a diff of this commit: cvs rdiff -u -r1.14 -r1.15 src/sys/dev/acpi/atk0110.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/acpi/atk0110.c diff -u src/sys/dev/acpi/atk0110.c:1.14 src/sys/dev/acpi/atk0110.c:1.15 --- src/sys/dev/acpi/atk0110.c:1.14 Tue Oct 26 03:11:10 2010 +++ src/sys/dev/acpi/atk0110.c Tue Oct 26 04:24:21 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: atk0110.c,v 1.14 2010/10/26 03:11:10 jruoho Exp $ */ +/* $NetBSD: atk0110.c,v 1.15 2010/10/26 04:24:21 jruoho Exp $ */ /* $OpenBSD: atk0110.c,v 1.1 2009/07/23 01:38:16 cnst Exp $ */ /* @@ -18,10 +18,10 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: atk0110.c,v 1.14 2010/10/26 03:11:10 jruoho Exp $"); +__KERNEL_RCSID(0, "$NetBSD: atk0110.c,v 1.15 2010/10/26 04:24:21 jruoho Exp $"); #include <sys/param.h> -#include <sys/malloc.h> +#include <sys/kmem.h> #include <sys/module.h> #include <sys/systm.h> @@ -52,12 +52,13 @@ struct aibs_softc { struct acpi_devnode *sc_node; - + struct sysmon_envsys *sc_sme; struct aibs_sensor *sc_asens_volt; struct aibs_sensor *sc_asens_temp; struct aibs_sensor *sc_asens_fan; - - struct sysmon_envsys *sc_sme; + uint32_t sc_asens_volt_count; + uint32_t sc_asens_temp_count; + uint32_t sc_asens_fan_count; }; static int aibs_match(device_t, cfdata_t, void *); @@ -93,7 +94,6 @@ { struct aibs_softc *sc = device_private(self); struct acpi_attach_args *aa = aux; - int err; sc->sc_node = aa->aa_node; @@ -110,26 +110,16 @@ aibs_attach_sif(self, ENVSYS_STEMP); aibs_attach_sif(self, ENVSYS_SFANRPM); + (void)pmf_device_register(self, NULL, NULL); + if (sc->sc_sme->sme_nsensors == 0) { aprint_error_dev(self, "no sensors found\n"); sysmon_envsys_destroy(sc->sc_sme); return; } - if ((err = sysmon_envsys_register(sc->sc_sme))) { - aprint_error_dev(self, "unable to register with sysmon: %d\n", - err); - if (sc->sc_asens_volt != NULL) - free(sc->sc_asens_volt, M_DEVBUF); - if (sc->sc_asens_temp != NULL) - free(sc->sc_asens_temp, M_DEVBUF); - if (sc->sc_asens_fan != NULL) - free(sc->sc_asens_fan, M_DEVBUF); - return; - } - - if (!pmf_device_register(self, NULL, NULL)) - aprint_error_dev(self, "could not establish power handler\n"); + if (sysmon_envsys_register(sc->sc_sme) != 0) + aprint_error_dev(self, "failed to register with sysmon\n"); } static void @@ -148,9 +138,11 @@ case ENVSYS_STEMP: name[0] = 'T'; break; + case ENVSYS_SFANRPM: name[0] = 'F'; break; + case ENVSYS_SVOLTS_DC: name[0] = 'V'; break; @@ -194,7 +186,7 @@ goto out; } - as = malloc(sizeof(*as) * n, M_DEVBUF, M_NOWAIT | M_ZERO); + as = kmem_zalloc(sizeof(*as) * n, KM_SLEEP); if (as == NULL) { rv = AE_NO_MEMORY; @@ -205,15 +197,20 @@ case ENVSYS_STEMP: sc->sc_asens_temp = as; + sc->sc_asens_temp_count = n; break; + case ENVSYS_SFANRPM: sc->sc_asens_fan = as; + sc->sc_asens_fan_count = n; break; + case ENVSYS_SVOLTS_DC: sc->sc_asens_volt = as; + sc->sc_asens_volt_count = n; break; + default: - /* NOTREACHED */ return; } @@ -267,16 +264,21 @@ static int aibs_detach(device_t self, int flags) { + static const size_t size = sizeof(struct aibs_sensor); struct aibs_softc *sc = device_private(self); pmf_device_deregister(self); sysmon_envsys_unregister(sc->sc_sme); + if (sc->sc_asens_volt != NULL) - free(sc->sc_asens_volt, M_DEVBUF); + kmem_free(sc->sc_asens_volt, sc->sc_asens_volt_count * size); + if (sc->sc_asens_temp != NULL) - free(sc->sc_asens_temp, M_DEVBUF); + kmem_free(sc->sc_asens_temp, sc->sc_asens_temp_count * size); + if (sc->sc_asens_fan != NULL) - free(sc->sc_asens_fan, M_DEVBUF); + kmem_free(sc->sc_asens_fan, sc->sc_asens_fan_count * size); + return 0; }