]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
soundwire: stream: Revert "soundwire: stream: fix programming slave ports for non...
authorKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Mon, 9 Sep 2024 16:47:46 +0000 (18:47 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 18 Sep 2024 17:24:09 +0000 (19:24 +0200)
commit 233a95fd574fde1c375c486540a90304a2d2d49f upstream.

This reverts commit ab8d66d132bc8f1992d3eb6cab8d32dda6733c84 because it
breaks codecs using non-continuous masks in source and sink ports.  The
commit missed the point that port numbers are not used as indices for
iterating over prop.sink_ports or prop.source_ports.

Soundwire core and existing codecs expect that the array passed as
prop.sink_ports and prop.source_ports is continuous.  The port mask still
might be non-continuous, but that's unrelated.

Reported-by: Bard Liao <yung-chuan.liao@linux.intel.com>
Closes: https://lore.kernel.org/all/b6c75eee-761d-44c8-8413-2a5b34ee2f98@linux.intel.com/
Fixes: ab8d66d132bc ("soundwire: stream: fix programming slave ports for non-continous port maps")
Acked-by: Bard Liao <yung-chuan.liao@linux.intel.com>
Reviewed-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Cc: stable@vger.kernel.org
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Tested-by: Peter Ujfalusi <peter.ujfalusi@linux.intel.com>
Link: https://lore.kernel.org/r/20240909164746.136629-1-krzysztof.kozlowski@linaro.org
Signed-off-by: Vinod Koul <vkoul@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/soundwire/stream.c

index cf69d5c415fbfb1ee35c036ddc1e16363f46e4c4..68d54887992d914aa68ae7657ecf8966a422f4be 100644 (file)
@@ -1286,18 +1286,18 @@ struct sdw_dpn_prop *sdw_get_slave_dpn_prop(struct sdw_slave *slave,
                                            unsigned int port_num)
 {
        struct sdw_dpn_prop *dpn_prop;
-       unsigned long mask;
+       u8 num_ports;
        int i;
 
        if (direction == SDW_DATA_DIR_TX) {
-               mask = slave->prop.source_ports;
+               num_ports = hweight32(slave->prop.source_ports);
                dpn_prop = slave->prop.src_dpn_prop;
        } else {
-               mask = slave->prop.sink_ports;
+               num_ports = hweight32(slave->prop.sink_ports);
                dpn_prop = slave->prop.sink_dpn_prop;
        }
 
-       for_each_set_bit(i, &mask, 32) {
+       for (i = 0; i < num_ports; i++) {
                if (dpn_prop[i].num == port_num)
                        return &dpn_prop[i];
        }