soundwire: bandwidth allocation: improve error messages
authorPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Tue, 11 May 2021 05:49:45 +0000 (13:49 +0800)
committerVinod Koul <vkoul@kernel.org>
Tue, 11 May 2021 12:04:07 +0000 (17:34 +0530)
In rare corner cases, we see an error with the log:

[  838.297840] soundwire sdw-master-1: Compute bus params failed: -22

That's not very useful, there can be two different error conditions
with the same -EINVAL code provided to the caller.

Let's add better dev_err() messages to figure out what went wrong.

Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: Guennadi Liakhovetski <guennadi.liakhovetski@linux.intel.com>
Signed-off-by: Bard Liao <yung-chuan.liao@linux.intel.com>
Link: https://lore.kernel.org/r/20210511054945.29558-1-yung-chuan.liao@linux.intel.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/soundwire/generic_bandwidth_allocation.c

index 84d1295..f7c6608 100644 (file)
@@ -382,12 +382,18 @@ static int sdw_compute_bus_params(struct sdw_bus *bus)
                 */
        }
 
-       if (i == clk_values)
+       if (i == clk_values) {
+               dev_err(bus->dev, "%s: could not find clock value for bandwidth %d\n",
+                       __func__, bus->params.bandwidth);
                return -EINVAL;
+       }
 
        ret = sdw_select_row_col(bus, curr_dr_freq);
-       if (ret < 0)
+       if (ret < 0) {
+               dev_err(bus->dev, "%s: could not find frame configuration for bus dr_freq %d\n",
+                       __func__, curr_dr_freq);
                return -EINVAL;
+       }
 
        bus->params.curr_dr_freq = curr_dr_freq;
        return 0;
@@ -404,10 +410,8 @@ int sdw_compute_params(struct sdw_bus *bus)
 
        /* Computes clock frequency, frame shape and frame frequency */
        ret = sdw_compute_bus_params(bus);
-       if (ret < 0) {
-               dev_err(bus->dev, "Compute bus params failed: %d\n", ret);
+       if (ret < 0)
                return ret;
-       }
 
        /* Compute transport and port params */
        ret = sdw_compute_port_params(bus);