Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbarm Imported pwrbtn and lidsw drivers for NetWal...
details: https://anonhg.NetBSD.org/src/rev/f314566bd0c8
branches: trunk
changeset: 795857:f314566bd0c8
user: hkenken <hkenken%NetBSD.org@localhost>
date: Tue May 06 11:08:51 2014 +0000
description:
Imported pwrbtn and lidsw drivers for NetWalker. Those attached to GPIO bus.
+ power button
+ lid close switch
diffstat:
sys/arch/evbarm/conf/NETWALKER | 21 ++-
sys/arch/evbarm/conf/files.netwalker | 16 ++-
sys/arch/evbarm/netwalker/netwalker.h | 7 +-
sys/arch/evbarm/netwalker/netwalker_btn.c | 8 +-
sys/arch/evbarm/netwalker/netwalker_lid.c | 181 +++++++++++++++++++++++++++++
sys/arch/evbarm/netwalker/netwalker_pwr.c | 183 ++++++++++++++++++++++++++++++
6 files changed, 405 insertions(+), 11 deletions(-)
diffs (truncated from 500 to 300 lines):
diff -r 97ace92037d1 -r f314566bd0c8 sys/arch/evbarm/conf/NETWALKER
--- a/sys/arch/evbarm/conf/NETWALKER Tue May 06 10:16:52 2014 +0000
+++ b/sys/arch/evbarm/conf/NETWALKER Tue May 06 11:08:51 2014 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: NETWALKER,v 1.25 2014/03/29 12:00:27 hkenken Exp $
+# $NetBSD: NETWALKER,v 1.26 2014/05/06 11:08:51 hkenken Exp $
#
# NETWALKER -- http://www.sharp.co.jp/netwalker/
#
@@ -149,6 +149,17 @@
#options SCSIPI_DEBUG_TARGET=0
#options SCSIPI_DEBUG_LUN=0
+# Valid options for BOOT_ARGS:
+# single Boot to single user only
+# kdb Give control to kernel debugger
+# ask Ask for file name to reboot from
+# pmapdebug=<n> If PMAP_DEBUG, set pmap_debug_level to <n>
+# memorydisk=<n> Set memorydisk size to <n> KB
+# quiet Show aprint_naive output
+# verbose Show aprint_normal and aprint_verbose output
+#options BOOT_ARGS="\"verbose\""
+#options BOOT_ARGS="\"pmapdebug=1\""
+
# Kernel root file system and dump configuration.
config netbsd root on ? type ?
config netbsd-ld0 root on ld0 type ffs
@@ -214,14 +225,18 @@
#options IMXSPI_DEBUG=10
# Optical Joystick
-mousebtn0 at gpio1 offset 22 mask 0x03 # intr 182, 183
-#options MOUSEBTN_POLLING
oj6sh0 at spi0 slave 2
#options OJ6SH_DEBUG=4
options OJ6SH_UP_X_LEFT_Y
wsmouse* at oj6sh? mux 0
+
+mousebtn0 at gpio1 offset 22 mask 0x03 # intr 182, 183
+#options MOUSEBTN_POLLING
wsmouse* at mousebtn? mux 0
+pwrbtn0 at gpio1 offset 21 mask 0x01 # intr 181
+lidsw0 at gpio3 offset 12 mask 0x01 # intr 236
+
# SPI NOR-Flash
#spiflash0 at spiflashbus?
#m25p0 at spi0 slave 1
diff -r 97ace92037d1 -r f314566bd0c8 sys/arch/evbarm/conf/files.netwalker
--- a/sys/arch/evbarm/conf/files.netwalker Tue May 06 10:16:52 2014 +0000
+++ b/sys/arch/evbarm/conf/files.netwalker Tue May 06 11:08:51 2014 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.netwalker,v 1.5 2014/03/29 12:00:27 hkenken Exp $
+# $NetBSD: files.netwalker,v 1.6 2014/05/06 11:08:51 hkenken Exp $
#
# Sharp Netwalker configuration info
#
@@ -30,10 +30,20 @@
# Mouse button
device mousebtn: wsmousedev
-attach mousebtn at gpio with btn_netwalker
-file arch/evbarm/netwalker/netwalker_btn.c btn_netwalker
+attach mousebtn at gpio with netwalker_btn
+file arch/evbarm/netwalker/netwalker_btn.c netwalker_btn
defflag opt_mousebtn.h MOUSEBTN_POLLING
+# Power button
+device pwrbtn: sysmon_envsys
+attach pwrbtn at gpio with netwalker_pwr
+file arch/evbarm/netwalker/netwalker_pwr.c netwalker_pwr
+
+# Lid close switch
+device lidsw: sysmon_envsys
+attach lidsw at gpio with netwalker_lid
+file arch/evbarm/netwalker/netwalker_lid.c netwalker_lid
+
# OJ6SH-T25 Optical Joystick
device oj6sh: wsmousedev
attach oj6sh at spi
diff -r 97ace92037d1 -r f314566bd0c8 sys/arch/evbarm/netwalker/netwalker.h
--- a/sys/arch/evbarm/netwalker/netwalker.h Tue May 06 10:16:52 2014 +0000
+++ b/sys/arch/evbarm/netwalker/netwalker.h Tue May 06 11:08:51 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netwalker.h,v 1.1 2014/04/09 04:00:50 hkenken Exp $ */
+/* $NetBSD: netwalker.h,v 1.2 2014/05/06 11:08:51 hkenken Exp $ */
/*
* Copyright (c) 2014 Genetec Corporation. All rights reserved.
@@ -35,4 +35,9 @@
#define KERNEL_VM_BASE 0xc0000000
#define KERNEL_VM_SIZE 0x20000000
+#define GPIO0_IRQBASE 128
+#define GPIO1_IRQBASE 160
+#define GPIO2_IRQBASE 192
+#define GPIO3_IRQBASE 224
+
#endif /* _EVBARM_NETWALKER_NETWALKER_H */
diff -r 97ace92037d1 -r f314566bd0c8 sys/arch/evbarm/netwalker/netwalker_btn.c
--- a/sys/arch/evbarm/netwalker/netwalker_btn.c Tue May 06 10:16:52 2014 +0000
+++ b/sys/arch/evbarm/netwalker/netwalker_btn.c Tue May 06 11:08:51 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netwalker_btn.c,v 1.1 2014/03/29 12:00:27 hkenken Exp $ */
+/* $NetBSD: netwalker_btn.c,v 1.2 2014/05/06 11:08:51 hkenken Exp $ */
/*
* Copyright (c) 2014 Genetec Corporation. All rights reserved.
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: netwalker_btn.c,v 1.1 2014/03/29 12:00:27 hkenken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: netwalker_btn.c,v 1.2 2014/05/06 11:08:51 hkenken Exp $");
#include "opt_imxspi.h"
#include "opt_mousebtn.h"
@@ -77,8 +77,8 @@
static void mousebtn_attach(device_t, device_t, void *);
static int mousebtn_detach(device_t, int);
-CFATTACH_DECL_NEW(btn_netwalker, sizeof(struct mousebtn_softc),
- mousebtn_match, mousebtn_attach, mousebtn_detach, NULL);
+CFATTACH_DECL_NEW(netwalker_btn, sizeof(struct mousebtn_softc),
+ mousebtn_match, mousebtn_attach, mousebtn_detach, NULL);
static void mousebtn_poll(void *);
static int mousebtn_intr(void *);
diff -r 97ace92037d1 -r f314566bd0c8 sys/arch/evbarm/netwalker/netwalker_lid.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/evbarm/netwalker/netwalker_lid.c Tue May 06 11:08:51 2014 +0000
@@ -0,0 +1,181 @@
+/* $NetBSD: netwalker_lid.c,v 1.1 2014/05/06 11:08:51 hkenken Exp $ */
+
+/*
+ * Copyright (c) 2014 Genetec Corporation. All rights reserved.
+ * Written by Hashimoto Kenichi for Genetec Corporation.
+ *
+ * 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 GENETEC CORPORATION ``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 GENETEC CORPORATION
+ * 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: netwalker_lid.c,v 1.1 2014/05/06 11:08:51 hkenken Exp $");
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/device.h>
+#include <sys/gpio.h>
+
+#include <dev/gpio/gpiovar.h>
+#include <dev/sysmon/sysmonvar.h>
+#include <dev/sysmon/sysmon_taskq.h>
+
+#include <dev/gpio/gpiovar.h>
+
+#include <evbarm/netwalker/netwalker.h>
+
+#define LID_PIN_INPUT 0
+#define LID_NPINS 1
+
+struct netwalker_lid_softc {
+ device_t sc_dev;
+ void *sc_gpio;
+ void *sc_intr;
+
+ struct gpio_pinmap sc_map;
+ int sc_map_pins[LID_NPINS];
+
+ struct sysmon_pswitch sc_smpsw;
+ int sc_state;
+};
+
+static int netwalker_lid_match(device_t, cfdata_t, void *);
+static void netwalker_lid_attach(device_t, device_t, void *);
+static int netwalker_lid_detach(device_t, int);
+
+CFATTACH_DECL_NEW(netwalker_lid, sizeof(struct netwalker_lid_softc),
+ netwalker_lid_match, netwalker_lid_attach, netwalker_lid_detach, NULL);
+
+static void netwalker_lid_refresh(void *);
+static int netwalker_lid_intr(void *);
+
+
+static int
+netwalker_lid_match(device_t parent, cfdata_t cf, void * aux)
+{
+ struct gpio_attach_args *ga = aux;
+
+ if (strcmp(ga->ga_dvname, cf->cf_name))
+ return 0;
+ if (ga->ga_offset == -1)
+ return 0;
+ /* check that we have enough pins */
+ if (gpio_npins(ga->ga_mask) != LID_NPINS) {
+ aprint_debug("%s: invalid pin mask 0x%02x\n", cf->cf_name,
+ ga->ga_mask);
+ return 0;
+ }
+
+ return 1;
+}
+
+static void
+netwalker_lid_attach(device_t parent, device_t self, void *aux)
+{
+ struct netwalker_lid_softc *sc = device_private(self);
+ struct gpio_attach_args *ga = aux;
+ int caps;
+
+ sc->sc_dev = self;
+ sc->sc_gpio = ga->ga_gpio;
+
+ /* map pins */
+ sc->sc_map.pm_map = sc->sc_map_pins;
+ if (gpio_pin_map(sc->sc_gpio, ga->ga_offset, ga->ga_mask, &sc->sc_map)) {
+ aprint_error(": couldn't map the pins\n");
+ return;
+ }
+
+ /* configure the input pin */
+ caps = gpio_pin_caps(sc->sc_gpio, &sc->sc_map, LID_PIN_INPUT);
+ if (!(caps & GPIO_PIN_INPUT)) {
+ aprint_error(": pin is unable to read input\n");
+ gpio_pin_unmap(sc->sc_gpio, &sc->sc_map);
+ return;
+ }
+ gpio_pin_ctl(sc->sc_gpio, &sc->sc_map, LID_PIN_INPUT,
+ GPIO_PIN_INPUT);
+
+ sc->sc_intr = intr_establish(GPIO3_IRQBASE + ga->ga_offset,
+ IPL_VM, IST_EDGE_BOTH, netwalker_lid_intr, sc);
+ if (sc->sc_intr == NULL) {
+ aprint_error(": couldn't establish interrupt\n");
+ gpio_pin_unmap(sc->sc_gpio, &sc->sc_map);
+ return;
+ }
+
+ aprint_normal(": NETWALKER lid switch\n");
+ aprint_naive(": NETWALKER lid switch\n");
+
+ if (!pmf_device_register(sc->sc_dev, NULL, NULL)) {
+ aprint_error_dev(sc->sc_dev,
+ "couldn't establish lid handler\n");
+ }
+
+ sysmon_task_queue_init();
+ sc->sc_smpsw.smpsw_name = device_xname(self);
+ sc->sc_smpsw.smpsw_type = PSWITCH_TYPE_LID;
+ sc->sc_state = PSWITCH_EVENT_RELEASED;
+ sysmon_pswitch_register(&sc->sc_smpsw);
+}
+
+static int
+netwalker_lid_detach(device_t self, int flags)
+{
+ struct netwalker_lid_softc *sc = device_private(self);
+
+ if (sc->sc_intr != NULL)
+ intr_disestablish(sc->sc_intr);
+
+ gpio_pin_unmap(sc->sc_gpio, &sc->sc_map);
+ pmf_device_deregister(self);
+ sysmon_task_queue_fini();
+ return 0;
+}
+
+static int
+netwalker_lid_intr(void *v)
+{
+ struct netwalker_lid_softc *sc = v;
+
+ sysmon_task_queue_sched(0, netwalker_lid_refresh, sc);
+ return 1;
+}
+
+static void
+netwalker_lid_refresh(void *v)
+{
+ struct netwalker_lid_softc *sc = v;
+ int lid;
+ int event;
Home |
Main Index |
Thread Index |
Old Index