Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbarm GC toastersensors driver
details: https://anonhg.NetBSD.org/src/rev/141a289af19e
branches: trunk
changeset: 972308:141a289af19e
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sat May 23 13:46:36 2020 +0000
description:
GC toastersensors driver
diffstat:
sys/arch/evbarm/conf/files.tsarm | 6 +-
sys/arch/evbarm/tsarm/toastersensors.c | 280 ---------------------------------
2 files changed, 1 insertions(+), 285 deletions(-)
diffs (truncated from 304 to 300 lines):
diff -r 820da6e56e35 -r 141a289af19e sys/arch/evbarm/conf/files.tsarm
--- a/sys/arch/evbarm/conf/files.tsarm Sat May 23 13:43:34 2020 +0000
+++ b/sys/arch/evbarm/conf/files.tsarm Sat May 23 13:46:36 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.tsarm,v 1.11 2008/03/17 09:30:02 kiyohara Exp $
+# $NetBSD: files.tsarm,v 1.12 2020/05/23 13:46:36 jmcneill Exp $
#
# First try for arm-specific configuration info
#
@@ -37,10 +37,6 @@
attach tskp at tspldbus
file arch/evbarm/tsarm/tskp.c tskp
-device toastersensors: matrixkp, wskbddev
-attach toastersensors at tspldbus
-file arch/evbarm/tsarm/toastersensors.c toastersensors
-
# XXXX pcic here because it needs to be late. The catch: pcic needs
# to be late, so devices which attach to it are attached late. But it
# needs to be before its isa and pci attachments. This answer is
diff -r 820da6e56e35 -r 141a289af19e sys/arch/evbarm/tsarm/toastersensors.c
--- a/sys/arch/evbarm/tsarm/toastersensors.c Sat May 23 13:43:34 2020 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,280 +0,0 @@
-/* $NetBSD: toastersensors.c,v 1.12 2014/02/25 18:30:08 pooka Exp $ */
-
-/*-
- * Copyright (c) 2005 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is from software contributed to The NetBSD Foundation
- * by Jesse Off.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
- * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
- * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- * POSSIBILITY OF SUCH DAMAGE.
- */
-#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: toastersensors.c,v 1.12 2014/02/25 18:30:08 pooka Exp $");
-
-#include <sys/param.h>
-#include <sys/sysctl.h>
-#include <sys/systm.h>
-#include <sys/proc.h>
-#include <sys/poll.h>
-#include <sys/conf.h>
-#include <sys/uio.h>
-#include <sys/types.h>
-#include <sys/kernel.h>
-#include <sys/device.h>
-#include <sys/callout.h>
-#include <sys/select.h>
-
-#include <sys/bus.h>
-#include <machine/autoconf.h>
-
-#include <dev/wscons/wsconsio.h>
-#include <dev/wscons/wskbdvar.h>
-#include <dev/wscons/wsksymdef.h>
-#include <dev/wscons/wsksymvar.h>
-
-#include <arm/ep93xx/ep93xxreg.h>
-#include <arm/ep93xx/epgpioreg.h>
-#include <dev/ic/matrixkpvar.h>
-#include <evbarm/tsarm/tspldvar.h>
-#include <evbarm/tsarm/tsarmreg.h>
-
-struct toastersensors_softc {
- struct matrixkp_softc sc_mxkp;
- bus_space_tag_t sc_iot;
- bus_space_handle_t sc_gpioh;
- bus_space_handle_t sc_adch;
- uint32_t toast_down;
- uint32_t burnlevel_knob;
- uint32_t cancel_key;
- uint32_t toast_key;
- uint32_t frozen_key;
- uint32_t warm_key;
- uint32_t bagel_key;
- uint32_t toast_down_ticks;
- uint32_t cancel_key_ticks;
- uint32_t toast_key_ticks;
- uint32_t frozen_key_ticks;
- uint32_t warm_key_ticks;
- uint32_t bagel_key_ticks;
- struct callout poll;
-};
-
-#define KC(n) KS_KEYCODE(n)
-static const keysym_t mxkp_keydesc_default[] = {
-/* pos normal shifted */
- KC(0), KS_f,
- KC(1), KS_b,
- KC(2), KS_w,
- KC(3), KS_t,
- KC(4), KS_c,
-};
-#undef KC
-#define KBD_MAP(name, base, map) \
- { name, base, sizeof(map)/sizeof(keysym_t), map }
-const struct wscons_keydesc mxkp_keydesctab[] = {
- KBD_MAP(KB_US, 0, mxkp_keydesc_default),
- {0, 0, 0, 0}
-};
-#undef KBD_MAP
-
-struct wskbd_mapdata mxkp_keymapdata = {
- mxkp_keydesctab,
- KB_US,
-};
-
-static int toastersensors_match(device_t, cfdata_t, void *);
-static void toastersensors_attach(device_t, device_t, void *);
-static void toastersensors_scankeys(struct matrixkp_softc *, uint32_t *);
-static void toastersensors_poll(void *);
-
-CFATTACH_DECL_NEW(toastersensors, sizeof(struct toastersensors_softc),
- toastersensors_match, toastersensors_attach, NULL, NULL);
-
-static int
-toastersensors_match(device_t parent, cfdata_t match, void *aux)
-{
- return 1;
-}
-
-#define GPIO_GET(x) bus_space_read_1(sc->sc_iot, sc->sc_gpioh, \
- (EP93XX_GPIO_ ## x))
-
-#define GPIO_SET(x, y) bus_space_write_1(sc->sc_iot, sc->sc_gpioh, \
- (EP93XX_GPIO_ ## x), (y))
-
-#define GPIO_SETBITS(x, y) bus_space_write_1(sc->sc_iot, sc->sc_gpioh, \
- (EP93XX_GPIO_ ## x), GPIO_GET(x) | (y))
-
-#define GPIO_CLEARBITS(x, y) bus_space_write_1(sc->sc_iot, sc->sc_gpioh, \
- (EP93XX_GPIO_ ## x), GPIO_GET(x) & (~(y)))
-
-static void
-toastersensors_poll(void *arg)
-{
- struct toastersensors_softc *sc = arg;
-
- if (sc->cancel_key) sc->cancel_key_ticks++;
- if (sc->toast_key) sc->toast_key_ticks++;
- if (sc->warm_key) sc->warm_key_ticks++;
- if (sc->frozen_key) sc->frozen_key_ticks++;
- if (sc->bagel_key) sc->bagel_key_ticks++;
- if (sc->toast_down) sc->toast_down_ticks++;
-
- sc->burnlevel_knob = bus_space_read_1(sc->sc_iot, sc->sc_adch, 0) |
- (bus_space_read_1(sc->sc_iot, sc->sc_adch, 1) << 8);
- /* Initiate another conversion */
- bus_space_write_1(sc->sc_iot, sc->sc_adch, 0, 0x40);
- callout_schedule(&sc->poll, 1);
-}
-
-static void
-toastersensors_attach(device_t parent, device_t self, void *aux)
-{
- struct toastersensors_softc *sc = device_private(self);
- struct tspld_attach_args *taa = aux;
- struct wskbddev_attach_args wa;
- const struct sysctlnode *node, *datnode;
- uint32_t i;
-
- sc->sc_iot = taa->ta_iot;
- if (bus_space_map(sc->sc_iot, EP93XX_APB_HWBASE + EP93XX_APB_GPIO,
- EP93XX_APB_GPIO_SIZE, 0, &sc->sc_gpioh))
- panic("toastersensors_attach: couldn't map GPIO registers");
-
- if (bus_space_map(sc->sc_iot, TS7XXX_IO8_HWBASE + TS7XXX_MAX197ADC,
- 2, 0, &sc->sc_adch))
- panic("toastersensors_attach: couldn't map MAX197-ADC registers");
-
- sc->sc_mxkp.mxkp_scankeys = toastersensors_scankeys;
- sc->sc_mxkp.mxkp_event = mxkp_wskbd_event;
- sc->sc_mxkp.mxkp_nkeys = 5;
- sc->sc_mxkp.debounce_stable_ms = 3;
- sc->sc_mxkp.sc_dev = self;
- sc->sc_mxkp.poll_freq = hz;
-
- GPIO_CLEARBITS(PBDDR, 0x3f); /* tristate all lines */
-
- aprint_normal(": internal toaster sensor inputs\n");
- aprint_normal_dev(self, "using signal DIO_0 for toast down sensor\n");
- aprint_normal_dev(self, "using signals DIO_1-DIO_5 for panel buttons\n");
- aprint_normal_dev(self, "using 12-bit MAX197-ADC channel 0 for burnlevel knob\n");
-
- if (sysctl_createv(NULL, 0, NULL, &node,
- 0, CTLTYPE_NODE, device_xname(self),
- NULL,
- NULL, 0, NULL, 0,
- CTL_HW, CTL_CREATE, CTL_EOL) != 0) {
- printf("%s: could not create sysctl\n",
- device_xname(self));
- return;
- }
-
-
- if ((i = sysctl_createv(NULL, 0, NULL, &datnode,
- 0, CTLTYPE_INT,
- "burnlevel_knob",
- SYSCTL_DESCR(
- "12-bit analog reading of front-panel potentiometer"),
- NULL, 0, &sc->burnlevel_knob, 0,
- CTL_HW, node->sysctl_num,
- CTL_CREATE, CTL_EOL))
- != 0) {
- printf("%s: could not create sysctl\n",
- device_xname(self));
- return;
- }
-
-#define KEYSYSCTL_SETUP(x) if ((i = sysctl_createv(NULL, 0, NULL, &datnode, \
- 0, CTLTYPE_INT, \
- #x, \
- SYSCTL_DESCR( \
- "toaster user input sensor"), \
- NULL, 0, &sc->x, 0, \
- CTL_HW, node->sysctl_num, \
- CTL_CREATE, CTL_EOL)) \
- != 0) { \
- printf("%s: could not create sysctl\n", \
- device_xname(self)); \
- return; \
- } \
- \
- if ((i = sysctl_createv(NULL, 0, NULL, &datnode, \
- CTLFLAG_READWRITE, CTLTYPE_INT, \
- #x "_ticks", \
- SYSCTL_DESCR( \
- "running total of on-time in ticks"), \
- NULL, 0, &sc->x ## _ticks, 0, \
- CTL_HW, node->sysctl_num, \
- CTL_CREATE, CTL_EOL)) \
- != 0) { \
- printf("%s: could not create sysctl\n", \
- device_xname(self)); \
- return; \
- } \
-
- KEYSYSCTL_SETUP(cancel_key);
- KEYSYSCTL_SETUP(toast_key);
- KEYSYSCTL_SETUP(bagel_key);
- KEYSYSCTL_SETUP(warm_key);
- KEYSYSCTL_SETUP(frozen_key);
- KEYSYSCTL_SETUP(toast_down);
-
- sc->cancel_key_ticks = 0;
- sc->toast_key_ticks = 0;
- sc->frozen_key_ticks = 0;
- sc->warm_key_ticks = 0;
- sc->bagel_key_ticks = 0;
- sc->toast_down_ticks = 0;
-
- mxkp_attach(&sc->sc_mxkp);
- wa.console = 0;
- wa.keymap = &mxkp_keymapdata;
- wa.accessops = &mxkp_accessops;
- wa.accesscookie = &sc->sc_mxkp;
- sc->sc_mxkp.sc_wskbddev = config_found(self, &wa, wskbddevprint);
-
- callout_init(&sc->poll, 0);
- callout_setfunc(&sc->poll, toastersensors_poll, sc);
- callout_schedule(&sc->poll, 1);
-}
-
-static void
-toastersensors_scankeys(struct matrixkp_softc *mxkp_sc, uint32_t *keys)
-{
- struct toastersensors_softc *sc = device_private(mxkp_sc->sc_dev);
- uint32_t val = GPIO_GET(PBDR) & 0x3f;
-
- /*
- * toast_down isn't a key, but we update its state here since its
- * read in the same reg.
- */
- sc->toast_down = (val & 0x1) ? 0 : 1;
-
- *keys = ~(val >> 1);
-
- sc->cancel_key = (*keys & 0x10) ? 1 : 0;
- sc->toast_key = (*keys & 0x8) ? 1 : 0;
Home |
Main Index |
Thread Index |
Old Index