Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/i2c Trigger shutdown on POKLIRQ instead of POKSIRQ.
details: https://anonhg.NetBSD.org/src/rev/eae164c7142d
branches: trunk
changeset: 322689:eae164c7142d
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sat May 12 01:31:07 2018 +0000
description:
Trigger shutdown on POKLIRQ instead of POKSIRQ.
POKSIRQ is triggered if POK remains low for less than IRQLEVEL. This makes
it way too easy to accidentally trigger shutdown. POKLIRQ is triggered if
POK hold time is greater than IRQLEVEL, which is much more reasonable for
this use case.
diffstat:
sys/dev/i2c/axppmic.c | 34 ++++++++++++++++------------------
1 files changed, 16 insertions(+), 18 deletions(-)
diffs (107 lines):
diff -r 5d7e063ca3c8 -r eae164c7142d sys/dev/i2c/axppmic.c
--- a/sys/dev/i2c/axppmic.c Fri May 11 23:05:41 2018 +0000
+++ b/sys/dev/i2c/axppmic.c Sat May 12 01:31:07 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: axppmic.c,v 1.6 2018/05/10 23:57:31 jmcneill Exp $ */
+/* $NetBSD: axppmic.c,v 1.7 2018/05/12 01:31:07 jmcneill Exp $ */
/*-
* Copyright (c) 2014-2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: axppmic.c,v 1.6 2018/05/10 23:57:31 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: axppmic.c,v 1.7 2018/05/12 01:31:07 jmcneill Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -61,8 +61,6 @@
#define AXP_IRQ1_ACIN_LOWER __BIT(5)
#define AXP_IRQ1_VBUS_RAISE __BIT(3)
#define AXP_IRQ1_VBUS_LOWER __BIT(2)
-#define AXP_IRQ2_POKSIRQ __BIT(1)
-#define AXP_IRQ2_
#define AXP_IRQ_STATUS_REG(n) (0x48 + (n) - 1)
#define AXP_FUEL_GAUGE_CTRL_REG 0xb8
@@ -186,8 +184,8 @@
u_int irq_regs;
bool has_battery;
bool has_fuel_gauge;
- u_int poksirq_reg;
- uint8_t poksirq_mask;
+ u_int poklirq_reg;
+ uint8_t poklirq_mask;
};
enum axppmic_sensor {
@@ -208,8 +206,8 @@
bool sc_has_battery;
bool sc_has_fuel_gauge;
- u_int sc_poksirq_reg;
- uint8_t sc_poksirq_mask;
+ u_int sc_poklirq_reg;
+ uint8_t sc_poklirq_mask;
u_int sc_irq_regs;
@@ -244,8 +242,8 @@
.irq_regs = 6,
.has_battery = true,
.has_fuel_gauge = true,
- .poksirq_reg = 5,
- .poksirq_mask = __BIT(4),
+ .poklirq_reg = 5,
+ .poklirq_mask = __BIT(3),
};
static const struct axppmic_config axp805_config = {
@@ -253,8 +251,8 @@
.controls = axp805_ctrls,
.ncontrols = __arraycount(axp805_ctrls),
.irq_regs = 2,
- .poksirq_reg = 2,
- .poksirq_mask = __BIT(1),
+ .poklirq_reg = 2,
+ .poklirq_mask = __BIT(0),
};
static const struct of_compat_data compat_data[] = {
@@ -379,11 +377,11 @@
iic_acquire_bus(sc->sc_i2c, flags);
for (n = 1; n <= sc->sc_irq_regs; n++) {
if (axppmic_read(sc->sc_i2c, sc->sc_addr, AXP_IRQ_STATUS_REG(n), &stat, flags) == 0) {
- if (n == sc->sc_poksirq_reg && (stat & sc->sc_poksirq_mask) != 0)
+ if (n == sc->sc_poklirq_reg && (stat & sc->sc_poklirq_mask) != 0)
sysmon_task_queue_sched(0, axppmic_task_shut, sc);
axppmic_write(sc->sc_i2c, sc->sc_addr,
- AXP_IRQ_STATUS_REG(sc->sc_poksirq_reg), stat, flags);
+ AXP_IRQ_STATUS_REG(sc->sc_poklirq_reg), stat, flags);
}
}
iic_release_bus(sc->sc_i2c, flags);
@@ -582,8 +580,8 @@
sc->sc_has_battery = c->has_battery;
sc->sc_has_fuel_gauge = c->has_fuel_gauge;
sc->sc_irq_regs = c->irq_regs;
- sc->sc_poksirq_reg = c->poksirq_reg;
- sc->sc_poksirq_mask = c->poksirq_mask;
+ sc->sc_poklirq_reg = c->poklirq_reg;
+ sc->sc_poklirq_mask = c->poklirq_mask;
aprint_naive("\n");
aprint_normal(": %s\n", c->name);
@@ -595,8 +593,8 @@
iic_acquire_bus(sc->sc_i2c, I2C_F_POLL);
for (i = 1; i <= c->irq_regs; i++) {
irq_mask = 0;
- if (i == c->poksirq_reg)
- irq_mask |= c->poksirq_mask;
+ if (i == c->poklirq_reg)
+ irq_mask |= c->poklirq_mask;
axppmic_write(sc->sc_i2c, sc->sc_addr, AXP_IRQ_ENABLE_REG(i), irq_mask, I2C_F_POLL);
}
iic_release_bus(sc->sc_i2c, I2C_F_POLL);
Home |
Main Index |
Thread Index |
Old Index