Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/i2c Use the device_compatible_entry mechanism rather...
details: https://anonhg.NetBSD.org/src/rev/c6cebfe1cec7
branches: trunk
changeset: 362640:c6cebfe1cec7
user: thorpej <thorpej%NetBSD.org@localhost>
date: Tue Jun 19 02:08:12 2018 +0000
description:
Use the device_compatible_entry mechanism rather than of_compat_data;
all of the OF / FDT data we need is already in the i2c_attach_args.
diffstat:
sys/dev/i2c/axppmic.c | 39 ++++++++++++++++-----------------------
1 files changed, 16 insertions(+), 23 deletions(-)
diffs (96 lines):
diff -r fa50a74fd10f -r c6cebfe1cec7 sys/dev/i2c/axppmic.c
--- a/sys/dev/i2c/axppmic.c Tue Jun 19 01:24:17 2018 +0000
+++ b/sys/dev/i2c/axppmic.c Tue Jun 19 02:08:12 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: axppmic.c,v 1.11 2018/06/16 21:22:13 thorpej Exp $ */
+/* $NetBSD: axppmic.c,v 1.12 2018/06/19 02:08:12 thorpej 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.11 2018/06/16 21:22:13 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: axppmic.c,v 1.12 2018/06/19 02:08:12 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -264,6 +264,7 @@
i2c_addr_t reg_addr;
};
+static const char *axp803_compatstrings[] = { "x-powers,axp803", NULL };
static const struct axppmic_config axp803_config = {
.name = "AXP803",
.controls = axp803_ctrls,
@@ -282,6 +283,8 @@
.chargestirq = AXPPMIC_IRQ(4, __BITS(1,0)),
};
+static const char *axp805_compatstrings[] = { "x-powers,axp805",
+ "x-powers,axp806", NULL };
static const struct axppmic_config axp805_config = {
.name = "AXP805/806",
.controls = axp805_ctrls,
@@ -290,11 +293,10 @@
.poklirq = AXPPMIC_IRQ(2, __BIT(0)),
};
-static const struct of_compat_data compat_data[] = {
- { "x-powers,axp803", (uintptr_t)&axp803_config },
- { "x-powers,axp805", (uintptr_t)&axp805_config },
- { "x-powers,axp806", (uintptr_t)&axp805_config },
- { NULL }
+static const struct device_compatible_entry axppmic_compat_data[] = {
+ DEVICE_COMPAT_ENTRY_WITH_DATA(axp803_compatstrings, &axp803_config),
+ DEVICE_COMPAT_ENTRY_WITH_DATA(axp805_compatstrings, &axp805_config),
+ DEVICE_COMPAT_TERMINATOR
};
static int
@@ -678,22 +680,10 @@
axppmic_match(device_t parent, cfdata_t match, void *aux)
{
struct i2c_attach_args *ia = aux;
+ int match_result;
- /* XXXJRT Gross. */
- if (ia->ia_name != NULL) {
- if (ia->ia_cookie) {
- int match_result =
- of_match_compat_data(ia->ia_cookie, compat_data);
- if (match_result) {
- match_result = match_result - 1 +
- I2C_MATCH_DIRECT_COMPATIBLE;
- match_result = MIN(match_result,
- I2C_MATCH_DIRECT_COMPATIBLE_MAX);
- }
- return match_result;
- } else
- return 0;
- }
+ if (iic_use_direct_match(ia, match, axppmic_compat_data, &match_result))
+ return match_result;
/* This device is direct-config only. */
@@ -704,6 +694,7 @@
axppmic_attach(device_t parent, device_t self, void *aux)
{
struct axppmic_softc *sc = device_private(self);
+ const struct device_compatible_entry *dce;
const struct axppmic_config *c;
struct axpreg_attach_args aaa;
struct i2c_attach_args *ia = aux;
@@ -711,7 +702,9 @@
uint32_t irq_mask;
void *ih;
- c = (void *)of_search_compatible(ia->ia_cookie, compat_data)->data;
+ dce = iic_compatible_match(ia, axppmic_compat_data, NULL);
+ KASSERT(dce != NULL);
+ c = DEVICE_COMPAT_ENTRY_GET_PTR(dce);
sc->sc_dev = self;
sc->sc_i2c = ia->ia_tag;
Home |
Main Index |
Thread Index |
Old Index