From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-ej1-f47.google.com (mail-ej1-f47.google.com [209.85.218.47]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id BF4633BE146 for ; Wed, 17 Jun 2026 08:00:43 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.218.47 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781683248; cv=none; b=RyIph6ZglqW/CS5PdeZSOg/gjtbQ2SslalNWkFKoMVz6/kEtfqS6gqqPvx0FMMKY6kGH4hCud6nGfrTkVeGtoj6Fa9jL3lJ+lJOq7wfa8c24SuE201lcL97w64ue7qteUY114YfGZQKqX8QWnvnw7e1fsFmow+5nV96/1xEyMI0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781683248; c=relaxed/simple; bh=R4AtVbQ6oyC+Ag1oLv+Kj+iSS/rVvY9CmVauAm7kD2o=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=lSyjGWzoMEnoOHyoyfC5hgh5J5QPUaHQGIz28bwDfxyYSQlTbLRkKiJwihRP2LEMAJ+EsxSS9ywkKoDt33FfEvCFO13Xn+qgVYDdWSmVmiEDLcPkaaIR8QmQXz1UNgIRzy3dLAfgtobmfzcxdyZITBQV8KlEvfMG1xSTG1Ki/P4= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=lIfxnH7i; arc=none smtp.client-ip=209.85.218.47 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="lIfxnH7i" Received: by mail-ej1-f47.google.com with SMTP id a640c23a62f3a-c069d7646b2so8133666b.2 for ; Wed, 17 Jun 2026 01:00:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1781683242; x=1782288042; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=kcUO9XWzTg2IsD2mVUzEQjeXErkVrXuEkYwVMwsj2Z0=; b=lIfxnH7iD18zPNxrG8f0e7cOOCn+nSdxcjxtXJYLConi3l752C1QaiAUFdclvH8bnO oGzUD3Q6u+5Wqoz1BNc2sq+NSUvtby5TT7bppAxqGYiHVDFaBw5q1ysaWdfYz05NOYEX oxo1uo+SjJ9ZORLOVa4POqDIyU+MZ9A8KA86mLR6grGyB96QW7ZdItO4ylKBZl4efvwj n17hgw/NTfDUYJ9/CT2HhrfCh3dLv8Q0uPqS6EEePSagyQubcQyQNJ0fPRDYpAIObbv8 Gg6pMu1hGhuKl9OUDXYhFYnS9N1rHtvGMnQwRIIjqw9zGLi/JbLMJY+pfENZcp3HHFGV IJFQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781683242; x=1782288042; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=kcUO9XWzTg2IsD2mVUzEQjeXErkVrXuEkYwVMwsj2Z0=; b=COfxwQHf1FidiKuQQAwlONwrAC0AJBgcrohPfTb2Eg4XiJcrQUDxX0EDTyPuUr2eM8 +da69zD2fGInF6LqhkHfn7yuT4sqHI2fSHRoRsznVESTiodxcpuAgWQCfh8Y4dPCBuNA 7PNrQM74BD1XRlGCooJctQF0c86LRQujYrXqYvsTrqeuGqEAl4UeFp6s+PhZ9OVC3OH4 VjC15xabD2qnWlxEjcm8+KhG0+n9XrP5tLhYMUWp5dqQSdl60HyfM/wJS4fVT997SHZW OsVb0Hf1rHX8Du/IFdvcaoIYTW2NnlZIgYxhWqRt8VuzRBPiOTC5s40VNHlE+nLkvKxG GLNw== X-Forwarded-Encrypted: i=1; AFNElJ8Kcff0rvHKAiRenVrPozRIjryNtgq0Dpn1z7Iztp6d5kvHhuf87hrMSkQ1O0DX2VNnSKcVtHGvtmB7mw==@vger.kernel.org X-Gm-Message-State: AOJu0YxhMKv3bGIQ0Vh4CfTwMtYFlGHlZSJDW6ks7KOxOqkmrO1c0c7x rcFblMNJH7b7m8xbWQhFWuyf9sZUTdctFEq/vkjXaKJh0YF5TjVhukXp X-Gm-Gg: Acq92OF6GezGFUyR2Fcy+XuROK1GG90MzYIgORa3Lu06NHelBYiwRZwwrzZTkK9L923 TeZNvxgIreObocNcopy4LQmPUkHyMyf/De/jEhlMqiO5+KDIOPczCRhOQEBLl5TFo5epoGQYiJZ Fxu8pidVhFXZaeEV3dz+Q9IDnWVNou3OtH4mumscrb+Hlgdo8vE0tgG7UffMs+UTcWRmyNiWibL iGBViL6ka8OiSwJ/MBYOoSmfKIt+ovvbgMMnUx9tv1C/zThJAdMR53kbjti8W6zaZBlYvk51jNQ 97D6FQBhXbXbnBbiKcCLg351lpL59VJ6zphanrOtmCkXBTtMjP2/FLbBD2xY30HZGb1XIor8mRr ZCqtmooZFADhCNhpbXHzt/RE8hTCvNdvmI83NzjATBNN88DcTk/TYf5mXXG822uxxPlbTHS/e/2 QnxQ== X-Received: by 2002:a17:907:6090:b0:bed:e2e8:d8c3 with SMTP id a640c23a62f3a-c05a2e40c2dmr185800566b.22.1781683241134; Wed, 17 Jun 2026 01:00:41 -0700 (PDT) Received: from xeon ([188.163.112.61]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-bfdb058fa59sm755339766b.0.2026.06.17.01.00.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 17 Jun 2026 01:00:40 -0700 (PDT) From: Svyatoslav Ryhel To: Lee Jones , Daniel Thompson , Jingoo Han , Pavel Machek , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Jonathan Cameron , David Lechner , =?UTF-8?q?Nuno=20S=C3=A1?= , Andy Shevchenko , Helge Deller , Svyatoslav Ryhel Cc: Johan Hovold , dri-devel@lists.freedesktop.org, linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org, linux-fbdev@vger.kernel.org Subject: [PATCH v5 00/14] mfd: lm3533: convert to OF bindings, improve support Date: Wed, 17 Jun 2026 11:00:17 +0300 Message-ID: <20260617080031.99156-1-clamor95@gmail.com> X-Mailer: git-send-email 2.53.0 Precedence: bulk X-Mailing-List: linux-fbdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Convert LM3533 to OF bindings, add missing VIN supply, add support for setting mapping mode and LED sources based on device tree. --- Changes in v2: schema - maximum led sources for leds set to 4 - anyOf > oneOf in ALS - improved ALS descriptions - adjusted example drivers - dropped devm convertion of irq and mfd helpers - all als configuration moved into lm3533_als_setup - added regulator/consumer.h - lm3533_bl_setup set before sysfs_create_group in backlight - added check if LVLED is valid - LM3533_REG_OUTPUT_CONF1 > LM3533_REG_OUTPUT_CONF2 for LVLED4 and LVLED5 Changes in v3: - ohm -> ohms - added default PWM mask to schema - added commit removing driver regmap wrappers - added commits which flatten pdata helpers - adjusted check if als->irq > 0 since als->irq can be negative if error/missing - added count for children defined in device tree and mfd_cell is allocated via devm_kcalloc to be able to contain all of them - fixed backlight boundary check - fixed count increased unconditionally - dev_err returns node name instead of reg value - LM3533_MAX_CURRENT_* defines moved to common header since they are used to clamp current values read from the tree - mapping mode commit splitted into 2 (sysfs logic improvement > mode from DT) - backlight mode configuration set before sysfs group is created - fixed LVLED check on LEDs setup - added check if HVLED is valid - fixed wrong err_sysfs_remove goto in lm3533_bl - added commit implementing backlight_scale property Changes in v4: - fixed regmap_update_bits val and mask swap in lm3533_als_set_int_mode - fixed als->irq check in store_thresh_either_en - removed clamping of r_select in als driver - added use_of_reg and of_reg for backlight and leds registration - added intermediate step in asigning props.brightness - fixed HVLED/LVLED configuration overwriting - added bounds check for num_leds in leds and backlight driver - switched to regmap_clean/set/assign/test_bits helpers where appropriate - dropped extern from header function declartions - switched lm3533 pointer in cell structures to regmap - sysfs_create_group > device_add_group - changes in backlight sysfs were expanded to all properties Changes in v5: - aligned driver helpers to use u32 - child nodes parsing linked with 'else if' to ensure there is one call per node - removed redundant pwm var init for leds - fixed regmap_test_bits return check - fixed leds and backlight counting handling - iterator variables made scoped - lm3533_als_setup() set to exit after mode set if m0de is pwm --- Svyatoslav Ryhel (14): dt-bindings: leds: Document TI LM3533 LED controller mfd: lm3533: Remove driver specific regmap wrappers mfd: lm3533: Remove extern from shared functions in the header mfd: lm3533: Pass only regmap and light sensor presence to child devices iio: light: lm3533-als: Remove redundant pdata helpers mfd: lm3533-core: Remove redundant pdata helpers mfd: lm3533: Use dev_groups in struct device_driver mfd: lm3533: Convert to use OF bindings mfd: lm3533: Add support for VIN power supply mfd: lm3533: Set DMA mask video: backlight: lm3533_bl: Improve logic of sysfs functions video: backlight: lm3533_bl: Set initial mapping mode from DT video: backlight: lm3533_bl: Implement backlight_scale property video: leds: backlight: lm3533: Support getting LED sources from DT .../leds/backlight/ti,lm3533-backlight.yaml | 69 ++++ .../bindings/leds/ti,lm3533-leds.yaml | 67 ++++ .../devicetree/bindings/leds/ti,lm3533.yaml | 169 ++++++++ drivers/iio/light/lm3533-als.c | 180 ++++----- drivers/leds/leds-lm3533.c | 184 ++++++--- drivers/mfd/lm3533-core.c | 375 +++++++----------- drivers/mfd/lm3533-ctrlbank.c | 33 +- drivers/video/backlight/lm3533_bl.c | 232 ++++++----- include/linux/mfd/lm3533.h | 75 +--- 9 files changed, 821 insertions(+), 563 deletions(-) create mode 100644 Documentation/devicetree/bindings/leds/backlight/ti,lm3533-backlight.yaml create mode 100644 Documentation/devicetree/bindings/leds/ti,lm3533-leds.yaml create mode 100644 Documentation/devicetree/bindings/leds/ti,lm3533.yaml -- 2.53.0