Point-to-point bus in device tree

From: David Brown
Date: Thu Apr 05 2012 - 14:15:53 EST


Some MSM SoCs have a small serial-type "bus" that is used to
communicate with the PMIC devices. This interface is always
point-to-point. I'm doing a device-tree conversion of the driver that
Ken Heitke posted last year <https://lkml.org/lkml/2011/2/17/503>.

A naive conversion to device tree, would result in something like
this:

qcom,ssbi@500000 {
compatible = "qcom,ssbi";
reg = <0x500000 0x1000>;
qcom,controller-type = "ssbi";

qcom,pmic8058@0 {
reg = <0x0 0x01>;
...
}
}

There would end up being an extraneous register for the device on the
other end (there are no addresses), and there would need to be code in
the ssbi driver to traverse this small tree to find these nodes.

Another approach would be to make the pmic driver the actual device,
and just have it use the ssbi code as a library. Something like:

qcom,pmic8058@500000 {
compatible = "qcom,pmic8058";
reg = <0x500000 0x1000>;
qcom,ssbi-type = "ssbi";
...
}

This is a lot cleaner, takes less code, but doesn't technically
represent how the hardware is really structured.

Does anyone have strong (or weak) feelings about this?

Thanks,
David

--
Sent by an employee of the Qualcomm Innovation Center, Inc.
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/