Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/macppc/dev if we have more than one i2c-bus node, l...
details: https://anonhg.NetBSD.org/src/rev/9d28a6b510e0
branches: trunk
changeset: 1006313:9d28a6b510e0
user: macallan <macallan%NetBSD.org@localhost>
date: Thu Jan 09 18:47:46 2020 +0000
description:
if we have more than one i2c-bus node, look for children on both
now we find the light sensor in my shiny new toy
diffstat:
sys/arch/macppc/dev/ki2c.c | 91 ++++++++++++++++++++++++---------------------
1 files changed, 48 insertions(+), 43 deletions(-)
diffs (131 lines):
diff -r f6759b71661d -r 9d28a6b510e0 sys/arch/macppc/dev/ki2c.c
--- a/sys/arch/macppc/dev/ki2c.c Thu Jan 09 17:06:46 2020 +0000
+++ b/sys/arch/macppc/dev/ki2c.c Thu Jan 09 18:47:46 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ki2c.c,v 1.27 2019/12/22 23:23:30 thorpej Exp $ */
+/* $NetBSD: ki2c.c,v 1.28 2020/01/09 18:47:46 macallan Exp $ */
/* Id: ki2c.c,v 1.7 2002/10/05 09:56:05 tsubai Exp */
/*-
@@ -83,7 +83,7 @@
struct confargs *ca = aux;
int node = ca->ca_node;
uint32_t addr, channel, reg;
- int rate, child, /*namelen,*/ i2cbus;
+ int rate, child, /*namelen,*/ i2cbus[2] = {0, 0};
struct i2cbus_attach_args iba;
prop_dictionary_t dict = device_properties(self);
prop_array_t cfg;
@@ -138,59 +138,63 @@
* XXX
* should probably check for multiple i2c-bus children
*/
- i2cbus = 0;
+
+ int found_busnode = 0;
channel = 0;
child = OF_child(node);
- while ((child != 0) && (i2cbus == 0)) {
+ while (child != 0) {
OF_getprop(child, "name", name, sizeof(name));
if (strcmp(name, "i2c-bus") == 0) {
OF_getprop(child, "reg", &channel, sizeof(channel));
- i2cbus = child;
+ i2cbus[channel] = child;
DPRINTF("found channel %x\n", channel);
+ found_busnode = 1;
}
child = OF_peer(child);
}
- if (i2cbus == 0)
- i2cbus = node;
+ if (found_busnode == 0)
+ i2cbus[0] = node;
- devs = OF_child(i2cbus);
- while (devs != 0) {
- if (OF_getprop(devs, "name", name, 32) <= 0)
- goto skip;
- if (OF_getprop(devs, "compatible", compat, 256) <= 0) {
- /* some i2c device nodes don't have 'compatible' */
- memset(compat, 0, 256);
- strncpy(compat, name, 256);
- }
- if (OF_getprop(devs, "reg", &addr, 4) <= 0)
- if (OF_getprop(devs, "i2c-address", &addr, 4) <= 0)
+ for (channel = 0; channel < 2; channel++) {
+ devs = OF_child(i2cbus[channel]);
+ while (devs != 0) {
+ if (OF_getprop(devs, "name", name, 32) <= 0)
goto skip;
- addr |= channel << 8;
- addr = addr >> 1;
- DPRINTF("-> %s@%x\n", name, addr);
- dev = prop_dictionary_create();
- prop_dictionary_set_cstring(dev, "name", name);
- data = prop_data_create_data(compat, strlen(compat)+1);
- prop_dictionary_set(dev, "compatible", data);
- prop_object_release(data);
- prop_dictionary_set_uint32(dev, "addr", addr);
- prop_dictionary_set_uint64(dev, "cookie", devs);
- /* look for location info for sensors */
- devc = OF_child(devs);
- while (devc != 0) {
- if (OF_getprop(devc, "reg", ®, 4) < 4) goto nope;
- if (OF_getprop(devc, "location", descr, 32) <= 0)
- goto nope;
- DPRINTF("found '%s' at %02x\n", descr, reg);
- snprintf(num, 7, "s%02x", reg);
- prop_dictionary_set_cstring(dev, num, descr);
- nope:
- devc = OF_peer(devc);
+ if (OF_getprop(devs, "compatible", compat, 256) <= 0) {
+ /* some i2c device nodes don't have 'compatible' */
+ memset(compat, 0, 256);
+ strncpy(compat, name, 256);
+ }
+ if (OF_getprop(devs, "reg", &addr, 4) <= 0)
+ if (OF_getprop(devs, "i2c-address", &addr, 4) <= 0)
+ goto skip;
+ addr |= channel << 8;
+ addr = addr >> 1;
+ DPRINTF("-> %s@%x\n", name, addr);
+ dev = prop_dictionary_create();
+ prop_dictionary_set_cstring(dev, "name", name);
+ data = prop_data_create_data(compat, strlen(compat)+1);
+ prop_dictionary_set(dev, "compatible", data);
+ prop_object_release(data);
+ prop_dictionary_set_uint32(dev, "addr", addr);
+ prop_dictionary_set_uint64(dev, "cookie", devs);
+ /* look for location info for sensors */
+ devc = OF_child(devs);
+ while (devc != 0) {
+ if (OF_getprop(devc, "reg", ®, 4) < 4) goto nope;
+ if (OF_getprop(devc, "location", descr, 32) <= 0)
+ goto nope;
+ DPRINTF("found '%s' at %02x\n", descr, reg);
+ snprintf(num, 7, "s%02x", reg);
+ prop_dictionary_set_cstring(dev, num, descr);
+ nope:
+ devc = OF_peer(devc);
+ }
+ prop_array_add(cfg, dev);
+ prop_object_release(dev);
+ skip:
+ devs = OF_peer(devs);
}
- prop_array_add(cfg, dev);
- prop_object_release(dev);
- skip:
- devs = OF_peer(devs);
}
/* fill in the i2c tag */
@@ -405,6 +409,7 @@
/* we handle the subaddress stuff ourselves */
ki2c_setmode(sc, channel | I2C_STDMODE);
+ ki2c_setspeed(sc, I2C_50kHz);
/* Write-buffer defaults to vcmd */
wp = (uint8_t *)(__UNCONST(vcmd));
Home |
Main Index |
Thread Index |
Old Index