]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
thunderbolt: debugfs: Don't hardcode margining results size
authorAapo Vienamo <aapo.vienamo@iki.fi>
Thu, 15 Aug 2024 18:45:19 +0000 (21:45 +0300)
committerMika Westerberg <mika.westerberg@linux.intel.com>
Fri, 1 Nov 2024 05:55:38 +0000 (07:55 +0200)
Use ARRAY_SIZE() when available or pass in the array size derived from
it. This is in preparation for adding another result data word for
supporting Gen 4 asymmetric links with an additional lane.

Signed-off-by: Aapo Vienamo <aapo.vienamo@iki.fi>
Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
drivers/thunderbolt/debugfs.c
drivers/thunderbolt/tb.h
drivers/thunderbolt/usb4.c

index 2f9756c201b6fc2fcd6f457eba9670ca55e9d96d..9899d88b73711ca99c47c49c0e5d178f2cd04b5e 100644 (file)
@@ -1191,7 +1191,7 @@ static int margining_run_write(void *data, u64 val)
                            margining->lanes);
 
                ret = usb4_port_hw_margin(port, margining->target, margining->index, &params,
-                                         margining->results);
+                                         margining->results, ARRAY_SIZE(margining->results));
        }
 
        if (down_sw)
@@ -1219,8 +1219,7 @@ static ssize_t margining_results_write(struct file *file,
                return -ERESTARTSYS;
 
        /* Just clear the results */
-       margining->results[0] = 0;
-       margining->results[1] = 0;
+       memset(margining->results, 0, sizeof(margining->results));
 
        if (margining->software) {
                /* Clear the error counters */
@@ -1312,7 +1311,8 @@ static int margining_results_show(struct seq_file *s, void *not_used)
        seq_printf(s, "0x%08x\n", margining->results[0]);
        /* Only the hardware margining has two result dwords */
        if (!margining->software) {
-               seq_printf(s, "0x%08x\n", margining->results[1]);
+               for (int i = 1; i < ARRAY_SIZE(margining->results); i++)
+                       seq_printf(s, "0x%08x\n", margining->results[i]);
 
                if (margining->lanes == USB4_MARGINING_LANE_ALL) {
                        margining_hw_result_format(s, margining,
index fb2e1f089169f9b4346f401d0f953eb0009af57f..0954b8bafadaf6e93ae0c5c24a0f856edd0c02ff 100644 (file)
@@ -1398,7 +1398,7 @@ int usb4_port_margining_caps(struct tb_port *port, enum usb4_sb_target target,
                             u8 index, u32 *caps, size_t ncaps);
 int usb4_port_hw_margin(struct tb_port *port, enum usb4_sb_target target,
                        u8 index, const struct usb4_port_margining_params *params,
-                       u32 *results);
+                       u32 *results, size_t nresults);
 int usb4_port_sw_margin(struct tb_port *port, enum usb4_sb_target target,
                        u8 index, const struct usb4_port_margining_params *params,
                        u32 *results);
index 985f24b044b39487d4939dc6589ee9df85a81f62..05985b18834e8f5a3ba4de4b7477647d6b5c5b98 100644 (file)
@@ -1655,14 +1655,15 @@ int usb4_port_margining_caps(struct tb_port *port, enum usb4_sb_target target,
  * @target: Sideband target
  * @index: Retimer index if taget is %USB4_SB_TARGET_RETIMER
  * @params: Parameters for USB4 hardware margining
- * @results: Array with at least two elements to hold the results
+ * @results: Array to hold the results
+ * @nresults: Number of elements in the results array
  *
  * Runs hardware lane margining on USB4 port and returns the result in
  * @results.
  */
 int usb4_port_hw_margin(struct tb_port *port, enum usb4_sb_target target,
                        u8 index, const struct usb4_port_margining_params *params,
-                       u32 *results)
+                       u32 *results, size_t nresults)
 {
        u32 val;
        int ret;
@@ -1691,7 +1692,7 @@ int usb4_port_hw_margin(struct tb_port *port, enum usb4_sb_target target,
                return ret;
 
        return usb4_port_sb_read(port, target, index, USB4_SB_DATA, results,
-                                sizeof(*results) * 2);
+                                sizeof(*results) * nresults);
 }
 
 /**