From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 683DEC43334 for ; Fri, 15 Jul 2022 11:26:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229603AbiGOL0Z (ORCPT ); Fri, 15 Jul 2022 07:26:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229452AbiGOL0Y (ORCPT ); Fri, 15 Jul 2022 07:26:24 -0400 Received: from mail-pj1-x1030.google.com (mail-pj1-x1030.google.com [IPv6:2607:f8b0:4864:20::1030]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 167BC13DDA; Fri, 15 Jul 2022 04:26:23 -0700 (PDT) Received: by mail-pj1-x1030.google.com with SMTP id o3-20020a17090a744300b001ef8f7f3dddso5777007pjk.3; Fri, 15 Jul 2022 04:26:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=HUVakAht3QYDlCi6rTyHeuImXIMd379d6m8rZFlB3sH4E5dxdvR2GCC4cEqBq0hWHO 3mZAFFKklsIBUVZeEziNcYCKl3zu29jSR49coEkq/NEsl8fliMu4Gps15q5kYqP7H2x2 pBJFKtAwkAm0YIsjRhHfrikU+jVoPijPUxfVIVn4JjFXKSyP/NBe/eprcI6/hgR03rQJ ETmc1N5Q2qEArmwE5va/IgZTPbmV9zI22+JK2uCOFMjlRhq72MCfo1oJCOvIr7sI8vRB fkkJ6hSHZzzEKAWLjQfbpocJ6mU2MF42oDM8TC5eEwin4rpIj5+HZnjfPYFWo1igXxvk ylpg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=HTnMH46nvwcYxm4XqMIEiD+eNO/0h6/jCTu89Ilnal89R+ankotVPwr3ehn5zRvNXp geleH2bIqOUuXhrTrPyiJi69mtFr5h74C31GtqKh0NJ3uZ5rnHuTPLxsBAQMQ7yEHdqy 4kfP+5O3i8f8VTlyu0WALaGGl+ZlbefKZyjfQqfvYcwZEW692OwmxPlvHyXrHZK/lNc4 SLLGDdlP7upyutkmnmL7CO1fiHTLP+PyQ4aWlapA1aXcrUnTtX5lFdqyAg4kJQ5YEgnM YsVRCn5f/6ZE4Co5jXOTF5L38CN3kyZPyc8+7Ni3bcMPVDDAgglHuqpy5D0AsXmQxz/K u48w== X-Gm-Message-State: AJIora8ftNcXzL3p0rrPcWSBg1E7RRv0Yru53PmftgKCGEQuhMbYjA+c 4hTGvd+VVBEzv0d5BSmAo28= X-Google-Smtp-Source: AGRyM1vAeOtUIfstbiXdFTS8IM2qsuNBcIlE5ZGLviTu+LOg0TWAQB6D3c0+uhw6k8SiuBspFKiMsA== X-Received: by 2002:a17:902:7487:b0:16b:d8ae:7e33 with SMTP id h7-20020a170902748700b0016bd8ae7e33mr12804578pll.21.1657884382451; Fri, 15 Jul 2022 04:26:22 -0700 (PDT) Received: from RD-3580-24288.rt.l (42-72-159-86.emome-ip.hinet.net. [42.72.159.86]) by smtp.gmail.com with ESMTPSA id a5-20020aa78e85000000b00525b61f4792sm3550604pfr.109.2022.07.15.04.26.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Jul 2022 04:26:21 -0700 (PDT) From: ChiaEn Wu To: lee.jones@linaro.org, daniel.thompson@linaro.org, jingoohan1@gmail.com, pavel@ucw.cz, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, matthias.bgg@gmail.com, sre@kernel.org, chunfeng.yun@mediatek.com, gregkh@linuxfoundation.org, jic23@kernel.org, lars@metafoo.de, lgirdwood@gmail.com, broonie@kernel.org, linux@roeck-us.net, heikki.krogerus@linux.intel.com, deller@gmx.de Cc: chiaen_wu@richtek.com, alice_chen@richtek.com, cy_huang@richtek.com, dri-devel@lists.freedesktop.org, linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, linux-usb@vger.kernel.org, linux-iio@vger.kernel.org, linux-fbdev@vger.kernel.org, szunichen@gmail.com Subject: [PATCH v5 00/13] Add MediaTek MT6370 PMIC support Date: Fri, 15 Jul 2022 19:25:54 +0800 Message-Id: <20220715112607.591-1-peterwu.pub@gmail.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-leds@vger.kernel.org From: ChiaEn Wu This patch series add MediaTek MT6370 PMIC support. The MT6370 is a highly-integrated smart power management IC, which includes a single cell Li-Ion/Li-Polymer switching battery charger, a USB Type-C & Power Delivery (PD) controller, dual Flash LED current sources, a RGB LED driver, a backlight WLED driver, a display bias driver and a general LDO for portable devices. In this series of patches, we based on Andy Shevchenko's mfd patch used to adjust the Makefile order. (https://lore.kernel.org/all/20220616182524.7956-2-andriy.shevchenko@linux.intel.com/) Among with this, we took some changes for MT6370 and refined the MT6370 device tree files to comply with DT specifications. "[PATCH v5 06/13] dt-bindings: mfd: Add MediaTek MT6370" depends on previous DT binding patches, so before applying this patch, please apply other DT patches first. Thanks! Thank you, ChiaEn Wu --- Changes in v5: - In patch 07/13: - Add the comma in the last REGMAP_IRQ_REG_LINE(), DEFINE_RES_IRQ_NAMED() and MFD_CELL_RES() - Add the prefix in the first parameter of all mfd_cell - Move enum and struct mt6370_info to mt6370.h - Remove struct device *dev in struct mt6370_info - Revise the description of Kconfig help text - Revise MODULE_DESCRIPTION() - In patch 08/13: - Add comma for the last index of mt6370_reg_init. - Use dev_err_probe to decrease LOC. - Use 'dev' variable to make probe function more clean. - Refine kconfig text. - Remove both 'else' in set_vbus callback. - Remove comma for of_device_id if the assigned member is only one. - In patch 09/13: - Replace using snprintf() with sysfs_emit() in mt6370_adc_read_label() - Remove macro ADC_CONV_TIME_US - Revise all variable ordering - Revise the description of Kconfig help text - Revise MODULE_DESCRIPTION() - In patch 10/13: - Replace unsigned int type of pwr_rdy with bool in mt6370_chg_set_online() - Remove redundant 'else' in mt6370_chg_field_get() - Revise 'if-else' in mt6370_chg_field_set() - Revise 'if' condition in mt6370_chg_enable_irq() - Revise all text 'otg' --> 'OTG' - Revise MT6370_MIVR_IBUS_TH_100_MA --> MT6370_MIVR_IBUS_TH_100_mA - Revise the description of Kconfig help text - In patch 12/13: - Refine descriptions. - Refine the macro name. - Refine the bracket and blanks. - In patch 13/13: - Add missed - Add struct device *dev in probe() to make code cleaning - Remove useless including header file , - Remove useless variable uasage in mt6370_init_backlight_properties() - Remove redundant checking enable_gpio in mt6370_bl_update_status() - Remove redundant parentheses in mt6370_bl_get_brightness() - Revise the description of Kconfig help text - Revise the calculation of hys_th_steps Changes in v4: - In patch 02/13: - Add minItems of "io-channel-names" - Replace text "Mediatek" with "MediaTek" - In patch 06/13: - Roll back all "$ref: " to v2 patch style (using "/schemas/...") - In patch 07/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace "first break and then return" with "return directly" in "mt6370_check_vendor_info()" - Add module name related description in Kconfig helptext - Add Copyright in the source code - Add header file "mt6370.h" for all "#define IRQ" - Adjust Makefile order of MT6370 - Refine "bank_idx" and "bank_addr" in "mt6375_regmap_read()" / "mt6375_regmap_write()" - Refine redundant "else if" in "mt6370_regmap_read()" - In patch 08/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace "first ret=regulator_(dis/en)able and then return" with "return directly" in "mt6370_tcpc_set_vbus()" - Replace header file with - Add Copyright in the source code - Add module name related description in Kconfig helptext - Remove header file - Refine all probe error by using dev_err_probe() - In patch 09/13: - Replace text "Mediatek" with "MediaTek" - Replace all "first dev_err() and then return" with "return dev_err_probe()" - Add Copyright in the source code - Add module name related description in Kconfig - Add unit suffix of macro "ADC_CONV_POLLING_TIME" - Add new macro "ADC_CONV_TIME_MS" - Adjust the position of include file - Adjust the postions between and - Fix some incorrect characters - In patch 10/13: - Replace text "Mediatek" with "MediaTek" in Kconfig and MODULE_DESCRIPTION() - Replace "mt6370_chg_val_to_reg" and "mt6370_chg_reg_to_val" with "linear_range" API - Replace "first break and then return" with "return directly" in all cases of get/set power_supply_property - Replace all "first dev_err() and then return" with "return dev_err_probe()" - Replace all "return IS_ERR(priv->rdev) ? PTR_ERR(priv->rdev) : 0" with "PTR_ERR_OR_ZERO()" - Replace "priv->dev->of_node" with "dev_of_node()" - Add Copyright in the source code - Add module name related description in Kconfig helptext - Add proper unit of "MT6370_MIVR_IBUS_TH" - Add error check in "mt6370_chg_get_status" - Remove including header file - Remove redundant comma of every enum terminator line - Remove unwanted blank lines - Remove the useless label (toggle_cfo_exit:) - Remove using atomic - Remove using of_match_ptr() - Fix some incorrect characters - Fix updating wrong bits when using ena_gpiod of OTG regulator - Adjust the probe order in probe() - In patch 11/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace text "const" with "constant" in Kconfig - Add Copyright in the source code - In patch 12/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Add Copyright in the source code - In patch 13/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Add Copyright in the source code - Revise the comment of "PWM HYS STEPS" Changes in v3: - Remove ADC ABI file, which is added in v2 Patch 7 - In patch 02/14: - Add items and remove maxItems of io-channels - Add io-channel-names and describe each item - Add "unevaluatedProperties: false" in "usb-otg-vbus-regulator" - Rename "enable-gpio" to "enable-gpios" in "usb-otg-vbus-regulator" - In patch 03/14: - Use leds-class-multicolor.yaml instead of common.yaml. - Split multi-led and led node. - Add subdevice "led" in "multi-led". - In patch 04/14: - Remove the description of enum. - In patch 05/14: - Rename "mediatek,bled-pwm-hys-input-threshold-steps" to "mediatek,bled-pwm-hys-input-th-steps" - Refine "bled-pwm-hys-input-th-steps", "bled-ovp-microvolt", "bled-ocp-microamp" enum values - In patch 06/14: - Use " in entire patchset - Refine ADC description - Rename "enable-gpio" to "enable-gpios" in "regualtor" - In patch 07/14: - Refine Kconfig help text - Refine error message of unknown vendor ID in mt6370_check_vendor_info() - Refine return value handling of mt6370_regmap_read() - Refine all probe error by using dev_err_probe() - Refine "bank_idx" and "bank_addr" in mt6370_regmap_read() and mt6370_regmap_write() - Add "#define VENID*" and drop the comments in mt6370_check_vendor_info() - Drop "MFD" in MODULE_DESCRIPTION() - In patch 09/14: - Refine Kconfig help text - In patch 10/14: - Refine Kconfig help text - Refine all channel value in read_scale() a. current: uA --> mA b. voltage: uV --> mV c. temperature: degrees Celsius --> milli degrees Celsius - Add "default:" condition of switch statement in read_scale() and read_raw() - Add error message for reading ADC register failed - Add the comment for adc_lock - Add header file for struct of_device_id - Replace "adc" text with "ADC" in all of the error messages - In patch 12/14: - Refine the grammer of the Kconfig. - Change reg mode to the const current mode. - In patch 14/14: - Refine bool properties parsing (pwm-enable, ovp-shutdown, ocp-shutdown) in DT parsing function - Refine u32 and u8 properties parsing (pwm-hys-input-th-steps, ovp-microvolt, ocp-microamp), from using register value to using actual value - Refine error string of "channle-use" parsing failed - Refine Kconfig help text Changes in v2: - In patch 01/15: - Add "unevaluatedProperties: false". - Delete "DT bindings". - Refine the description to fit in 80 columns. - Skip the connector description. - In patch 02/15: - Refine items description of interrupt-name - Rename "usb-otg-vbus" to "usb-otg-vbus-regulator" - Add constraint properties for ADC - In patch 03/15: - Skip not useful description of "^(multi-)?led@[0-3]$" and reg. - Due to the dependency, remove the mention of mfd document directory. - Delete Soft-start property. In design aspect, we think soft-restart should always be enabled, our new chip has deleted the related setting register , also, we don’t allow user adjust this parameter in this chip. - Refine the commit message. - In patch 04/15: - Skip not useful description of "^led@[0-1]$" and reg. - Add apace after '#'. - Refine the commit message. - In patch 05/15: - Remove "binding documentation" in subject title - Refine description of mt6370 backlight binding document - Refine properties name(bled-pwm-hys-input-bit, bled-ovp-microvolt, bled-ocp-microamp) and their description - In patch 06/15: - Refine ADC and Regulator descriptions - Refine include header usage in example - Refine node name to generic node name("pmic@34") - Refine led example indentation - Refine license of mediatek,mt6370_adc.h - Rename the dts example from IRQ define to number. - Remove mediatek,mt6370.h - In patch 07/15: - Add ABI documentation for mt6370 non-standard ADC sysfs interfaces. - In patch 08/15: - Add all IRQ define into mt6370.c. - Refine include header usage - In patch 09/15: - No changes. - In patch 10/15: - Use 'gpiod_get_from_of_node' to replace 'fwnode_gpiod_get_index'. - In patch 11/15: - Refine Kconfig mt6370 help text - Refine mask&shift to FIELD_PREP() - Refine mutex lock name ("lock" -> "adc_lock") - Refine mt6370_adc_read_scale() - Refine mt6370_adc_read_offset() - Refine mt6370_channel_labels[] by using enum to index chan spec - Refine MT6370_ADC_CHAN() - Refine indio_dev->name - Remove useless include header files - In patch 12/15: - Refine mt6370_chg_otg_rdesc.of_match ("mt6370,otg-vbus" -> "usb-otg-vbus-regulator") to match DT binding - In patch 13/15: - Refine Kconfig description. - Remove include "linux/of.h" and use "linux/mod_devicetable.h". - Place a comma for the last element of the const unsigned int array. - Add a comment line for the mutex 'lock'. - In probe function, use 'dev_err_probe' in some judgement to reduce the LOC. - Refine include header usage. BIT/GENMASK -> linux/bits.h FIELD_GET -> linux/bitfield.h - In patch 14/15: - Add blank line. - Replace container_of() with to_mt6370_led() . - Refine description of ramping. - Refine the mt6370_init_common_properties function. - Refine the probe return. - In patch 15/15: - Refine MT6370 help text in Kconfig - Refine DT Parse function - Remove useless enum - Add comment for 6372 backward compatible in bl_update_status() and check_vendor_info() - Using dev_err_probe(); insteads dev_err()&return; in the probe() Alice Chen (2): dt-bindings: leds: Add MediaTek MT6370 flashlight leds: flashlight: mt6370: Add MediaTek MT6370 flashlight support ChiYuan Huang (7): dt-bindings: usb: Add MediaTek MT6370 TCPC dt-bindings: leds: mt6370: Add MediaTek MT6370 current sink type LED indicator dt-bindings: backlight: Add MediaTek MT6370 backlight dt-bindings: mfd: Add MediaTek MT6370 mfd: mt6370: Add MediaTek MT6370 support usb: typec: tcpci_mt6370: Add Mediatek MT6370 tcpci driver leds: mt6370: Add MediaTek MT6370 current sink type LED Indicator support ChiaEn Wu (4): dt-bindings: power: supply: Add MediaTek MT6370 Charger iio: adc: mt6370: Add MediaTek MT6370 support power: supply: mt6370: Add MediaTek MT6370 charger driver video: backlight: mt6370: Add MediaTek MT6370 support .../leds/backlight/mediatek,mt6370-backlight.yaml | 92 ++ .../bindings/leds/mediatek,mt6370-flashlight.yaml | 41 + .../bindings/leds/mediatek,mt6370-indicator.yaml | 77 ++ .../devicetree/bindings/mfd/mediatek,mt6370.yaml | 280 ++++++ .../power/supply/mediatek,mt6370-charger.yaml | 88 ++ .../bindings/usb/mediatek,mt6370-tcpc.yaml | 36 + drivers/iio/adc/Kconfig | 12 + drivers/iio/adc/Makefile | 1 + drivers/iio/adc/mt6370-adc.c | 273 +++++ drivers/leds/Kconfig | 14 + drivers/leds/Makefile | 1 + drivers/leds/flash/Kconfig | 12 + drivers/leds/flash/Makefile | 1 + drivers/leds/flash/leds-mt6370-flash.c | 661 ++++++++++++ drivers/leds/leds-mt6370.c | 994 ++++++++++++++++++ drivers/mfd/Kconfig | 16 + drivers/mfd/Makefile | 1 + drivers/mfd/mt6370.c | 281 ++++++ drivers/mfd/mt6370.h | 99 ++ drivers/power/supply/Kconfig | 14 + drivers/power/supply/Makefile | 1 + drivers/power/supply/mt6370-charger.c | 1062 ++++++++++++++++++++ drivers/usb/typec/tcpm/Kconfig | 11 + drivers/usb/typec/tcpm/Makefile | 1 + drivers/usb/typec/tcpm/tcpci_mt6370.c | 207 ++++ drivers/video/backlight/Kconfig | 12 + drivers/video/backlight/Makefile | 1 + drivers/video/backlight/mt6370-backlight.c | 339 +++++++ include/dt-bindings/iio/adc/mediatek,mt6370_adc.h | 18 + 29 files changed, 4646 insertions(+) create mode 100644 Documentation/devicetree/bindings/leds/backlight/mediatek,mt6370-backlight.yaml create mode 100644 Documentation/devicetree/bindings/leds/mediatek,mt6370-flashlight.yaml create mode 100644 Documentation/devicetree/bindings/leds/mediatek,mt6370-indicator.yaml create mode 100644 Documentation/devicetree/bindings/mfd/mediatek,mt6370.yaml create mode 100644 Documentation/devicetree/bindings/power/supply/mediatek,mt6370-charger.yaml create mode 100644 Documentation/devicetree/bindings/usb/mediatek,mt6370-tcpc.yaml create mode 100644 drivers/iio/adc/mt6370-adc.c create mode 100644 drivers/leds/flash/leds-mt6370-flash.c create mode 100644 drivers/leds/leds-mt6370.c create mode 100644 drivers/mfd/mt6370.c create mode 100644 drivers/mfd/mt6370.h create mode 100644 drivers/power/supply/mt6370-charger.c create mode 100644 drivers/usb/typec/tcpm/tcpci_mt6370.c create mode 100644 drivers/video/backlight/mt6370-backlight.c create mode 100644 include/dt-bindings/iio/adc/mediatek,mt6370_adc.h -- 2.7.4 From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 846E3C43334 for ; Fri, 15 Jul 2022 11:26:29 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id C9B0714BF76; Fri, 15 Jul 2022 11:26:28 +0000 (UTC) Received: from mail-pl1-x62b.google.com (mail-pl1-x62b.google.com [IPv6:2607:f8b0:4864:20::62b]) by gabe.freedesktop.org (Postfix) with ESMTPS id BC55014BF76 for ; Fri, 15 Jul 2022 11:26:27 +0000 (UTC) Received: by mail-pl1-x62b.google.com with SMTP id x21so2979331plb.3 for ; Fri, 15 Jul 2022 04:26:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=HUVakAht3QYDlCi6rTyHeuImXIMd379d6m8rZFlB3sH4E5dxdvR2GCC4cEqBq0hWHO 3mZAFFKklsIBUVZeEziNcYCKl3zu29jSR49coEkq/NEsl8fliMu4Gps15q5kYqP7H2x2 pBJFKtAwkAm0YIsjRhHfrikU+jVoPijPUxfVIVn4JjFXKSyP/NBe/eprcI6/hgR03rQJ ETmc1N5Q2qEArmwE5va/IgZTPbmV9zI22+JK2uCOFMjlRhq72MCfo1oJCOvIr7sI8vRB fkkJ6hSHZzzEKAWLjQfbpocJ6mU2MF42oDM8TC5eEwin4rpIj5+HZnjfPYFWo1igXxvk ylpg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=B0GR6fpJ9UD96OGeFmt2SOhd+8VLUpkFlNgRBBItxM8S151wUBOvlAFy0+7SR6lj4R UWbg0yIw5wHJMtD6teDHnfDAyRhARqNYmOWWU4ke61JouFqanVmYtfj0F0UJDaqKEhEH CCY27fHRF853I9b9Pu4XsIsNtW8IFf+ryrXRk9kQ/80ffr66VMUHA2hlT54VvIj+Nupt YkrVlYGKeb2h98/lEFvaOTt3PzP9veCLNZBAIgnbJnrXIuuB4EuzRPZk55TW9fknQkZY 3k8XUZvM0FLL9eUvFayCoul/3qUJI0uR/GBn3dzoav5goRCWG6sOKlByU3It60pHFEyQ jCig== X-Gm-Message-State: AJIora90sg97ewGjbbLOoGbz+rG56oo1pmSlN5iZcikJ20L0qDvv/yBi TKrejyAC6pJ3yy1xsQ2qCzg= X-Google-Smtp-Source: AGRyM1vAeOtUIfstbiXdFTS8IM2qsuNBcIlE5ZGLviTu+LOg0TWAQB6D3c0+uhw6k8SiuBspFKiMsA== X-Received: by 2002:a17:902:7487:b0:16b:d8ae:7e33 with SMTP id h7-20020a170902748700b0016bd8ae7e33mr12804578pll.21.1657884382451; Fri, 15 Jul 2022 04:26:22 -0700 (PDT) Received: from RD-3580-24288.rt.l (42-72-159-86.emome-ip.hinet.net. [42.72.159.86]) by smtp.gmail.com with ESMTPSA id a5-20020aa78e85000000b00525b61f4792sm3550604pfr.109.2022.07.15.04.26.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Jul 2022 04:26:21 -0700 (PDT) From: ChiaEn Wu To: lee.jones@linaro.org, daniel.thompson@linaro.org, jingoohan1@gmail.com, pavel@ucw.cz, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, matthias.bgg@gmail.com, sre@kernel.org, chunfeng.yun@mediatek.com, gregkh@linuxfoundation.org, jic23@kernel.org, lars@metafoo.de, lgirdwood@gmail.com, broonie@kernel.org, linux@roeck-us.net, heikki.krogerus@linux.intel.com, deller@gmx.de Subject: [PATCH v5 00/13] Add MediaTek MT6370 PMIC support Date: Fri, 15 Jul 2022 19:25:54 +0800 Message-Id: <20220715112607.591-1-peterwu.pub@gmail.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: devicetree@vger.kernel.org, linux-fbdev@vger.kernel.org, szunichen@gmail.com, alice_chen@richtek.com, linux-pm@vger.kernel.org, linux-iio@vger.kernel.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, cy_huang@richtek.com, chiaen_wu@richtek.com, linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-leds@vger.kernel.org Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" From: ChiaEn Wu This patch series add MediaTek MT6370 PMIC support. The MT6370 is a highly-integrated smart power management IC, which includes a single cell Li-Ion/Li-Polymer switching battery charger, a USB Type-C & Power Delivery (PD) controller, dual Flash LED current sources, a RGB LED driver, a backlight WLED driver, a display bias driver and a general LDO for portable devices. In this series of patches, we based on Andy Shevchenko's mfd patch used to adjust the Makefile order. (https://lore.kernel.org/all/20220616182524.7956-2-andriy.shevchenko@linux.intel.com/) Among with this, we took some changes for MT6370 and refined the MT6370 device tree files to comply with DT specifications. "[PATCH v5 06/13] dt-bindings: mfd: Add MediaTek MT6370" depends on previous DT binding patches, so before applying this patch, please apply other DT patches first. Thanks! Thank you, ChiaEn Wu --- Changes in v5: - In patch 07/13: - Add the comma in the last REGMAP_IRQ_REG_LINE(), DEFINE_RES_IRQ_NAMED() and MFD_CELL_RES() - Add the prefix in the first parameter of all mfd_cell - Move enum and struct mt6370_info to mt6370.h - Remove struct device *dev in struct mt6370_info - Revise the description of Kconfig help text - Revise MODULE_DESCRIPTION() - In patch 08/13: - Add comma for the last index of mt6370_reg_init. - Use dev_err_probe to decrease LOC. - Use 'dev' variable to make probe function more clean. - Refine kconfig text. - Remove both 'else' in set_vbus callback. - Remove comma for of_device_id if the assigned member is only one. - In patch 09/13: - Replace using snprintf() with sysfs_emit() in mt6370_adc_read_label() - Remove macro ADC_CONV_TIME_US - Revise all variable ordering - Revise the description of Kconfig help text - Revise MODULE_DESCRIPTION() - In patch 10/13: - Replace unsigned int type of pwr_rdy with bool in mt6370_chg_set_online() - Remove redundant 'else' in mt6370_chg_field_get() - Revise 'if-else' in mt6370_chg_field_set() - Revise 'if' condition in mt6370_chg_enable_irq() - Revise all text 'otg' --> 'OTG' - Revise MT6370_MIVR_IBUS_TH_100_MA --> MT6370_MIVR_IBUS_TH_100_mA - Revise the description of Kconfig help text - In patch 12/13: - Refine descriptions. - Refine the macro name. - Refine the bracket and blanks. - In patch 13/13: - Add missed - Add struct device *dev in probe() to make code cleaning - Remove useless including header file , - Remove useless variable uasage in mt6370_init_backlight_properties() - Remove redundant checking enable_gpio in mt6370_bl_update_status() - Remove redundant parentheses in mt6370_bl_get_brightness() - Revise the description of Kconfig help text - Revise the calculation of hys_th_steps Changes in v4: - In patch 02/13: - Add minItems of "io-channel-names" - Replace text "Mediatek" with "MediaTek" - In patch 06/13: - Roll back all "$ref: " to v2 patch style (using "/schemas/...") - In patch 07/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace "first break and then return" with "return directly" in "mt6370_check_vendor_info()" - Add module name related description in Kconfig helptext - Add Copyright in the source code - Add header file "mt6370.h" for all "#define IRQ" - Adjust Makefile order of MT6370 - Refine "bank_idx" and "bank_addr" in "mt6375_regmap_read()" / "mt6375_regmap_write()" - Refine redundant "else if" in "mt6370_regmap_read()" - In patch 08/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace "first ret=regulator_(dis/en)able and then return" with "return directly" in "mt6370_tcpc_set_vbus()" - Replace header file with - Add Copyright in the source code - Add module name related description in Kconfig helptext - Remove header file - Refine all probe error by using dev_err_probe() - In patch 09/13: - Replace text "Mediatek" with "MediaTek" - Replace all "first dev_err() and then return" with "return dev_err_probe()" - Add Copyright in the source code - Add module name related description in Kconfig - Add unit suffix of macro "ADC_CONV_POLLING_TIME" - Add new macro "ADC_CONV_TIME_MS" - Adjust the position of include file - Adjust the postions between and - Fix some incorrect characters - In patch 10/13: - Replace text "Mediatek" with "MediaTek" in Kconfig and MODULE_DESCRIPTION() - Replace "mt6370_chg_val_to_reg" and "mt6370_chg_reg_to_val" with "linear_range" API - Replace "first break and then return" with "return directly" in all cases of get/set power_supply_property - Replace all "first dev_err() and then return" with "return dev_err_probe()" - Replace all "return IS_ERR(priv->rdev) ? PTR_ERR(priv->rdev) : 0" with "PTR_ERR_OR_ZERO()" - Replace "priv->dev->of_node" with "dev_of_node()" - Add Copyright in the source code - Add module name related description in Kconfig helptext - Add proper unit of "MT6370_MIVR_IBUS_TH" - Add error check in "mt6370_chg_get_status" - Remove including header file - Remove redundant comma of every enum terminator line - Remove unwanted blank lines - Remove the useless label (toggle_cfo_exit:) - Remove using atomic - Remove using of_match_ptr() - Fix some incorrect characters - Fix updating wrong bits when using ena_gpiod of OTG regulator - Adjust the probe order in probe() - In patch 11/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Replace text "const" with "constant" in Kconfig - Add Copyright in the source code - In patch 12/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Add Copyright in the source code - In patch 13/13: - Replace text "Mediatek" with "MediaTek" in Kconfig - Add Copyright in the source code - Revise the comment of "PWM HYS STEPS" Changes in v3: - Remove ADC ABI file, which is added in v2 Patch 7 - In patch 02/14: - Add items and remove maxItems of io-channels - Add io-channel-names and describe each item - Add "unevaluatedProperties: false" in "usb-otg-vbus-regulator" - Rename "enable-gpio" to "enable-gpios" in "usb-otg-vbus-regulator" - In patch 03/14: - Use leds-class-multicolor.yaml instead of common.yaml. - Split multi-led and led node. - Add subdevice "led" in "multi-led". - In patch 04/14: - Remove the description of enum. - In patch 05/14: - Rename "mediatek,bled-pwm-hys-input-threshold-steps" to "mediatek,bled-pwm-hys-input-th-steps" - Refine "bled-pwm-hys-input-th-steps", "bled-ovp-microvolt", "bled-ocp-microamp" enum values - In patch 06/14: - Use " in entire patchset - Refine ADC description - Rename "enable-gpio" to "enable-gpios" in "regualtor" - In patch 07/14: - Refine Kconfig help text - Refine error message of unknown vendor ID in mt6370_check_vendor_info() - Refine return value handling of mt6370_regmap_read() - Refine all probe error by using dev_err_probe() - Refine "bank_idx" and "bank_addr" in mt6370_regmap_read() and mt6370_regmap_write() - Add "#define VENID*" and drop the comments in mt6370_check_vendor_info() - Drop "MFD" in MODULE_DESCRIPTION() - In patch 09/14: - Refine Kconfig help text - In patch 10/14: - Refine Kconfig help text - Refine all channel value in read_scale() a. current: uA --> mA b. voltage: uV --> mV c. temperature: degrees Celsius --> milli degrees Celsius - Add "default:" condition of switch statement in read_scale() and read_raw() - Add error message for reading ADC register failed - Add the comment for adc_lock - Add header file for struct of_device_id - Replace "adc" text with "ADC" in all of the error messages - In patch 12/14: - Refine the grammer of the Kconfig. - Change reg mode to the const current mode. - In patch 14/14: - Refine bool properties parsing (pwm-enable, ovp-shutdown, ocp-shutdown) in DT parsing function - Refine u32 and u8 properties parsing (pwm-hys-input-th-steps, ovp-microvolt, ocp-microamp), from using register value to using actual value - Refine error string of "channle-use" parsing failed - Refine Kconfig help text Changes in v2: - In patch 01/15: - Add "unevaluatedProperties: false". - Delete "DT bindings". - Refine the description to fit in 80 columns. - Skip the connector description. - In patch 02/15: - Refine items description of interrupt-name - Rename "usb-otg-vbus" to "usb-otg-vbus-regulator" - Add constraint properties for ADC - In patch 03/15: - Skip not useful description of "^(multi-)?led@[0-3]$" and reg. - Due to the dependency, remove the mention of mfd document directory. - Delete Soft-start property. In design aspect, we think soft-restart should always be enabled, our new chip has deleted the related setting register , also, we don’t allow user adjust this parameter in this chip. - Refine the commit message. - In patch 04/15: - Skip not useful description of "^led@[0-1]$" and reg. - Add apace after '#'. - Refine the commit message. - In patch 05/15: - Remove "binding documentation" in subject title - Refine description of mt6370 backlight binding document - Refine properties name(bled-pwm-hys-input-bit, bled-ovp-microvolt, bled-ocp-microamp) and their description - In patch 06/15: - Refine ADC and Regulator descriptions - Refine include header usage in example - Refine node name to generic node name("pmic@34") - Refine led example indentation - Refine license of mediatek,mt6370_adc.h - Rename the dts example from IRQ define to number. - Remove mediatek,mt6370.h - In patch 07/15: - Add ABI documentation for mt6370 non-standard ADC sysfs interfaces. - In patch 08/15: - Add all IRQ define into mt6370.c. - Refine include header usage - In patch 09/15: - No changes. - In patch 10/15: - Use 'gpiod_get_from_of_node' to replace 'fwnode_gpiod_get_index'. - In patch 11/15: - Refine Kconfig mt6370 help text - Refine mask&shift to FIELD_PREP() - Refine mutex lock name ("lock" -> "adc_lock") - Refine mt6370_adc_read_scale() - Refine mt6370_adc_read_offset() - Refine mt6370_channel_labels[] by using enum to index chan spec - Refine MT6370_ADC_CHAN() - Refine indio_dev->name - Remove useless include header files - In patch 12/15: - Refine mt6370_chg_otg_rdesc.of_match ("mt6370,otg-vbus" -> "usb-otg-vbus-regulator") to match DT binding - In patch 13/15: - Refine Kconfig description. - Remove include "linux/of.h" and use "linux/mod_devicetable.h". - Place a comma for the last element of the const unsigned int array. - Add a comment line for the mutex 'lock'. - In probe function, use 'dev_err_probe' in some judgement to reduce the LOC. - Refine include header usage. BIT/GENMASK -> linux/bits.h FIELD_GET -> linux/bitfield.h - In patch 14/15: - Add blank line. - Replace container_of() with to_mt6370_led() . - Refine description of ramping. - Refine the mt6370_init_common_properties function. - Refine the probe return. - In patch 15/15: - Refine MT6370 help text in Kconfig - Refine DT Parse function - Remove useless enum - Add comment for 6372 backward compatible in bl_update_status() and check_vendor_info() - Using dev_err_probe(); insteads dev_err()&return; in the probe() Alice Chen (2): dt-bindings: leds: Add MediaTek MT6370 flashlight leds: flashlight: mt6370: Add MediaTek MT6370 flashlight support ChiYuan Huang (7): dt-bindings: usb: Add MediaTek MT6370 TCPC dt-bindings: leds: mt6370: Add MediaTek MT6370 current sink type LED indicator dt-bindings: backlight: Add MediaTek MT6370 backlight dt-bindings: mfd: Add MediaTek MT6370 mfd: mt6370: Add MediaTek MT6370 support usb: typec: tcpci_mt6370: Add Mediatek MT6370 tcpci driver leds: mt6370: Add MediaTek MT6370 current sink type LED Indicator support ChiaEn Wu (4): dt-bindings: power: supply: Add MediaTek MT6370 Charger iio: adc: mt6370: Add MediaTek MT6370 support power: supply: mt6370: Add MediaTek MT6370 charger driver video: backlight: mt6370: Add MediaTek MT6370 support .../leds/backlight/mediatek,mt6370-backlight.yaml | 92 ++ .../bindings/leds/mediatek,mt6370-flashlight.yaml | 41 + .../bindings/leds/mediatek,mt6370-indicator.yaml | 77 ++ .../devicetree/bindings/mfd/mediatek,mt6370.yaml | 280 ++++++ .../power/supply/mediatek,mt6370-charger.yaml | 88 ++ .../bindings/usb/mediatek,mt6370-tcpc.yaml | 36 + drivers/iio/adc/Kconfig | 12 + drivers/iio/adc/Makefile | 1 + drivers/iio/adc/mt6370-adc.c | 273 +++++ drivers/leds/Kconfig | 14 + drivers/leds/Makefile | 1 + drivers/leds/flash/Kconfig | 12 + drivers/leds/flash/Makefile | 1 + drivers/leds/flash/leds-mt6370-flash.c | 661 ++++++++++++ drivers/leds/leds-mt6370.c | 994 ++++++++++++++++++ drivers/mfd/Kconfig | 16 + drivers/mfd/Makefile | 1 + drivers/mfd/mt6370.c | 281 ++++++ drivers/mfd/mt6370.h | 99 ++ drivers/power/supply/Kconfig | 14 + drivers/power/supply/Makefile | 1 + drivers/power/supply/mt6370-charger.c | 1062 ++++++++++++++++++++ drivers/usb/typec/tcpm/Kconfig | 11 + drivers/usb/typec/tcpm/Makefile | 1 + drivers/usb/typec/tcpm/tcpci_mt6370.c | 207 ++++ drivers/video/backlight/Kconfig | 12 + drivers/video/backlight/Makefile | 1 + drivers/video/backlight/mt6370-backlight.c | 339 +++++++ include/dt-bindings/iio/adc/mediatek,mt6370_adc.h | 18 + 29 files changed, 4646 insertions(+) create mode 100644 Documentation/devicetree/bindings/leds/backlight/mediatek,mt6370-backlight.yaml create mode 100644 Documentation/devicetree/bindings/leds/mediatek,mt6370-flashlight.yaml create mode 100644 Documentation/devicetree/bindings/leds/mediatek,mt6370-indicator.yaml create mode 100644 Documentation/devicetree/bindings/mfd/mediatek,mt6370.yaml create mode 100644 Documentation/devicetree/bindings/power/supply/mediatek,mt6370-charger.yaml create mode 100644 Documentation/devicetree/bindings/usb/mediatek,mt6370-tcpc.yaml create mode 100644 drivers/iio/adc/mt6370-adc.c create mode 100644 drivers/leds/flash/leds-mt6370-flash.c create mode 100644 drivers/leds/leds-mt6370.c create mode 100644 drivers/mfd/mt6370.c create mode 100644 drivers/mfd/mt6370.h create mode 100644 drivers/power/supply/mt6370-charger.c create mode 100644 drivers/usb/typec/tcpm/tcpci_mt6370.c create mode 100644 drivers/video/backlight/mt6370-backlight.c create mode 100644 include/dt-bindings/iio/adc/mediatek,mt6370_adc.h -- 2.7.4 From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id DC008C43334 for ; Fri, 15 Jul 2022 11:28:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-Id:Date:Subject:Cc :To:From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=KMB88Li48nDqGDe0k6LGd8fEJuq5sztclrFDjUGqhko=; b=CruvKKrr1xOxGC aOykky7fzgT17lG3+2xSgTReSo9uSyp4fJyILgMLk2NxXkAKt8DPaQYkebLiZ0c75x7omAgfm8dEF S73PoMFby8BOBzdDS4c4BmPsszWvL1wP+UQjJFvu7tBxSX/ZT6Abz1oXOeCgZJeWIbdPRXMnmZ/XX 3vo1fMmK3JA5eE9g9tyqSup6gWT33VsYRTNdYIlLdK9dwgk0tQyKOUppYlm3Dzg6hiY8CofGjtD1I QNI0JId4FWY+YK9AOEmMRipNJOUmQ2uiyMsrwcOONPneK1XHHDHgEC5EKvhK++haNG08CAYMIrKJi 2CIpRQqxZ7D8k02p5uNQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1oCJSo-006Yep-Dq; Fri, 15 Jul 2022 11:26:30 +0000 Received: from mail-pl1-x635.google.com ([2607:f8b0:4864:20::635]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1oCJSk-006YcC-6Z; Fri, 15 Jul 2022 11:26:28 +0000 Received: by mail-pl1-x635.google.com with SMTP id c6so2981124pla.6; Fri, 15 Jul 2022 04:26:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=HUVakAht3QYDlCi6rTyHeuImXIMd379d6m8rZFlB3sH4E5dxdvR2GCC4cEqBq0hWHO 3mZAFFKklsIBUVZeEziNcYCKl3zu29jSR49coEkq/NEsl8fliMu4Gps15q5kYqP7H2x2 pBJFKtAwkAm0YIsjRhHfrikU+jVoPijPUxfVIVn4JjFXKSyP/NBe/eprcI6/hgR03rQJ ETmc1N5Q2qEArmwE5va/IgZTPbmV9zI22+JK2uCOFMjlRhq72MCfo1oJCOvIr7sI8vRB fkkJ6hSHZzzEKAWLjQfbpocJ6mU2MF42oDM8TC5eEwin4rpIj5+HZnjfPYFWo1igXxvk ylpg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gxyNAIdF8uVow3H1XhXBwg96o/plsRwQuCipoy5Ry9E=; b=ls9Bx0GM5AErOCSiDbWx+mdG6mXVqBreyCXfIj6f8dcLKh0Z1Lgwg1aiadee3x8m2r JJI5mQmiLJq7rIMltREnKWEp0WiQmB1bKDJqnj0wtZueedP+L+qiktA2aDIa0HiLeovS dPQEZJFxoTDBSWLtsHopj7W+FFeQewgaQRKQ59e05DAtvU+Nu9QrAbxO267UmgTSkkwY cOwhZyVKOU2YFgXPNQM2bFk7s0g41h+N7Mq9wTni1BR8bYSf5gY2hnB++uZsWUlRJWwp bYssgQIqLUFiWolGiAqrn9tBmyPt+DAdcEEeTrRR5/EK3ruXzYA5Q0nk9Jp6+iIbmPGU foAg== X-Gm-Message-State: AJIora9lFCU69sPkiDh4Di8dT1U49KIm4vCp83cBJmFBoajiwbhlM6J0 pffVkAqjWaTQpX52KQOtZvU= X-Google-Smtp-Source: AGRyM1vAeOtUIfstbiXdFTS8IM2qsuNBcIlE5ZGLviTu+LOg0TWAQB6D3c0+uhw6k8SiuBspFKiMsA== X-Received: by 2002:a17:902:7487:b0:16b:d8ae:7e33 with SMTP id h7-20020a170902748700b0016bd8ae7e33mr12804578pll.21.1657884382451; Fri, 15 Jul 2022 04:26:22 -0700 (PDT) Received: from RD-3580-24288.rt.l (42-72-159-86.emome-ip.hinet.net. [42.72.159.86]) by smtp.gmail.com with ESMTPSA id a5-20020aa78e85000000b00525b61f4792sm3550604pfr.109.2022.07.15.04.26.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Jul 2022 04:26:21 -0700 (PDT) From: ChiaEn Wu To: lee.jones@linaro.org, daniel.thompson@linaro.org, jingoohan1@gmail.com, pavel@ucw.cz, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, matthias.bgg@gmail.com, sre@kernel.org, chunfeng.yun@mediatek.com, gregkh@linuxfoundation.org, jic23@kernel.org, lars@metafoo.de, lgirdwood@gmail.com, broonie@kernel.org, linux@roeck-us.net, heikki.krogerus@linux.intel.com, deller@gmx.de Cc: chiaen_wu@richtek.com, alice_chen@richtek.com, cy_huang@richtek.com, dri-devel@lists.freedesktop.org, linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, linux-usb@vger.kernel.org, linux-iio@vger.kernel.org, linux-fbdev@vger.kernel.org, szunichen@gmail.com Subject: [PATCH v5 00/13] Add MediaTek MT6370 PMIC support Date: Fri, 15 Jul 2022 19:25:54 +0800 Message-Id: <20220715112607.591-1-peterwu.pub@gmail.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220715_042626_279968_73D16952 X-CRM114-Status: GOOD ( 21.87 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org RnJvbTogQ2hpYUVuIFd1IDxjaGlhZW5fd3VAcmljaHRlay5jb20+CgpUaGlzIHBhdGNoIHNlcmll cyBhZGQgTWVkaWFUZWsgTVQ2MzcwIFBNSUMgc3VwcG9ydC4gVGhlIE1UNjM3MCBpcyBhCmhpZ2hs eS1pbnRlZ3JhdGVkIHNtYXJ0IHBvd2VyIG1hbmFnZW1lbnQgSUMsIHdoaWNoIGluY2x1ZGVzIGEg c2luZ2xlCmNlbGwgTGktSW9uL0xpLVBvbHltZXIgc3dpdGNoaW5nIGJhdHRlcnkgY2hhcmdlciwg YSBVU0IKVHlwZS1DICYgUG93ZXIgRGVsaXZlcnkgKFBEKSBjb250cm9sbGVyLCBkdWFsIEZsYXNo IExFRCBjdXJyZW50IHNvdXJjZXMsCmEgUkdCIExFRCBkcml2ZXIsIGEgYmFja2xpZ2h0IFdMRUQg ZHJpdmVyLCBhIGRpc3BsYXkgYmlhcyBkcml2ZXIgYW5kIGEKZ2VuZXJhbCBMRE8gZm9yIHBvcnRh YmxlIGRldmljZXMuCgpJbiB0aGlzIHNlcmllcyBvZiBwYXRjaGVzLCB3ZSBiYXNlZCBvbiBBbmR5 IFNoZXZjaGVua28ncyBtZmQgcGF0Y2ggdXNlZCB0bwphZGp1c3QgdGhlIE1ha2VmaWxlIG9yZGVy LgooaHR0cHM6Ly9sb3JlLmtlcm5lbC5vcmcvYWxsLzIwMjIwNjE2MTgyNTI0Ljc5NTYtMi1hbmRy aXkuc2hldmNoZW5rb0BsaW51eC5pbnRlbC5jb20vKQpBbW9uZyB3aXRoIHRoaXMsIHdlIHRvb2sg c29tZSBjaGFuZ2VzIGZvciBNVDYzNzAgYW5kIHJlZmluZWQgdGhlIE1UNjM3MCBkZXZpY2UKdHJl ZSBmaWxlcyB0byBjb21wbHkgd2l0aCBEVCBzcGVjaWZpY2F0aW9ucy4KCiJbUEFUQ0ggdjUgMDYv MTNdIGR0LWJpbmRpbmdzOiBtZmQ6IEFkZCBNZWRpYVRlayBNVDYzNzAiIGRlcGVuZHMgb24gcHJl dmlvdXMKRFQgYmluZGluZyBwYXRjaGVzLCBzbyBiZWZvcmUgYXBwbHlpbmcgdGhpcyBwYXRjaCwg cGxlYXNlIGFwcGx5IG90aGVyIERUCnBhdGNoZXMgZmlyc3QuIFRoYW5rcyEKClRoYW5rIHlvdSwK Q2hpYUVuIFd1CgotLS0KQ2hhbmdlcyBpbiB2NToKLSBJbiBwYXRjaCAwNy8xMzoKCS0gQWRkIHRo ZSBjb21tYSBpbiB0aGUgbGFzdCBSRUdNQVBfSVJRX1JFR19MSU5FKCksCgkgICBERUZJTkVfUkVT X0lSUV9OQU1FRCgpIGFuZCBNRkRfQ0VMTF9SRVMoKQoJLSBBZGQgdGhlIHByZWZpeCBpbiB0aGUg Zmlyc3QgcGFyYW1ldGVyIG9mIGFsbCBtZmRfY2VsbAoJLSBNb3ZlIGVudW0gYW5kIHN0cnVjdCBt dDYzNzBfaW5mbyB0byBtdDYzNzAuaAoJLSBSZW1vdmUgc3RydWN0IGRldmljZSAqZGV2IGluIHN0 cnVjdCBtdDYzNzBfaW5mbwoJLSBSZXZpc2UgdGhlIGRlc2NyaXB0aW9uIG9mIEtjb25maWcgaGVs cCB0ZXh0CgktIFJldmlzZSBNT0RVTEVfREVTQ1JJUFRJT04oKQoKLSBJbiBwYXRjaCAwOC8xMzoK CS0gQWRkIGNvbW1hIGZvciB0aGUgbGFzdCBpbmRleCBvZiBtdDYzNzBfcmVnX2luaXQuCgktIFVz ZSBkZXZfZXJyX3Byb2JlIHRvIGRlY3JlYXNlIExPQy4KCS0gVXNlICdkZXYnIHZhcmlhYmxlIHRv IG1ha2UgcHJvYmUgZnVuY3Rpb24gbW9yZSBjbGVhbi4KCS0gUmVmaW5lIGtjb25maWcgdGV4dC4K CS0gUmVtb3ZlIGJvdGggJ2Vsc2UnIGluIHNldF92YnVzIGNhbGxiYWNrLgoJLSBSZW1vdmUgY29t bWEgZm9yIG9mX2RldmljZV9pZCBpZiB0aGUgYXNzaWduZWQgbWVtYmVyIGlzIG9ubHkgb25lLgoK LSBJbiBwYXRjaCAwOS8xMzoKCS0gUmVwbGFjZSB1c2luZyBzbnByaW50ZigpIHdpdGggc3lzZnNf ZW1pdCgpIGluIG10NjM3MF9hZGNfcmVhZF9sYWJlbCgpCgktIFJlbW92ZSBtYWNybyBBRENfQ09O Vl9USU1FX1VTCgktIFJldmlzZSBhbGwgdmFyaWFibGUgb3JkZXJpbmcKCS0gUmV2aXNlIHRoZSBk ZXNjcmlwdGlvbiBvZiBLY29uZmlnIGhlbHAgdGV4dAoJLSBSZXZpc2UgTU9EVUxFX0RFU0NSSVBU SU9OKCkKCi0gSW4gcGF0Y2ggMTAvMTM6CgktIFJlcGxhY2UgdW5zaWduZWQgaW50IHR5cGUgb2Yg cHdyX3JkeSB3aXRoIGJvb2wgaW4KCSAgIG10NjM3MF9jaGdfc2V0X29ubGluZSgpCgktIFJlbW92 ZSByZWR1bmRhbnQgJ2Vsc2UnIGluIG10NjM3MF9jaGdfZmllbGRfZ2V0KCkKCS0gUmV2aXNlICdp Zi1lbHNlJyBpbiBtdDYzNzBfY2hnX2ZpZWxkX3NldCgpCgktIFJldmlzZSAnaWYnIGNvbmRpdGlv biBpbiBtdDYzNzBfY2hnX2VuYWJsZV9pcnEoKQoJLSBSZXZpc2UgYWxsIHRleHQgJ290ZycgLS0+ ICdPVEcnCgktIFJldmlzZSBNVDYzNzBfTUlWUl9JQlVTX1RIXzEwMF9NQSAtLT4gTVQ2MzcwX01J VlJfSUJVU19USF8xMDBfbUEKCS0gUmV2aXNlIHRoZSBkZXNjcmlwdGlvbiBvZiBLY29uZmlnIGhl bHAgdGV4dAoKLSBJbiBwYXRjaCAxMi8xMzoKCS0gUmVmaW5lIGRlc2NyaXB0aW9ucy4KCS0gUmVm aW5lIHRoZSBtYWNybyBuYW1lLgoJLSBSZWZpbmUgdGhlIGJyYWNrZXQgYW5kIGJsYW5rcy4KCi0g SW4gcGF0Y2ggMTMvMTM6CgktIEFkZCBtaXNzZWQgPG1vZF9kZXZpY2V0YWJsZS5oPgoJLSBBZGQg c3RydWN0IGRldmljZSAqZGV2IGluIHByb2JlKCkgdG8gbWFrZSBjb2RlIGNsZWFuaW5nCgktIFJl bW92ZSB1c2VsZXNzIGluY2x1ZGluZyBoZWFkZXIgZmlsZSA8Z3Bpby9kcml2ZXIuaD4sIDxvZi5o PgoJLSBSZW1vdmUgdXNlbGVzcyB2YXJpYWJsZSB1YXNhZ2UgaW4gbXQ2MzcwX2luaXRfYmFja2xp Z2h0X3Byb3BlcnRpZXMoKQoJLSBSZW1vdmUgcmVkdW5kYW50IGNoZWNraW5nIGVuYWJsZV9ncGlv IGluIG10NjM3MF9ibF91cGRhdGVfc3RhdHVzKCkKCS0gUmVtb3ZlIHJlZHVuZGFudCBwYXJlbnRo ZXNlcyBpbiBtdDYzNzBfYmxfZ2V0X2JyaWdodG5lc3MoKQoJLSBSZXZpc2UgdGhlIGRlc2NyaXB0 aW9uIG9mIEtjb25maWcgaGVscCB0ZXh0CgktIFJldmlzZSB0aGUgY2FsY3VsYXRpb24gb2YgaHlz X3RoX3N0ZXBzCgoKQ2hhbmdlcyBpbiB2NDoKLSBJbiBwYXRjaCAwMi8xMzoKCS0gQWRkIG1pbkl0 ZW1zIG9mICJpby1jaGFubmVsLW5hbWVzIgoJLSBSZXBsYWNlIHRleHQgIk1lZGlhdGVrIiB3aXRo ICJNZWRpYVRlayIKCi0gSW4gcGF0Y2ggMDYvMTM6CgktIFJvbGwgYmFjayBhbGwgIiRyZWY6ICIg dG8gdjIgcGF0Y2ggc3R5bGUgKHVzaW5nICIvc2NoZW1hcy8uLi4iKQoKLSBJbiBwYXRjaCAwNy8x MzoKCS0gUmVwbGFjZSB0ZXh0ICJNZWRpYXRlayIgd2l0aCAiTWVkaWFUZWsiIGluIEtjb25maWcK CS0gUmVwbGFjZSAiZmlyc3QgYnJlYWsgYW5kIHRoZW4gcmV0dXJuIiB3aXRoICJyZXR1cm4gZGly ZWN0bHkiCgkgICBpbiAibXQ2MzcwX2NoZWNrX3ZlbmRvcl9pbmZvKCkiCgktIEFkZCBtb2R1bGUg bmFtZSByZWxhdGVkIGRlc2NyaXB0aW9uIGluIEtjb25maWcgaGVscHRleHQKCS0gQWRkIENvcHly aWdodCBpbiB0aGUgc291cmNlIGNvZGUKCS0gQWRkIGhlYWRlciBmaWxlICJtdDYzNzAuaCIgZm9y IGFsbCAiI2RlZmluZSBJUlEiCgktIEFkanVzdCBNYWtlZmlsZSBvcmRlciBvZiBNVDYzNzAKCS0g UmVmaW5lICJiYW5rX2lkeCIgYW5kICJiYW5rX2FkZHIiIGluCgkgICJtdDYzNzVfcmVnbWFwX3Jl YWQoKSIgLyAibXQ2Mzc1X3JlZ21hcF93cml0ZSgpIgoJLSBSZWZpbmUgcmVkdW5kYW50ICJlbHNl IGlmIiBpbiAibXQ2MzcwX3JlZ21hcF9yZWFkKCkiCgotIEluIHBhdGNoIDA4LzEzOgoJLSBSZXBs YWNlIHRleHQgIk1lZGlhdGVrIiB3aXRoICJNZWRpYVRlayIgaW4gS2NvbmZpZwoJLSBSZXBsYWNl ICJmaXJzdCByZXQ9cmVndWxhdG9yXyhkaXMvZW4pYWJsZSBhbmQgdGhlbiByZXR1cm4iCgkgICB3 aXRoICJyZXR1cm4gZGlyZWN0bHkiIGluICJtdDYzNzBfdGNwY19zZXRfdmJ1cygpIgoJLSBSZXBs YWNlIGhlYWRlciBmaWxlIDxsaW51eC9vZi5oPiB3aXRoIDxsaW51eC9tb2RfZGV2aWNldGFibGUu aD4KCS0gQWRkIENvcHlyaWdodCBpbiB0aGUgc291cmNlIGNvZGUKCS0gQWRkIG1vZHVsZSBuYW1l IHJlbGF0ZWQgZGVzY3JpcHRpb24gaW4gS2NvbmZpZyBoZWxwdGV4dAoJLSBSZW1vdmUgaGVhZGVy IGZpbGUgPGxpbnV4L29mLmg+CgktIFJlZmluZSBhbGwgcHJvYmUgZXJyb3IgYnkgdXNpbmcgZGV2 X2Vycl9wcm9iZSgpCgotIEluIHBhdGNoIDA5LzEzOgoJLSBSZXBsYWNlIHRleHQgIk1lZGlhdGVr IiB3aXRoICJNZWRpYVRlayIKCS0gUmVwbGFjZSBhbGwgImZpcnN0IGRldl9lcnIoKSBhbmQgdGhl biByZXR1cm4iIHdpdGgKCSAgICJyZXR1cm4gZGV2X2Vycl9wcm9iZSgpIgoJLSBBZGQgQ29weXJp Z2h0IGluIHRoZSBzb3VyY2UgY29kZQoJLSBBZGQgbW9kdWxlIG5hbWUgcmVsYXRlZCBkZXNjcmlw dGlvbiBpbiBLY29uZmlnCgktIEFkZCB1bml0IHN1ZmZpeCBvZiBtYWNybyAiQURDX0NPTlZfUE9M TElOR19USU1FIgoJLSBBZGQgbmV3IG1hY3JvICJBRENfQ09OVl9USU1FX01TIgoJLSBBZGp1c3Qg dGhlIHBvc2l0aW9uIG9mIGluY2x1ZGUgZmlsZSA8bWVkaWF0ZWssbXQ2MzcwX2FkYy5oPgoJLSBB ZGp1c3QgdGhlIHBvc3Rpb25zIGJldHdlZW4gPGxpbnV4L21vZHVsZS5oPiBhbmQKCSAgIDxsaW51 eC9tb2RfZGV2aWNldGFibGUuaD4KCS0gRml4IHNvbWUgaW5jb3JyZWN0IGNoYXJhY3RlcnMKCi0g SW4gcGF0Y2ggMTAvMTM6CgktIFJlcGxhY2UgdGV4dCAiTWVkaWF0ZWsiIHdpdGggIk1lZGlhVGVr IiBpbiBLY29uZmlnIGFuZAoJICAgTU9EVUxFX0RFU0NSSVBUSU9OKCkKCS0gUmVwbGFjZSAibXQ2 MzcwX2NoZ192YWxfdG9fcmVnIiBhbmQgIm10NjM3MF9jaGdfcmVnX3RvX3ZhbCIKCSAgIHdpdGgg ImxpbmVhcl9yYW5nZSIgQVBJCgktIFJlcGxhY2UgImZpcnN0IGJyZWFrIGFuZCB0aGVuIHJldHVy biIgd2l0aCAicmV0dXJuIGRpcmVjdGx5IgoJICAgaW4gYWxsIGNhc2VzIG9mIGdldC9zZXQgcG93 ZXJfc3VwcGx5X3Byb3BlcnR5CgktIFJlcGxhY2UgYWxsICJmaXJzdCBkZXZfZXJyKCkgYW5kIHRo ZW4gcmV0dXJuIiB3aXRoICJyZXR1cm4KCSAgIGRldl9lcnJfcHJvYmUoKSIKCS0gUmVwbGFjZSBh bGwgInJldHVybiBJU19FUlIocHJpdi0+cmRldikgPyBQVFJfRVJSKHByaXYtPnJkZXYpIDogMCIK CSAgIHdpdGggIlBUUl9FUlJfT1JfWkVSTygpIgoJLSBSZXBsYWNlICJwcml2LT5kZXYtPm9mX25v ZGUiIHdpdGggImRldl9vZl9ub2RlKCkiCgktIEFkZCBDb3B5cmlnaHQgaW4gdGhlIHNvdXJjZSBj b2RlCgktIEFkZCBtb2R1bGUgbmFtZSByZWxhdGVkIGRlc2NyaXB0aW9uIGluIEtjb25maWcgaGVs cHRleHQKCS0gQWRkIHByb3BlciB1bml0IG9mICJNVDYzNzBfTUlWUl9JQlVTX1RIIgoJLSBBZGQg ZXJyb3IgY2hlY2sgaW4gIm10NjM3MF9jaGdfZ2V0X3N0YXR1cyIKCS0gUmVtb3ZlIGluY2x1ZGlu ZyA8bWVkaWF0ZWssbXQ2MzcwX2FkYy5oPiBoZWFkZXIgZmlsZQoJLSBSZW1vdmUgcmVkdW5kYW50 IGNvbW1hIG9mIGV2ZXJ5IGVudW0gdGVybWluYXRvciBsaW5lCgktIFJlbW92ZSB1bndhbnRlZCBi bGFuayBsaW5lcwoJLSBSZW1vdmUgdGhlIHVzZWxlc3MgbGFiZWwgKHRvZ2dsZV9jZm9fZXhpdDop CgktIFJlbW92ZSB1c2luZyBhdG9taWMKCS0gUmVtb3ZlIHVzaW5nIG9mX21hdGNoX3B0cigpCgkt IEZpeCBzb21lIGluY29ycmVjdCBjaGFyYWN0ZXJzCgktIEZpeCB1cGRhdGluZyB3cm9uZyBiaXRz IHdoZW4gdXNpbmcgZW5hX2dwaW9kIG9mIE9URyByZWd1bGF0b3IKCS0gQWRqdXN0IHRoZSBwcm9i ZSBvcmRlciBpbiBwcm9iZSgpCgotIEluIHBhdGNoIDExLzEzOgoJLSBSZXBsYWNlIHRleHQgIk1l ZGlhdGVrIiB3aXRoICJNZWRpYVRlayIgaW4gS2NvbmZpZwoJLSBSZXBsYWNlIHRleHQgImNvbnN0 IiB3aXRoICJjb25zdGFudCIgaW4gS2NvbmZpZwoJLSBBZGQgQ29weXJpZ2h0IGluIHRoZSBzb3Vy Y2UgY29kZQoKLSBJbiBwYXRjaCAxMi8xMzoKCS0gUmVwbGFjZSB0ZXh0ICJNZWRpYXRlayIgd2l0 aCAiTWVkaWFUZWsiIGluIEtjb25maWcKCS0gQWRkIENvcHlyaWdodCBpbiB0aGUgc291cmNlIGNv ZGUKCi0gSW4gcGF0Y2ggMTMvMTM6CgktIFJlcGxhY2UgdGV4dCAiTWVkaWF0ZWsiIHdpdGggIk1l ZGlhVGVrIiBpbiBLY29uZmlnCgktIEFkZCBDb3B5cmlnaHQgaW4gdGhlIHNvdXJjZSBjb2RlCgkt IFJldmlzZSB0aGUgY29tbWVudCBvZiAiUFdNIEhZUyBTVEVQUyIKCgpDaGFuZ2VzIGluIHYzOgot IFJlbW92ZSBBREMgQUJJIGZpbGUsIHdoaWNoIGlzIGFkZGVkIGluIHYyIFBhdGNoIDcKLSBJbiBw YXRjaCAwMi8xNDoKCS0gQWRkIGl0ZW1zIGFuZCByZW1vdmUgbWF4SXRlbXMgb2YgaW8tY2hhbm5l bHMKCS0gQWRkIGlvLWNoYW5uZWwtbmFtZXMgYW5kIGRlc2NyaWJlIGVhY2ggaXRlbQoJLSBBZGQg InVuZXZhbHVhdGVkUHJvcGVydGllczogZmFsc2UiIGluICJ1c2Itb3RnLXZidXMtcmVndWxhdG9y IgoJLSBSZW5hbWUgImVuYWJsZS1ncGlvIiB0byAiZW5hYmxlLWdwaW9zIiBpbiAidXNiLW90Zy12 YnVzLXJlZ3VsYXRvciIKLSBJbiBwYXRjaCAwMy8xNDoKCS0gVXNlIGxlZHMtY2xhc3MtbXVsdGlj b2xvci55YW1sIGluc3RlYWQgb2YgY29tbW9uLnlhbWwuCgktIFNwbGl0IG11bHRpLWxlZCBhbmQg bGVkIG5vZGUuCgktIEFkZCBzdWJkZXZpY2UgImxlZCIgaW4gIm11bHRpLWxlZCIuCi0gSW4gcGF0 Y2ggMDQvMTQ6CgktIFJlbW92ZSB0aGUgZGVzY3JpcHRpb24gb2YgZW51bS4KLSBJbiBwYXRjaCAw NS8xNDoKCS0gUmVuYW1lICJtZWRpYXRlayxibGVkLXB3bS1oeXMtaW5wdXQtdGhyZXNob2xkLXN0 ZXBzIiB0bwoJICAibWVkaWF0ZWssYmxlZC1wd20taHlzLWlucHV0LXRoLXN0ZXBzIgoJLSBSZWZp bmUgImJsZWQtcHdtLWh5cy1pbnB1dC10aC1zdGVwcyIsICJibGVkLW92cC1taWNyb3ZvbHQiLAoJ ICAiYmxlZC1vY3AtbWljcm9hbXAiIGVudW0gdmFsdWVzCi0gSW4gcGF0Y2ggMDYvMTQ6CgktIFVz ZSAiIGluIGVudGlyZSBwYXRjaHNldAoJLSBSZWZpbmUgQURDIGRlc2NyaXB0aW9uCgktIFJlbmFt ZSAiZW5hYmxlLWdwaW8iIHRvICJlbmFibGUtZ3Bpb3MiIGluICJyZWd1YWx0b3IiCi0gSW4gcGF0 Y2ggMDcvMTQ6CgktIFJlZmluZSBLY29uZmlnIGhlbHAgdGV4dAoJLSBSZWZpbmUgZXJyb3IgbWVz c2FnZSBvZiB1bmtub3duIHZlbmRvciBJRCBpbgoJICBtdDYzNzBfY2hlY2tfdmVuZG9yX2luZm8o KQoJLSBSZWZpbmUgcmV0dXJuIHZhbHVlIGhhbmRsaW5nIG9mIG10NjM3MF9yZWdtYXBfcmVhZCgp CgktIFJlZmluZSBhbGwgcHJvYmUgZXJyb3IgYnkgdXNpbmcgZGV2X2Vycl9wcm9iZSgpCgktIFJl ZmluZSAiYmFua19pZHgiIGFuZCAiYmFua19hZGRyIiBpbiBtdDYzNzBfcmVnbWFwX3JlYWQoKSBh bmQKCSAgbXQ2MzcwX3JlZ21hcF93cml0ZSgpCgktIEFkZCAiI2RlZmluZSBWRU5JRCoiIGFuZCBk cm9wIHRoZSBjb21tZW50cyBpbgoJICBtdDYzNzBfY2hlY2tfdmVuZG9yX2luZm8oKQoJLSBEcm9w ICJNRkQiIGluIE1PRFVMRV9ERVNDUklQVElPTigpCi0gSW4gcGF0Y2ggMDkvMTQ6CgktIFJlZmlu ZSBLY29uZmlnIGhlbHAgdGV4dAotIEluIHBhdGNoIDEwLzE0OgoJLSBSZWZpbmUgS2NvbmZpZyBo ZWxwIHRleHQKCS0gUmVmaW5lIGFsbCBjaGFubmVsIHZhbHVlIGluIHJlYWRfc2NhbGUoKQoJCWEu IGN1cnJlbnQ6IHVBIC0tPiBtQQoJCWIuIHZvbHRhZ2U6IHVWIC0tPiBtVgoJCWMuIHRlbXBlcmF0 dXJlOiBkZWdyZWVzIENlbHNpdXMgLS0+IG1pbGxpIGRlZ3JlZXMgQ2Vsc2l1cwoJLSBBZGQgImRl ZmF1bHQ6IiBjb25kaXRpb24gb2Ygc3dpdGNoIHN0YXRlbWVudCBpbiByZWFkX3NjYWxlKCkgYW5k IHJlYWRfcmF3KCkKCS0gQWRkIGVycm9yIG1lc3NhZ2UgZm9yIHJlYWRpbmcgQURDIHJlZ2lzdGVy IGZhaWxlZAoJLSBBZGQgdGhlIGNvbW1lbnQgZm9yIGFkY19sb2NrCgktIEFkZCA8bGludXgvbW9k X2RldmljZXRhYmxlLmg+IGhlYWRlciBmaWxlIGZvciBzdHJ1Y3Qgb2ZfZGV2aWNlX2lkCgktIFJl cGxhY2UgImFkYyIgdGV4dCB3aXRoICJBREMiIGluIGFsbCBvZiB0aGUgZXJyb3IgbWVzc2FnZXMK LSBJbiBwYXRjaCAxMi8xNDoKCS0gUmVmaW5lIHRoZSBncmFtbWVyIG9mIHRoZSBLY29uZmlnLgoJ LSBDaGFuZ2UgcmVnIG1vZGUgdG8gdGhlIGNvbnN0IGN1cnJlbnQgbW9kZS4KLSBJbiBwYXRjaCAx NC8xNDoKCS0gUmVmaW5lIGJvb2wgcHJvcGVydGllcyBwYXJzaW5nIChwd20tZW5hYmxlLCBvdnAt c2h1dGRvd24sIG9jcC1zaHV0ZG93bikgaW4gRFQKCSAgcGFyc2luZyBmdW5jdGlvbgoJLSBSZWZp bmUgdTMyIGFuZCB1OCBwcm9wZXJ0aWVzIHBhcnNpbmcgKHB3bS1oeXMtaW5wdXQtdGgtc3RlcHMs IG92cC1taWNyb3ZvbHQsCgkgIG9jcC1taWNyb2FtcCksIGZyb20gdXNpbmcgcmVnaXN0ZXIgdmFs dWUgdG8gdXNpbmcgYWN0dWFsIHZhbHVlCgktIFJlZmluZSBlcnJvciBzdHJpbmcgb2YgImNoYW5u bGUtdXNlIiBwYXJzaW5nIGZhaWxlZAoJLSBSZWZpbmUgS2NvbmZpZyBoZWxwIHRleHQKCgpDaGFu Z2VzIGluIHYyOgotIEluIHBhdGNoIDAxLzE1OgoJLSBBZGQgInVuZXZhbHVhdGVkUHJvcGVydGll czogZmFsc2UiLgoJLSBEZWxldGUgIkRUIGJpbmRpbmdzIi4KCS0gUmVmaW5lIHRoZSBkZXNjcmlw dGlvbiB0byBmaXQgaW4gODAgY29sdW1ucy4KCS0gU2tpcCB0aGUgY29ubmVjdG9yIGRlc2NyaXB0 aW9uLgotIEluIHBhdGNoIDAyLzE1OgoJLSBSZWZpbmUgaXRlbXMgZGVzY3JpcHRpb24gb2YgaW50 ZXJydXB0LW5hbWUKCS0gUmVuYW1lICJ1c2Itb3RnLXZidXMiIHRvICJ1c2Itb3RnLXZidXMtcmVn dWxhdG9yIgoJLSBBZGQgY29uc3RyYWludCBwcm9wZXJ0aWVzIGZvciBBREMKLSBJbiBwYXRjaCAw My8xNToKCS0gU2tpcCBub3QgdXNlZnVsIGRlc2NyaXB0aW9uIG9mICJeKG11bHRpLSk/bGVkQFsw LTNdJCIKCSAgYW5kIHJlZy4KCS0gRHVlIHRvIHRoZSBkZXBlbmRlbmN5LCByZW1vdmUgdGhlIG1l bnRpb24gb2YgbWZkCgkgIGRvY3VtZW50IGRpcmVjdG9yeS4KCS0gRGVsZXRlIFNvZnQtc3RhcnQg cHJvcGVydHkuIEluIGRlc2lnbiBhc3BlY3QsIHdlIHRoaW5rCgkgIHNvZnQtcmVzdGFydCBzaG91 bGQgYWx3YXlzIGJlIGVuYWJsZWQsIG91ciBuZXcgY2hpcAoJICBoYXMgZGVsZXRlZCB0aGUgcmVs YXRlZCBzZXR0aW5nIHJlZ2lzdGVyICwgYWxzbywgd2UgZG9u4oCZdAoJICBhbGxvdyB1c2VyIGFk anVzdCB0aGlzIHBhcmFtZXRlciBpbiB0aGlzIGNoaXAuCgktIFJlZmluZSB0aGUgY29tbWl0IG1l c3NhZ2UuCi0gSW4gcGF0Y2ggMDQvMTU6CgktIFNraXAgbm90IHVzZWZ1bCBkZXNjcmlwdGlvbiBv ZiAiXmxlZEBbMC0xXSQiIGFuZCByZWcuCgktIEFkZCBhcGFjZSBhZnRlciAnIycuCgktIFJlZmlu ZSB0aGUgY29tbWl0IG1lc3NhZ2UuCi0gSW4gcGF0Y2ggMDUvMTU6CgktIFJlbW92ZSAiYmluZGlu ZyBkb2N1bWVudGF0aW9uIiBpbiBzdWJqZWN0IHRpdGxlCgktIFJlZmluZSBkZXNjcmlwdGlvbiBv ZiBtdDYzNzAgYmFja2xpZ2h0IGJpbmRpbmcKCSAgZG9jdW1lbnQKCS0gUmVmaW5lIHByb3BlcnRp ZXMgbmFtZShibGVkLXB3bS1oeXMtaW5wdXQtYml0LAoJICBibGVkLW92cC1taWNyb3ZvbHQsIGJs ZWQtb2NwLW1pY3JvYW1wKSBhbmQgdGhlaXIKCSAgZGVzY3JpcHRpb24KLSBJbiBwYXRjaCAwNi8x NToKCS0gUmVmaW5lIEFEQyBhbmQgUmVndWxhdG9yIGRlc2NyaXB0aW9ucwoJLSBSZWZpbmUgaW5j bHVkZSBoZWFkZXIgdXNhZ2UgaW4gZXhhbXBsZQoJLSBSZWZpbmUgbm9kZSBuYW1lIHRvIGdlbmVy aWMgbm9kZSBuYW1lKCJwbWljQDM0IikKCS0gUmVmaW5lIGxlZCBleGFtcGxlIGluZGVudGF0aW9u CgktIFJlZmluZSBsaWNlbnNlIG9mIG1lZGlhdGVrLG10NjM3MF9hZGMuaAoJLSBSZW5hbWUgdGhl IGR0cyBleGFtcGxlIGZyb20gSVJRIGRlZmluZSB0byBudW1iZXIuCgktIFJlbW92ZSBtZWRpYXRl ayxtdDYzNzAuaAotIEluIHBhdGNoIDA3LzE1OgoJLSBBZGQgQUJJIGRvY3VtZW50YXRpb24gZm9y IG10NjM3MCBub24tc3RhbmRhcmQgQURDCgkgIHN5c2ZzIGludGVyZmFjZXMuCi0gSW4gcGF0Y2gg MDgvMTU6CgktIEFkZCBhbGwgSVJRIGRlZmluZSBpbnRvIG10NjM3MC5jLgoJLSBSZWZpbmUgaW5j bHVkZSBoZWFkZXIgdXNhZ2UKLSBJbiBwYXRjaCAwOS8xNToKCS0gTm8gY2hhbmdlcy4KLSBJbiBw YXRjaCAxMC8xNToKCS0gVXNlICdncGlvZF9nZXRfZnJvbV9vZl9ub2RlJyB0byByZXBsYWNlCgkg ICdmd25vZGVfZ3Bpb2RfZ2V0X2luZGV4Jy4KLSBJbiBwYXRjaCAxMS8xNToKCS0gUmVmaW5lIEtj b25maWcgbXQ2MzcwIGhlbHAgdGV4dAoJLSBSZWZpbmUgbWFzayZzaGlmdCB0byBGSUVMRF9QUkVQ KCkKCS0gUmVmaW5lIG11dGV4IGxvY2sgbmFtZSAoImxvY2siIC0+ICJhZGNfbG9jayIpCgktIFJl ZmluZSBtdDYzNzBfYWRjX3JlYWRfc2NhbGUoKQoJLSBSZWZpbmUgbXQ2MzcwX2FkY19yZWFkX29m ZnNldCgpCgktIFJlZmluZSBtdDYzNzBfY2hhbm5lbF9sYWJlbHNbXSBieSB1c2luZyBlbnVtIHRv IGluZGV4CgkgIGNoYW4gc3BlYwoJLSBSZWZpbmUgTVQ2MzcwX0FEQ19DSEFOKCkKCS0gUmVmaW5l IGluZGlvX2Rldi0+bmFtZQoJLSBSZW1vdmUgdXNlbGVzcyBpbmNsdWRlIGhlYWRlciBmaWxlcwot IEluIHBhdGNoIDEyLzE1OgoJLSBSZWZpbmUgbXQ2MzcwX2NoZ19vdGdfcmRlc2Mub2ZfbWF0Y2gK CSAgKCJtdDYzNzAsb3RnLXZidXMiIC0+ICJ1c2Itb3RnLXZidXMtcmVndWxhdG9yIikgdG8gbWF0 Y2gKCSAgRFQgYmluZGluZwotIEluIHBhdGNoIDEzLzE1OgoJLSBSZWZpbmUgS2NvbmZpZyBkZXNj cmlwdGlvbi4KCS0gUmVtb3ZlIGluY2x1ZGUgImxpbnV4L29mLmgiIGFuZCB1c2UKCSAgImxpbnV4 L21vZF9kZXZpY2V0YWJsZS5oIi4KCS0gUGxhY2UgYSBjb21tYSBmb3IgdGhlIGxhc3QgZWxlbWVu dCBvZiB0aGUgY29uc3QKCSAgdW5zaWduZWQgaW50IGFycmF5LgoJLSBBZGQgYSBjb21tZW50IGxp bmUgZm9yIHRoZSBtdXRleCAnbG9jaycuCgktIEluIHByb2JlIGZ1bmN0aW9uLCB1c2UgJ2Rldl9l cnJfcHJvYmUnIGluIHNvbWUKCSAganVkZ2VtZW50IHRvIHJlZHVjZSB0aGUgTE9DLgoJLSBSZWZp bmUgaW5jbHVkZSBoZWFkZXIgdXNhZ2UuCgkgIEJJVC9HRU5NQVNLIC0+IGxpbnV4L2JpdHMuaAoJ ICBGSUVMRF9HRVQgLT4gbGludXgvYml0ZmllbGQuaAotIEluIHBhdGNoIDE0LzE1OgoJLSBBZGQg YmxhbmsgbGluZS4KCS0gUmVwbGFjZSBjb250YWluZXJfb2YoKSB3aXRoIHRvX210NjM3MF9sZWQo KSAuCgktIFJlZmluZSBkZXNjcmlwdGlvbiBvZiByYW1waW5nLgoJLSBSZWZpbmUgdGhlIG10NjM3 MF9pbml0X2NvbW1vbl9wcm9wZXJ0aWVzIGZ1bmN0aW9uLgoJLSBSZWZpbmUgdGhlIHByb2JlIHJl dHVybi4KLSBJbiBwYXRjaCAxNS8xNToKCS0gUmVmaW5lIE1UNjM3MCBoZWxwIHRleHQgaW4gS2Nv bmZpZwoJLSBSZWZpbmUgRFQgUGFyc2UgZnVuY3Rpb24KCS0gUmVtb3ZlIHVzZWxlc3MgZW51bQoJ LSBBZGQgY29tbWVudCBmb3IgNjM3MiBiYWNrd2FyZCBjb21wYXRpYmxlIGluCgkgIGJsX3VwZGF0 ZV9zdGF0dXMoKSBhbmQKCSAgY2hlY2tfdmVuZG9yX2luZm8oKQoJLSBVc2luZyBkZXZfZXJyX3By b2JlKCk7IGluc3RlYWRzIGRldl9lcnIoKSZyZXR1cm47IGluCgkgIHRoZSBwcm9iZSgpCgpBbGlj ZSBDaGVuICgyKToKICBkdC1iaW5kaW5nczogbGVkczogQWRkIE1lZGlhVGVrIE1UNjM3MCBmbGFz aGxpZ2h0CiAgbGVkczogZmxhc2hsaWdodDogbXQ2MzcwOiBBZGQgTWVkaWFUZWsgTVQ2MzcwIGZs YXNobGlnaHQgc3VwcG9ydAoKQ2hpWXVhbiBIdWFuZyAoNyk6CiAgZHQtYmluZGluZ3M6IHVzYjog QWRkIE1lZGlhVGVrIE1UNjM3MCBUQ1BDCiAgZHQtYmluZGluZ3M6IGxlZHM6IG10NjM3MDogQWRk IE1lZGlhVGVrIE1UNjM3MCBjdXJyZW50IHNpbmsgdHlwZSBMRUQKICAgIGluZGljYXRvcgogIGR0 LWJpbmRpbmdzOiBiYWNrbGlnaHQ6IEFkZCBNZWRpYVRlayBNVDYzNzAgYmFja2xpZ2h0CiAgZHQt YmluZGluZ3M6IG1mZDogQWRkIE1lZGlhVGVrIE1UNjM3MAogIG1mZDogbXQ2MzcwOiBBZGQgTWVk aWFUZWsgTVQ2MzcwIHN1cHBvcnQKICB1c2I6IHR5cGVjOiB0Y3BjaV9tdDYzNzA6IEFkZCBNZWRp YXRlayBNVDYzNzAgdGNwY2kgZHJpdmVyCiAgbGVkczogbXQ2MzcwOiBBZGQgTWVkaWFUZWsgTVQ2 MzcwIGN1cnJlbnQgc2luayB0eXBlIExFRCBJbmRpY2F0b3IKICAgIHN1cHBvcnQKCkNoaWFFbiBX dSAoNCk6CiAgZHQtYmluZGluZ3M6IHBvd2VyOiBzdXBwbHk6IEFkZCBNZWRpYVRlayBNVDYzNzAg Q2hhcmdlcgogIGlpbzogYWRjOiBtdDYzNzA6IEFkZCBNZWRpYVRlayBNVDYzNzAgc3VwcG9ydAog IHBvd2VyOiBzdXBwbHk6IG10NjM3MDogQWRkIE1lZGlhVGVrIE1UNjM3MCBjaGFyZ2VyIGRyaXZl cgogIHZpZGVvOiBiYWNrbGlnaHQ6IG10NjM3MDogQWRkIE1lZGlhVGVrIE1UNjM3MCBzdXBwb3J0 CgogLi4uL2xlZHMvYmFja2xpZ2h0L21lZGlhdGVrLG10NjM3MC1iYWNrbGlnaHQueWFtbCAgfCAg IDkyICsrCiAuLi4vYmluZGluZ3MvbGVkcy9tZWRpYXRlayxtdDYzNzAtZmxhc2hsaWdodC55YW1s ICB8ICAgNDEgKwogLi4uL2JpbmRpbmdzL2xlZHMvbWVkaWF0ZWssbXQ2MzcwLWluZGljYXRvci55 YW1sICAgfCAgIDc3ICsrCiAuLi4vZGV2aWNldHJlZS9iaW5kaW5ncy9tZmQvbWVkaWF0ZWssbXQ2 MzcwLnlhbWwgICB8ICAyODAgKysrKysrCiAuLi4vcG93ZXIvc3VwcGx5L21lZGlhdGVrLG10NjM3 MC1jaGFyZ2VyLnlhbWwgICAgICB8ICAgODggKysKIC4uLi9iaW5kaW5ncy91c2IvbWVkaWF0ZWss bXQ2MzcwLXRjcGMueWFtbCAgICAgICAgIHwgICAzNiArCiBkcml2ZXJzL2lpby9hZGMvS2NvbmZp ZyAgICAgICAgICAgICAgICAgICAgICAgICAgICB8ICAgMTIgKwogZHJpdmVycy9paW8vYWRjL01h a2VmaWxlICAgICAgICAgICAgICAgICAgICAgICAgICAgfCAgICAxICsKIGRyaXZlcnMvaWlvL2Fk Yy9tdDYzNzAtYWRjLmMgICAgICAgICAgICAgICAgICAgICAgIHwgIDI3MyArKysrKwogZHJpdmVy cy9sZWRzL0tjb25maWcgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfCAgIDE0ICsKIGRy aXZlcnMvbGVkcy9NYWtlZmlsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgICAgMSAr CiBkcml2ZXJzL2xlZHMvZmxhc2gvS2NvbmZpZyAgICAgICAgICAgICAgICAgICAgICAgICB8ICAg MTIgKwogZHJpdmVycy9sZWRzL2ZsYXNoL01ha2VmaWxlICAgICAgICAgICAgICAgICAgICAgICAg fCAgICAxICsKIGRyaXZlcnMvbGVkcy9mbGFzaC9sZWRzLW10NjM3MC1mbGFzaC5jICAgICAgICAg ICAgIHwgIDY2MSArKysrKysrKysrKysKIGRyaXZlcnMvbGVkcy9sZWRzLW10NjM3MC5jICAgICAg ICAgICAgICAgICAgICAgICAgIHwgIDk5NCArKysrKysrKysrKysrKysrKysKIGRyaXZlcnMvbWZk L0tjb25maWcgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgICAxNiArCiBkcml2ZXJz L21mZC9NYWtlZmlsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB8ICAgIDEgKwogZHJp dmVycy9tZmQvbXQ2MzcwLmMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfCAgMjgxICsr KysrKwogZHJpdmVycy9tZmQvbXQ2MzcwLmggICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg fCAgIDk5ICsrCiBkcml2ZXJzL3Bvd2VyL3N1cHBseS9LY29uZmlnICAgICAgICAgICAgICAgICAg ICAgICB8ICAgMTQgKwogZHJpdmVycy9wb3dlci9zdXBwbHkvTWFrZWZpbGUgICAgICAgICAgICAg ICAgICAgICAgfCAgICAxICsKIGRyaXZlcnMvcG93ZXIvc3VwcGx5L210NjM3MC1jaGFyZ2VyLmMg ICAgICAgICAgICAgIHwgMTA2MiArKysrKysrKysrKysrKysrKysrKwogZHJpdmVycy91c2IvdHlw ZWMvdGNwbS9LY29uZmlnICAgICAgICAgICAgICAgICAgICAgfCAgIDExICsKIGRyaXZlcnMvdXNi L3R5cGVjL3RjcG0vTWFrZWZpbGUgICAgICAgICAgICAgICAgICAgIHwgICAgMSArCiBkcml2ZXJz L3VzYi90eXBlYy90Y3BtL3RjcGNpX210NjM3MC5jICAgICAgICAgICAgICB8ICAyMDcgKysrKwog ZHJpdmVycy92aWRlby9iYWNrbGlnaHQvS2NvbmZpZyAgICAgICAgICAgICAgICAgICAgfCAgIDEy ICsKIGRyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L01ha2VmaWxlICAgICAgICAgICAgICAgICAgIHwg ICAgMSArCiBkcml2ZXJzL3ZpZGVvL2JhY2tsaWdodC9tdDYzNzAtYmFja2xpZ2h0LmMgICAgICAg ICB8ICAzMzkgKysrKysrKwogaW5jbHVkZS9kdC1iaW5kaW5ncy9paW8vYWRjL21lZGlhdGVrLG10 NjM3MF9hZGMuaCAgfCAgIDE4ICsKIDI5IGZpbGVzIGNoYW5nZWQsIDQ2NDYgaW5zZXJ0aW9ucygr KQogY3JlYXRlIG1vZGUgMTAwNjQ0IERvY3VtZW50YXRpb24vZGV2aWNldHJlZS9iaW5kaW5ncy9s ZWRzL2JhY2tsaWdodC9tZWRpYXRlayxtdDYzNzAtYmFja2xpZ2h0LnlhbWwKIGNyZWF0ZSBtb2Rl IDEwMDY0NCBEb2N1bWVudGF0aW9uL2RldmljZXRyZWUvYmluZGluZ3MvbGVkcy9tZWRpYXRlayxt dDYzNzAtZmxhc2hsaWdodC55YW1sCiBjcmVhdGUgbW9kZSAxMDA2NDQgRG9jdW1lbnRhdGlvbi9k ZXZpY2V0cmVlL2JpbmRpbmdzL2xlZHMvbWVkaWF0ZWssbXQ2MzcwLWluZGljYXRvci55YW1sCiBj cmVhdGUgbW9kZSAxMDA2NDQgRG9jdW1lbnRhdGlvbi9kZXZpY2V0cmVlL2JpbmRpbmdzL21mZC9t ZWRpYXRlayxtdDYzNzAueWFtbAogY3JlYXRlIG1vZGUgMTAwNjQ0IERvY3VtZW50YXRpb24vZGV2 aWNldHJlZS9iaW5kaW5ncy9wb3dlci9zdXBwbHkvbWVkaWF0ZWssbXQ2MzcwLWNoYXJnZXIueWFt bAogY3JlYXRlIG1vZGUgMTAwNjQ0IERvY3VtZW50YXRpb24vZGV2aWNldHJlZS9iaW5kaW5ncy91 c2IvbWVkaWF0ZWssbXQ2MzcwLXRjcGMueWFtbAogY3JlYXRlIG1vZGUgMTAwNjQ0IGRyaXZlcnMv aWlvL2FkYy9tdDYzNzAtYWRjLmMKIGNyZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL2xlZHMvZmxh c2gvbGVkcy1tdDYzNzAtZmxhc2guYwogY3JlYXRlIG1vZGUgMTAwNjQ0IGRyaXZlcnMvbGVkcy9s ZWRzLW10NjM3MC5jCiBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy9tZmQvbXQ2MzcwLmMKIGNy ZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL21mZC9tdDYzNzAuaAogY3JlYXRlIG1vZGUgMTAwNjQ0 IGRyaXZlcnMvcG93ZXIvc3VwcGx5L210NjM3MC1jaGFyZ2VyLmMKIGNyZWF0ZSBtb2RlIDEwMDY0 NCBkcml2ZXJzL3VzYi90eXBlYy90Y3BtL3RjcGNpX210NjM3MC5jCiBjcmVhdGUgbW9kZSAxMDA2 NDQgZHJpdmVycy92aWRlby9iYWNrbGlnaHQvbXQ2MzcwLWJhY2tsaWdodC5jCiBjcmVhdGUgbW9k ZSAxMDA2NDQgaW5jbHVkZS9kdC1iaW5kaW5ncy9paW8vYWRjL21lZGlhdGVrLG10NjM3MF9hZGMu aAoKLS0gCjIuNy40CgoKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX18KbGludXgtYXJtLWtlcm5lbCBtYWlsaW5nIGxpc3QKbGludXgtYXJtLWtlcm5lbEBsaXN0 cy5pbmZyYWRlYWQub3JnCmh0dHA6Ly9saXN0cy5pbmZyYWRlYWQub3JnL21haWxtYW4vbGlzdGlu Zm8vbGludXgtYXJtLWtlcm5lbAo=