All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v3 0/9] backlight: qcom-wled: fix and solidify handling of enabled-strings
@ 2021-11-15 20:34 ` Marijn Suijten
  0 siblings, 0 replies; 51+ messages in thread
From: Marijn Suijten @ 2021-11-15 20:34 UTC (permalink / raw)
  To: phone-devel, Andy Gross, Bjorn Andersson, Rob Herring, Lee Jones,
	Daniel Thompson, Jingoo Han
  Cc: devicetree, linux-fbdev, Kiran Gunda, Pavel Dubrova,
	Jami Kettunen, linux-arm-msm, Bryan Wu, Konrad Dybcio,
	linux-kernel, dri-devel, Martin Botka, ~postmarketos/upstreaming,
	AngeloGioacchino Del Regno, Marijn Suijten

This patchset fixes WLED's handling of enabled-strings: besides some
cleanup it is now actually possible to specify a non-contiguous array of
enabled strings (not necessarily starting at zero) and the values from
DT are now validated to prevent possible unexpected out-of-bounds
register and array element accesses.
Off-by-one mistakes in the maximum number of strings, also causing
out-of-bounds access, have been addressed as well.

Changes in v3:
- Use __le16 type for cpu_to_le16 result;
- Reword ambiguity warning between qcom,num-strings and
  qcom,enabled-strings to explain that only one should/needs to be set;
- Move this warning from patch 4 patch 5, where the length of
  qcom,enabled-strings starts to be taken into account;
- Drop DT patches that have been picked up in the qcom tree.

v2: https://lore.kernel.org/lkml/20211112002706.453289-1-marijn.suijten@somainline.org/T

Changes in v2:
- Reordered patch 4/10 (Validate enabled string indices in DT) to sit
  before patch 1/10 (Pass number of elements to read to read_u32_array);
- Pulled qcom,num-strings out of the DT enumeration parser, and moved it
  after qcom,enabled-strings parser to always have final sign-off over
  the number of strings;
- Extra validation for this number of strings against
  qcom,enabled-strings;
- Recombined patch 9 (Consistently use enabled-strings in
  set_brightness) and patch 10 (Consider enabled_strings in
  autodetection), which both solve the same problem in two different
  functions.  In addition the autodetection code uses set_brightness as
  helper already;
- Improved DT configurations for pmi8994 and pm660l, currently in 5.15
  rc's.

v1: https://lore.kernel.org/dri-devel/20211004192741.621870-1-marijn.suijten@somainline.org/T

Marijn Suijten (9):
  backlight: qcom-wled: Validate enabled string indices in DT
  backlight: qcom-wled: Pass number of elements to read to
    read_u32_array
  backlight: qcom-wled: Use cpu_to_le16 macro to perform conversion
  backlight: qcom-wled: Fix off-by-one maximum with default num_strings
  backlight: qcom-wled: Override default length with
    qcom,enabled-strings
  backlight: qcom-wled: Remove unnecessary 4th default string in WLED3
  backlight: qcom-wled: Provide enabled_strings default for WLED 4 and 5
  backlight: qcom-wled: Remove unnecessary double whitespace
  backlight: qcom-wled: Respect enabled-strings in set_brightness

 drivers/video/backlight/qcom-wled.c | 130 +++++++++++++++-------------
 1 file changed, 72 insertions(+), 58 deletions(-)


base-commit: fa55b7dcdc43c1aa1ba12bca9d2dd4318c2a0dbf
--
2.33.1


^ permalink raw reply	[flat|nested] 51+ messages in thread

end of thread, other threads:[~2021-12-22 11:19 UTC | newest]

Thread overview: 51+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-11-15 20:34 [PATCH v3 0/9] backlight: qcom-wled: fix and solidify handling of enabled-strings Marijn Suijten
2021-11-15 20:34 ` Marijn Suijten
2021-11-15 20:34 ` [PATCH v3 1/9] backlight: qcom-wled: Validate enabled string indices in DT Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:15   ` Lee Jones
2021-12-22 11:15     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 2/9] backlight: qcom-wled: Pass number of elements to read to read_u32_array Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:15   ` Lee Jones
2021-12-22 11:15     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 3/9] backlight: qcom-wled: Use cpu_to_le16 macro to perform conversion Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-11-16 11:56   ` Daniel Thompson
2021-11-16 11:56     ` Daniel Thompson
2021-12-22 11:16   ` Lee Jones
2021-12-22 11:16     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 4/9] backlight: qcom-wled: Fix off-by-one maximum with default num_strings Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-11-16 11:58   ` Daniel Thompson
2021-11-16 11:58     ` Daniel Thompson
2021-12-22 11:16   ` Lee Jones
2021-12-22 11:16     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 5/9] backlight: qcom-wled: Override default length with qcom, enabled-strings Marijn Suijten
2021-11-15 20:34   ` [PATCH v3 5/9] backlight: qcom-wled: Override default length with qcom,enabled-strings Marijn Suijten
2021-11-16 11:59   ` Daniel Thompson
2021-11-16 11:59     ` Daniel Thompson
2021-12-22 11:17   ` Lee Jones
2021-12-22 11:17     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 6/9] backlight: qcom-wled: Remove unnecessary 4th default string in WLED3 Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:17   ` Lee Jones
2021-12-22 11:17     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 7/9] backlight: qcom-wled: Provide enabled_strings default for WLED 4 and 5 Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:18   ` Lee Jones
2021-12-22 11:18     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 8/9] backlight: qcom-wled: Remove unnecessary double whitespace Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:18   ` Lee Jones
2021-12-22 11:18     ` Lee Jones
2021-11-15 20:34 ` [PATCH v3 9/9] backlight: qcom-wled: Respect enabled-strings in set_brightness Marijn Suijten
2021-11-15 20:34   ` Marijn Suijten
2021-12-22 11:18   ` Lee Jones
2021-12-22 11:18     ` Lee Jones
2021-11-16 12:02 ` [PATCH v3 0/9] backlight: qcom-wled: fix and solidify handling of enabled-strings Daniel Thompson
2021-11-16 12:02   ` Daniel Thompson
2021-11-16 15:42   ` Lee Jones
2021-11-16 15:42     ` Lee Jones
2021-12-21 23:31     ` Marijn Suijten
2021-12-21 23:31       ` Marijn Suijten
2021-12-22 10:56       ` Lee Jones

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.