[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <D10E1092-E75F-48F7-86F1-F8987973CEB5@goldelico.com>
Date: Wed, 6 May 2015 14:27:03 +0200
From: "Dr. H. Nikolaus Schaller" <hns@...delico.com>
To: Peter Hurley <peter@...leysoftware.com>
Cc: Pavel Machek <pavel@....cz>,
List for communicating with real GTA04 owners
<gta04-owner@...delico.com>, NeilBrown <neil@...wn.name>,
Mark Rutland <mark.rutland@....com>,
One Thousand Gnomes <gnomes@...rguk.ukuu.org.uk>,
Arnd Bergmann <arnd@...db.de>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Sebastian Reichel <sre@...nel.org>,
Grant Likely <grant.likely@...aro.org>,
Jiri Slaby <jslaby@...e.cz>, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [Gta04-owner] [PATCH 0/3] tty slave device support - version 3.
Hi Peter,
Am 06.05.2015 um 14:05 schrieb Peter Hurley <peter@...leysoftware.com>:
> On 05/06/2015 07:50 AM, Dr. H. Nikolaus Schaller wrote:
>> No, I am not playing devil’s advocate (which would imply that I am doing this
>> for fun to tease the dog), but I feel I have to be the advocate of future board
>> designers who want to easily import an existing board DT and overwrite device
>> tree nodes to describe design changes, i.e. what slave device is connected to
>> which uart.
>
> I dont' see a big distinction at the DTS source level, so your concern is wrt
> binary dtbs?
No. My concern is wrt including existing board files and making small modifications
on source level (or overlays).
We discuss:
board1.dts:
uart3 { // subnode of some SoC
slave { // slave connected to uart3
compatible = „…“;
gpio = <&gpio5 12 0>
};
};
vs.
board1.dts:
/ {
slave {
compatible = „…“;
gpio = <&gpio5 12 0>
uart = &uart3; // slave connected to uart3
};
};
uart3 { // subnode of some SoC
};
now let’s have a spin of the board design which just rewires the
slave to uart4 (somtimes hardware engineers do such things).
board2.dts:
#include <board-variant1.dts>
// reconnect device to uart4
uart4 { // subnode of some SoC
slave { // slave connected to uart4
compatible = „…“;
gpio = <&gpio5 12 0>
};
};
uart3 { // subnode of some SoC
slave { // slave connected to uart3
compatible = „none“ // we can’t delete imported subnodes
};
};
/// add another device to uart5?
uart5 { // subnode of some SoC
slave2 { // slave connected to uart5
compatible = „…“;
gpio = <&gpio5 13 0>
};
};
vs.
board2.dts:
#include <board-variant1.dts>
// reconnect device to uart4
&slave {
uart = &uart3;
};
// add another device to uart5?
slave2 {
compatible = „…“;
gpio = <&gpio5 13 0>
uart = &uart5;
};
So the main difference is if the slave device tells to which uart it is connected
or the uart which slave device it is connected to.
And I think the second approach is easier and more straightforward (on DT level).
>
>> At least in this regard, the alternatives are really differently easy to handle.
>>
>> And, the alternatives have some influence how a tty driver and a slave device
>> driver is designed. So that is for me the root question, before discussing (some)
>> implementation details.
>
> I would expect _no_ impact on the tty driver; have I overlooked something?
The way a tty driver finds the slave or the slave finds the tty driver instance.
In my proposal, the slave device has to look up the uart instance it is connected
to and must register itself as a power management client to get notifications. It
can also receive other notifications or change the line discipline to its needs.
In Neil’s original proposal the tty driver simply imposes some special power
management methods (control gpio or a regulator) over the slave driver which
does not encapsulate it’s power management methods.
BR,
Nikolaus--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists