[RFC] Driver configuration using Device Tree
Eric Holmberg
eholmber at codeaurora.org
Wed Jul 10 06:10:58 EST 2013
I am trying to determine if Device Tree is an appropriate use for
configuring drivers and would like to request comments. We currently
use Device Tree in our Shared Memory Driver (SMD) that manages up to 64
ports (where a port consists of an RX FIFO and a TX FIFO) between any
two processors and a pair of interrupts for each processor. The shared
memory address and interrupt configuration is stored in Device Tree and
since this is hardware, this is considered an acceptable use. However,
we also have two separate modules that use SMD and export devices to
userspace through either the TTY framework (SMD TTY) or through a
character device (SMD PKT). For these drivers, the configuration has
less to do with hardware and more about which port to connect to in the
SMD driver and how to expose the port to userspace through a device
node. This code is used in Linux-based phones.
The DT configuration looks like this:
qcom,smdtty {
compatible = "qcom,smdtty";
qcom,smdtty-ds {
qcom,smdtty-port-name = "DS";
qcom,smdtty-edge = <0>;
qcom,smdtty-dev-idx = <0>;
};
. . .
/* on the order of 10 more port config items */
};
Question
--------
Is there a concern that DT should only be used for hardware
configuration and that this "driver configuration" is not an acceptable
use? If it is not acceptable, should I go back to using platform
devices (seems like a step backwards) or some other method such as
exporting a control channel to userspace that can be configured using an
IOCTL?
More Detailed Background Information
------------------------------------
Here’s a diagram showing the modules to help visualize the system.
+-------------------------------+
| |
| SMD Userspace Clients |
| |
+-------------------------------+
User space ^ ^
+-------------------------|--------------|----------------------+
Kernel space + +
+--------------------------+
| Linux Virtual File Sys |
| |
+--------------------------+
^ ^
| |
| +---------------+
| | Linux |
| | TTY Framework |
| +---------------+
| ^
| |
+---------+ | | +---------+
| DT | +-----------+ +-----------+ | DT |
| Config |+---->| SMD | | SMD |<-------+| Config |
| | | PKT | | TTY | | |
+---------+ +-----------+ +-----------+ +---------+
| |
| |
v |
O <------------+
|
+---------+ |
| DT | +------------------------+
| Config |+---->| SMD |
| | | |
+---------+ +------------------------+
| ^ |
| | |
| | |
| | |
| | |
| | |
v | |
+--------------------+ | |Interrupts
| | | |
| Shared Memory | | |
| | | |
+---------+----------+ | |
| | |
| | |
| | |
| | |
| | |
| | |
v | v
+-----------------------------------+
| |
| Remote System (Modem, etc) |
| |
+-----------------------------------+
Here’s an example of our DT schema. Each SMD channel is uniquely
identified in the system by the NAME:EDGE, so this is included in the
configuration along with the index or name of the device node to export
to userspace (either a TTY device for streaming-mode data or a character
device for packet-mode data).
[Root level node]
Required properties:
-compatible: should be "qcom,smdtty"
[Second level nodes]
qcom,smdtty-port-names
Required properties:
-qcom,smdtty-port-name: the name that identifies the smd channel
-qcom,smdtty-edge: the smd edge (this is an enumeration that
identifies the local<->remote processor edge)
-qcom,smdtty-dev-idx: the device node index
Example:
qcom,smdtty {
compatible = "qcom,smdtty";
qcom,smdtty-ds {
qcom,smdtty-port-name = "DS";
qcom,smdtty-edge = <0>;
qcom,smdtty-dev-name = <0>;
};
qcom,smdtty-apps-fm {
qcom,smdtty-port-name = "APPS_FM";
qcom,smdtty-edge = <6>;
qcom,smdtty-dev-name = <1>;
};
qcom,smdtty-gpsnmea {
qcom,smdtty-port-name = "GPSNMEA";
qcom,smdtty-edge = <0>;
qcom,smdtty-dev-name = <27>;
};
};
Thanks,
Eric Holmberg
--
The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum,
hosted by The Linux Foundation.
More information about the devicetree-discuss
mailing list