All of lore.kernel.org
 help / color / mirror / Atom feed
* [U-Boot] [PATCH] cros_ec: Honor the google,remote-bus dt property
@ 2016-09-27 22:42 Moritz Fischer
  2016-10-03 21:49 ` [U-Boot] [PATCH] cros_ec: Honor the google, remote-bus " Simon Glass
  2016-10-08 17:08 ` [U-Boot] cros_ec: Honor the google,remote-bus " Tom Rini
  0 siblings, 2 replies; 3+ messages in thread
From: Moritz Fischer @ 2016-09-27 22:42 UTC (permalink / raw)
  To: u-boot

Boards where ECs that use a I2C port != 0 specify this in the
devicetree file via the google,remote-bus property.
Previously this was ignored and hardcoded to port 0.

Signed-off-by: Moritz Fischer <moritz.fischer@ettus.com>
Cc: Simon Glass <sjg@chromium.org>
Cc: Heiko Schocher <hs@denx.de>
Cc: u-boot at lists.denx.de
---
 drivers/i2c/cros_ec_tunnel.c | 24 +++++++++++++++++++++++-
 drivers/misc/cros_ec.c       |  5 +++--
 include/cros_ec.h            |  4 +++-
 3 files changed, 29 insertions(+), 4 deletions(-)

diff --git a/drivers/i2c/cros_ec_tunnel.c b/drivers/i2c/cros_ec_tunnel.c
index e2c6e44..9cf8e7d 100644
--- a/drivers/i2c/cros_ec_tunnel.c
+++ b/drivers/i2c/cros_ec_tunnel.c
@@ -11,6 +11,12 @@
 #include <errno.h>
 #include <i2c.h>
 
+DECLARE_GLOBAL_DATA_PTR;
+
+struct cros_ec_i2c_bus {
+	int remote_bus;
+};
+
 static int cros_ec_i2c_set_bus_speed(struct udevice *dev, unsigned int speed)
 {
 	return 0;
@@ -19,7 +25,21 @@ static int cros_ec_i2c_set_bus_speed(struct udevice *dev, unsigned int speed)
 static int cros_ec_i2c_xfer(struct udevice *dev, struct i2c_msg *msg,
 			    int nmsgs)
 {
-	return cros_ec_i2c_tunnel(dev->parent, msg, nmsgs);
+	struct cros_ec_i2c_bus *i2c_bus = dev_get_priv(dev);
+
+	return cros_ec_i2c_tunnel(dev->parent, i2c_bus->remote_bus, msg, nmsgs);
+}
+
+static int cros_ec_i2c_ofdata_to_platdata(struct udevice *dev)
+{
+	struct cros_ec_i2c_bus *i2c_bus = dev_get_priv(dev);
+	const void *blob = gd->fdt_blob;
+	int node = dev->of_offset;
+
+	i2c_bus->remote_bus = fdtdec_get_uint(blob, node, "google,remote-bus",
+					      0);
+
+	return 0;
 }
 
 static const struct dm_i2c_ops cros_ec_i2c_ops = {
@@ -36,5 +56,7 @@ U_BOOT_DRIVER(cros_ec_tunnel) = {
 	.name	= "cros_ec_tunnel",
 	.id	= UCLASS_I2C,
 	.of_match = cros_ec_i2c_ids,
+	.ofdata_to_platdata = cros_ec_i2c_ofdata_to_platdata,
+	.priv_auto_alloc_size = sizeof(struct cros_ec_i2c_bus),
 	.ops	= &cros_ec_i2c_ops,
 };
diff --git a/drivers/misc/cros_ec.c b/drivers/misc/cros_ec.c
index cb5db0f..37160d8 100644
--- a/drivers/misc/cros_ec.c
+++ b/drivers/misc/cros_ec.c
@@ -1098,7 +1098,8 @@ int cros_ec_decode_ec_flash(const void *blob, int node,
 	return 0;
 }
 
-int cros_ec_i2c_tunnel(struct udevice *dev, struct i2c_msg *in, int nmsgs)
+int cros_ec_i2c_tunnel(struct udevice *dev, int port, struct i2c_msg *in,
+		       int nmsgs)
 {
 	struct cros_ec_dev *cdev = dev_get_uclass_priv(dev);
 	union {
@@ -1118,7 +1119,7 @@ int cros_ec_i2c_tunnel(struct udevice *dev, struct i2c_msg *in, int nmsgs)
 	int rv;
 	int i;
 
-	p->port = 0;
+	p->port = port;
 
 	p->num_msgs = nmsgs;
 	size = sizeof(*p) + p->num_msgs * sizeof(*msg);
diff --git a/include/cros_ec.h b/include/cros_ec.h
index 5fa5f6f..30b1908 100644
--- a/include/cros_ec.h
+++ b/include/cros_ec.h
@@ -395,9 +395,11 @@ struct i2c_msg;
  * Tunnel an I2C transfer to the EC
  *
  * @param dev		CROS-EC device
+ * @param port		The remote port on EC to use
  * @param msg		List of messages to transfer
  * @param nmsgs		Number of messages to transfer
  */
-int cros_ec_i2c_tunnel(struct udevice *dev, struct i2c_msg *msg, int nmsgs);
+int cros_ec_i2c_tunnel(struct udevice *dev, int port, struct i2c_msg *msg,
+		       int nmsgs);
 
 #endif
-- 
2.7.4

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* [U-Boot] [PATCH] cros_ec: Honor the google, remote-bus dt property
  2016-09-27 22:42 [U-Boot] [PATCH] cros_ec: Honor the google,remote-bus dt property Moritz Fischer
@ 2016-10-03 21:49 ` Simon Glass
  2016-10-08 17:08 ` [U-Boot] cros_ec: Honor the google,remote-bus " Tom Rini
  1 sibling, 0 replies; 3+ messages in thread
From: Simon Glass @ 2016-10-03 21:49 UTC (permalink / raw)
  To: u-boot

On 27 September 2016 at 16:42, Moritz Fischer <moritz.fischer@ettus.com> wrote:
> Boards where ECs that use a I2C port != 0 specify this in the
> devicetree file via the google,remote-bus property.
> Previously this was ignored and hardcoded to port 0.
>
> Signed-off-by: Moritz Fischer <moritz.fischer@ettus.com>
> Cc: Simon Glass <sjg@chromium.org>
> Cc: Heiko Schocher <hs@denx.de>
> Cc: u-boot at lists.denx.de
>
> ---
>  drivers/i2c/cros_ec_tunnel.c | 24 +++++++++++++++++++++++-
>  drivers/misc/cros_ec.c       |  5 +++--
>  include/cros_ec.h            |  4 +++-
>  3 files changed, 29 insertions(+), 4 deletions(-)

Acked-by: Simon Glass <sjg@chromium.org>

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [U-Boot] cros_ec: Honor the google,remote-bus dt property
  2016-09-27 22:42 [U-Boot] [PATCH] cros_ec: Honor the google,remote-bus dt property Moritz Fischer
  2016-10-03 21:49 ` [U-Boot] [PATCH] cros_ec: Honor the google, remote-bus " Simon Glass
@ 2016-10-08 17:08 ` Tom Rini
  1 sibling, 0 replies; 3+ messages in thread
From: Tom Rini @ 2016-10-08 17:08 UTC (permalink / raw)
  To: u-boot

On Tue, Sep 27, 2016 at 03:42:07PM -0700, Moritz Fischer wrote:

> Boards where ECs that use a I2C port != 0 specify this in the
> devicetree file via the google,remote-bus property.
> Previously this was ignored and hardcoded to port 0.
> 
> Signed-off-by: Moritz Fischer <moritz.fischer@ettus.com>
> Cc: Simon Glass <sjg@chromium.org>
> Cc: Heiko Schocher <hs@denx.de>
> Cc: u-boot at lists.denx.de
> Acked-by: Simon Glass <sjg@chromium.org>

Applied to u-boot/master, thanks!

-- 
Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: Digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20161008/1371fd67/attachment.sig>

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2016-10-08 17:08 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-09-27 22:42 [U-Boot] [PATCH] cros_ec: Honor the google,remote-bus dt property Moritz Fischer
2016-10-03 21:49 ` [U-Boot] [PATCH] cros_ec: Honor the google, remote-bus " Simon Glass
2016-10-08 17:08 ` [U-Boot] cros_ec: Honor the google,remote-bus " Tom Rini

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.