Re: [RESEND PATCH v7 1/2] mmc: OCTEON: Add DT bindings for OCTEON MMC controller

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 14/04/16 13:45, Ulf Hansson wrote:

+ Rob and Ralf

On 31 March 2016 at 17:26, Matt Redfearn <matt.redfearn@xxxxxxxxxx><mailto:matt.redfearn@xxxxxxxxxx> wrote:


From: Aleksey Makarov <aleksey.makarov@xxxxxxxxxxxxxxxxxx><mailto:aleksey.makarov@xxxxxxxxxxxxxxxxxx>

Add Device Tree binding document for Octeon MMC controller. The driver
is in a following patch.

The MMC controller can be connected to up to 4 "slots" which may be
eMMC, MMC or SD card devices. As there is a single controller, each
available slot is represented as a child node of the controller.

This is a similar concept to the atmel-mci driver.

Tested-by: Aaro Koskinen <aaro.koskinen@xxxxxx><mailto:aaro.koskinen@xxxxxx>
Signed-off-by: Chandrakala Chavva <cchavva@xxxxxxxxxxxxxxxxxx><mailto:cchavva@xxxxxxxxxxxxxxxxxx>
Signed-off-by: David Daney <david.daney@xxxxxxxxxx><mailto:david.daney@xxxxxxxxxx>
Signed-off-by: Aleksey Makarov <aleksey.makarov@xxxxxxxxxx><mailto:aleksey.makarov@xxxxxxxxxx>
Signed-off-by: Leonid Rosenboim <lrosenboim@xxxxxxxxxxxxxxxxxx><mailto:lrosenboim@xxxxxxxxxxxxxxxxxx>
Signed-off-by: Peter Swain <pswain@xxxxxxxxxx><mailto:pswain@xxxxxxxxxx>
Signed-off-by: Aaron Williams <aaron.williams@xxxxxxxxxx><mailto:aaron.williams@xxxxxxxxxx>
Signed-off-by: Matt Redfearn <matt.redfearn@xxxxxxxxxx><mailto:matt.redfearn@xxxxxxxxxx>
Acked-by: Rob Herring <robh@xxxxxxxxxx><mailto:robh@xxxxxxxxxx>
---
v7: No changes

v6:
- Split up patch
- Moved device tree fixup to platform code
---
 .../devicetree/bindings/mmc/octeon-mmc.txt         | 79 ++++++++++++++++++++++
 1 file changed, 79 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/mmc/octeon-mmc.txt

diff --git a/Documentation/devicetree/bindings/mmc/octeon-mmc.txt b/Documentation/devicetree/bindings/mmc/octeon-mmc.txt
new file mode 100644
index 000000000000..d2c576d9ad65
--- /dev/null
+++ b/Documentation/devicetree/bindings/mmc/octeon-mmc.txt
@@ -0,0 +1,79 @@
+* OCTEON SD/MMC Host Controller
+
+This controller is present on some members of the Cavium OCTEON SoC
+family, provide an interface for eMMC, MMC and SD devices.  There is a
+single controller that may have several "slots" connected.  These
+slots appear as children of the main controller node.
+The DMA engine is an integral part of the controller block.
+
+1) MMC node
+
+Required properties:
+- compatible : Should be "cavium,octeon-6130-mmc" or "cavium,octeon-7890-mmc"
+- reg : Two entries:
+       1) The base address of the MMC controller register bank.
+       2) The base address of the MMC DMA engine register bank.
+- interrupts :
+       For "cavium,octeon-6130-mmc": two entries:
+       1) The MMC controller interrupt line.
+       2) The MMC DMA engine interrupt line.
+       For "cavium,octeon-7890-mmc": nine entries:
+       1) The next block transfer of a multiblock transfer has completed (BUF_DONE)
+       2) Operation completed successfully (CMD_DONE).
+       3) DMA transfer completed successfully (DMA_DONE).
+       4) Operation encountered an error (CMD_ERR).
+       5) DMA transfer encountered an error (DMA_ERR).
+       6) Switch operation completed successfully (SWITCH_DONE).
+       7) Switch operation encountered an error (SWITCH_ERR).
+       8) Internal DMA engine request completion interrupt (DONE).
+       9) Internal DMA FIFO underflow (FIFO).
+- #address-cells : Must be <1>
+- #size-cells : Must be <0>
+
+The node contains child nodes for each slot that the platform uses.
+
+Example:
+mmc@1180000002000 {
+       compatible = "cavium,octeon-6130-mmc";
+       reg = <0x11800 0x00002000 0x0 0x100>,
+               <0x11800 0x00000168 0x0 0x20>;
+       #address-cells = <1>;
+       #size-cells = <0>;
+       /* EMM irq, DMA irq */
+       interrupts = <1 19>, <0 63>;
+
+       [ child node definitions...]
+};
+
+
+2) Slot nodes
+Properties in mmc.txt apply to each slot node that the platform uses.
+
+Required properties:
+- reg : The slot number.
+
+Optional properties:
+- cavium,cmd-clk-skew : the amount of delay (in pS) past the clock edge
+       to sample the command pin.
+- cavium,dat-clk-skew : the amount of delay (in pS) past the clock edge
+       to sample the data pin.
+
+Example:
+       mmc@1180000002000 {
+               compatible = "cavium,octeon-6130-mmc";
+               reg = <0x11800 0x00002000 0x0 0x100>,
+                     <0x11800 0x00000168 0x0 0x20>;
+               #address-cells = <1>;
+               #size-cells = <0>;
+               /* EMM irq, DMA irq */
+               interrupts = <1 19>, <0 63>;
+
+               mmc-slot@0 {
+                       reg = <0>;


Let me elaborate on how child nodes are being used by the MMC subsystem today.

1)
When a child node has "reg = <0>", the mmc core treat this as being
represented by a non-removable/embedded card.
We have also added a compatible string, "mmc-card", that help us to
deal with constraints for eMMC cards during initialization. You may
have a look at Documentation/devicetree/bindings/mmc/mmc-card.txt to
know more about this.

Additionally, the dynamically created struct device representing the
card, gets its device node pointer assigned to the child node when
"reg = <0>". In that way, the bus/drivers for the card can use it as
well.

2)
When "reg" is non-zero and it's an SDIO card that has been detected,
we treat the child node as representing the embedded SDIO functional
device. The maximum amount of SDIO functional devices that is
supported is dynamic, as it's encoded inside registers of the SDIO
card. The "reg" number needs to be within this range, which allows the
dynamically created struct device for the SDIO func device, to get its
device node assigned to its corresponding child node.

Typically an SDIO function device may be a WLAN chip, which thus is
being attached to an SDIO interface. This is especially needed when
the WLAN driver requires platform specific resources, like some GPIOs
or wake IRQs. An example is available in
arch/arm/boot/dts/sun7i-a20-wits-pro-a20-dkt.dts, where mmc3 use this.



+                       max-frequency = <20000000>;
+                       bus-width = <8>;
+                       vmmc-supply = <&reg_vmmc3>;
+                       cd-gpios = <&gpio 9 0>;
+                       wp-gpios = <&gpio 10 0>;
+               };
+       };
--
2.5.0



So to summarize, the mmc core has a different view of what child nodes
represents than what is being suggested here. I am not sure it's good
idea to add/change that interpretation.

Perhaps it's better to implement the machine specific patching of the
DTS and then remove the "mmc-slot". I think something along those
lines was proposed in one of the earlier versions as well!?

What do you think?

Kind regards
Uffe


Hi Ulf,

Thanks for taking the time to reply and your detailed answer. I see why the bindings currently don't fit into the mmc core model. However, we still have the issue that these bindings are shipping in hardware and we can't change them. As far as I can see, ther major difference between these bindings and what is upstream, is the interpretation of the reg property, and the compatible string of what is connected to the controller. The Octeon MMC controller supports connections to up to 4 devices, either eMMC devices or SD card slots. I think it will be difficult to impossible to programatically interpret the device tree supplied by the bootloader to classify the slots as SD card / eMMC such that the necessary reg / compatible strings can be added.

If we were to remove the slots entirely from the device tree, how would the core deal with having one controller with multiple devices attached? Obviously we need some locking of the shared controller between the child devices.

Thanks,
Matt

--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux