ASoC: fsl_sai: Make Synchronous and Asynchronous modes exclusive
authorNicolin Chen <nicoleotsuka@gmail.com>
Fri, 8 Aug 2014 10:41:19 +0000 (18:41 +0800)
committerMark Brown <broonie@linaro.org>
Sat, 16 Aug 2014 22:06:23 +0000 (17:06 -0500)
The previous patch (ASoC: fsl_sai: Add asynchronous mode support) added
new Device Tree bindings for Asynchronous and Synchronous modes support.
However, these two shall not be present at the same time.

So this patch just simply makes them exclusive so as to avoid incorrect
Device Tree binding usage.

Signed-off-by: Nicolin Chen <nicoleotsuka@gmail.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
Documentation/devicetree/bindings/sound/fsl-sai.txt
sound/soc/fsl/fsl_sai.c

index 77864f4dd352baf5af7e6591cdc9130a5d92ecfc..dc9f9c356268a5635b6902aaa2e748b8746eda43 100644 (file)
@@ -38,8 +38,7 @@ Note:
   default synchronous mode (sync Rx with Tx) will be used, which means both
   transimitter and receiver will send and receive data by following clocks
   of transimitter.
-- fsl,sai-asynchronous will be ignored if fsl,sai-synchronous-rx property is
-  already present.
+- fsl,sai-asynchronous and fsl,sai-synchronous-rx are exclusive.
 
 Example:
 sai2: sai@40031000 {
index ef7c758627b1e2dc4c6532a6877a586bbedec20e..4c9e71c2f52ac801c0ee2e45921b2d9d2cd5aad0 100644 (file)
@@ -634,6 +634,13 @@ static int fsl_sai_probe(struct platform_device *pdev)
        fsl_sai_dai.symmetric_channels = 1;
        fsl_sai_dai.symmetric_samplebits = 1;
 
+       if (of_find_property(np, "fsl,sai-synchronous-rx", NULL) &&
+           of_find_property(np, "fsl,sai-asynchronous", NULL)) {
+               /* error out if both synchronous and asynchronous are present */
+               dev_err(&pdev->dev, "invalid binding for synchronous mode\n");
+               return -EINVAL;
+       }
+
        if (of_find_property(np, "fsl,sai-synchronous-rx", NULL)) {
                /* Sync Rx with Tx */
                sai->synchronous[RX] = false;