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 1CDBFC43217 for ; Wed, 5 Oct 2022 11:47:04 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230225AbiJELrD (ORCPT ); Wed, 5 Oct 2022 07:47:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38094 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230244AbiJELqn (ORCPT ); Wed, 5 Oct 2022 07:46:43 -0400 Received: from mail-pf1-x433.google.com (mail-pf1-x433.google.com [IPv6:2607:f8b0:4864:20::433]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 270EF79A75; Wed, 5 Oct 2022 04:44:29 -0700 (PDT) Received: by mail-pf1-x433.google.com with SMTP id g28so563248pfk.8; Wed, 05 Oct 2022 04:44:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date; bh=UrRRVt0/paABUAHCnH843IQvcePKpNudmSaaCNiEgas=; b=bK9KG3JT878OP0vfs4TShumyoV1WaOZ4tcQauip8rm2xQv2JaCT/2UdvI4ArDxZXnq riYFvwmN8rUHOgI4BwLVdutzWfZVOGBo5vzdAT4tAxHu8LLwwK94O/cRTdd+ftqmOMhb gyl5e9RdxIcuJ1slHEdogdYOszD6qsvFIsVTEhW2beEfNRL57s82w9PKQLAiTfTIuBGI 3Agr2r2/mFMO3fvCw+wgmFX/NvmjxNVpTlX0ryDXLyc16D3TdvaYm3sYwfWn9lU66AlI Tl7KnFD3H6Tgg4QWkViJ4NT/ZdbKJzj2y/PqtGUSXanJIZLy8ZJ49/eTrN66Sq8UXe2u XZEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date; bh=UrRRVt0/paABUAHCnH843IQvcePKpNudmSaaCNiEgas=; b=nfuxp+NVBkMhvts3ERKoFFTug8Qkle2awkqOyMRqTvlXO/RfroDETW1I3gQMHVehR2 eKqApBDYGMurpAREIBjucuYZ/trfuB1TkQpP4epK9JwKoLkU/6x+Y6HQDjDDJuxU62cR 3o7Ixkx9pSmiY6IuLh0RTIvhrgGz8Q7u9Aa3TESJ0ypsFpnb2XXSyPydH+NssoirCYi1 NBanEnX83ji/mIE5dqFpXX9CKnfcdkKHLcb1q2LpwrcoTnC93p5vHymCLnLx9KXRKqw4 1hkX0Ki9P/6HowZnXMTDdEa0XEVbtA4auwkMSH+80Kqx0h5JBzDjDmjXD8OeHLgjsade ROuQ== X-Gm-Message-State: ACrzQf1mQyi7f9E1lzghK7e0pI2Uq5iDwrS2lyDTZWQz+U3JA+SQplkK 5eEN076HF1AMMhf9fwKkhLRScSpM4s2jrw== X-Google-Smtp-Source: AMsMyM45m1MpWBCVQeXrDEYBSxBH+nNyff5wk1hSLxrurYvNfQ+QXMMlsIVBxzGWuNMD+5vdWG0BPg== X-Received: by 2002:a65:5901:0:b0:457:5322:65a0 with SMTP id f1-20020a655901000000b00457532265a0mr4478478pgu.585.1664970265059; Wed, 05 Oct 2022 04:44:25 -0700 (PDT) Received: from RD-3580-24288.rt.l (42-73-126-108.emome-ip.hinet.net. [42.73.126.108]) by smtp.gmail.com with ESMTPSA id y23-20020a17090264d700b00176e2fa216csm10477447pli.52.2022.10.05.04.44.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 05 Oct 2022 04:44:24 -0700 (PDT) From: ChiaEn Wu To: pavel@ucw.cz, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, matthias.bgg@gmail.com, jic23@kernel.org, lars@metafoo.de, andriy.shevchenko@linux.intel.com Cc: chiaen_wu@richtek.com, alice_chen@richtek.com, cy_huang@richtek.com, 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-iio@vger.kernel.org, szunichen@gmail.com Subject: [PATCH v13 0/5] Add MediaTek MT6370 PMIC support Date: Wed, 5 Oct 2022 19:43:52 +0800 Message-Id: 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-iio@vger.kernel.org From: ChiaEn Wu This patch series add MediaTek MT6370 PMIC support and add a index macro to . 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. First, in this series of patches, - 'dt-binding: mfd' and 'mfd driver' have been applied by Lee in the v7. https://lore.kernel.org/all/YvJdpq0MWNPQZw5c@google.com/ https://lore.kernel.org/all/YvJdxEpC2cB58Bq9@google.com/ - 'tcpci driver' has been applied by Greg in the v8. https://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb.git/commit/?h=usb-next&id=c2a8ea5997fdfeb43eda259d5533234c3cae05d7 - 'dt-binding: backlight' and 'backlight driver' have been applied by Lee in v9. https://lore.kernel.org/all/YxYSDSlnOELL2mPF@google.com/ https://lore.kernel.org/all/YxYS7%2FdZI69lMXeh@google.com/ - 'dt-binding: charger', 'charger driver' and 'linear_range.h' patch have been applied by Sebastian in v11. https://lore.kernel.org/all/20220920160857.6qfi66gtmgwesq7g@mercury.elektranox.org/ https://lore.kernel.org/all/20220920161218.dkkfvfomrruebahi@mercury.elektranox.org/ https://lore.kernel.org/all/20220920161238.dswtmyon462324dm@mercury.elektranox.org/ Second, the LED RGB driver is based on Andy's patch which moves led_init_default_state_get() to the global header. https://lore.kernel.org/all/20220805154907.32263-3-andriy.shevchenko@linux.intel.com/ Third, the Patch 3/5 (MT6370 ADC Drvier) depends on unmerged 'dt-binding:mfd' patch. In addition, we made some changes for MT6370 LED indicator dt-binding (see v13 section of the change log below). Thank you, ChiaEn Wu --- Change in v13: - In Patch 1/5 (dt-bindings: MT6370 LED Indicator) - Remove 'allOf' property - Add '$ref' and 'unevaluatedProperties: false' in 'multi-led' Change in v12: - In Patch 5/5 (MT6370 Flash): - Rename all 'led_flash_setting *s' --> 'led_flash_setting *setting' - Rename 'max_uA' --> 'max_ua' in mt6370_init_flash_properties() Change in v11: - In Patch 1/8 (dt-bindings: MT6370 Charger) - Add more detailed description of irqs. - Adujust the order of irqs Change in v10: - In Patch 6/8 (MT6370 Charger): - Add a feature (disable input current limit) in 'mt6370_chg_init_setting()' - Add the header file for using 'devm_work_autocancel()' and 'devm_delayed_work_autocancel() - Rename 'pwr_rdy' to 'opposite_pwr_rdy' in 'mt6370_chg_pwr_rdy_check()' - Rename enum elements ('MT6370_ATTACH_STAT_ATTACH_BC12_NOT_DONE' --> 'MT6370_ATTACH_STAT_ATTACH_WAIT_FOR_BC12') - Revise the assignment value of 'val.intval' in 'mt6370_chg_pwr_rdy_check()' to make the code easy to read. - Revise the initialization of bc12_work (INIT_WORK() --> using devm_work_autocancel()) and mivr_dwork (INIT_DELAYED_WORK + devm_add_action_or_reset() --> devm_delayed_work_autocancel()) - In Patch 8/8 (MT6370 LED Flashlight): - Add the revert code when '__mt6370_flash_brightness_set()' return failed. - Revise type of 'led_no' (u32 -> u8) - Revise type of 'default_state' (u32 -> enum led_default_state) - Revise the return value of '_mt6370_flash_brightness_set()' - Remove the useless function 'mt6370_init_common_properties()' - Use 'led_init_default_state_get()' to init 'led->default_state' Changes in v9: - In Patch 05/10: - Revise LINEAR_RANGE() and LINEAR_RANGE_IDX() - In Patch 07/10: - Fix wrong 'F_IINLMTSEL' setting in 'mt6370_chg_init_setting()' - Revise the usage of LINEAR_RANGE_IDX() - In Patch 09/10: - Revise the format of the comments. - In Patch 10/10: - Revise the format of the comments. Changes in v8: - In Patch 06/12: - Add linear_range_idx macro for declaring the linear_range struct simply. - In Patch 09/12: - Remove MT6370_CHG_LINEAR_RANGE() macro, and change to use LINEAR_RANGE_IDX() macro - In Patch 10/12: - Add include header file - Remove useless 'enum mt6370_state' because of using 'enum led_default_state' - Revise the calculation of 'val' in 'mt6370_gen_breath_pattern()' - Replace the medthod of getting default-state by using led_init_default_state_get() - In Patch 11/12: - Add missing 'dependency config' in Kconfig - Revise all multi-line comments - In Patch 12/12: - Add missing header file - Remove useledd header file - Revise the comment of 'mt6370_check_vendor_info()' Changes in v7: - In Patch 05/13: - Add the second compatible string for 'mt6372' - Add 'mediatek,bled-exponential-mode-enable' property for enable the exponential mode of backlight brightness - Add validation for the maximum value of 'default-brightness' and 'max-brightness' - In Patch 07/13: - Move '#define MT6370_REG_MAXADDR' to the next line of '#define MT6370_REG_CHG_MASK1' - Rename 'MT6370_REG_ADDRLEN' to 'MT6370_MAX_ADDRLEN' - In Patch 08/13: - Revise 'devm_add_action_or_reset(dev, ...)' to one line - Revise 'return regmap_update_bits(...)' with using positive conditional - In Patch 09/13: - Add AICR(100mA ~ 350mA), ICHG(100mA ~ 800mA) macros - Remove 400mA AICR and 900mA ICHG macros - Revise using 'if-else' to 'switch-case' in mt6370_adc_read_scale() where the adc channel is ibus or ibat - In Patch 10/13: - Revise the method to enable/disable irq - Revise all 'if (ret < 0)' to 'if (ret)' after using mt6370_chg_field_set/get() - Revise all 'OTG' text again - In Patch 11/13: - Add the comment for the union of 'struct mt6370_led' - Revise the wrong description of 'Authors' - Revise some typos (e.g. led --> LED) - Revise 'if (!fwnode_property_read_string())' to 'ret = fwnode_property_read_string()' - Replace 'memcpy(...)' with 'put_unaligned_be24()' in mt6370_gen_breath_pattern() - Replace all 'LED_OFF' with 0 - Remove the redundant assignment in mt6370_mc_pattern_clear() - In Patch 12/13: - Fix the indentation. - For the well defined macro, the parenthesis is needed for input parameters. - Replace some dev_warn to dev_info in 'init_flash_properties'. - Add sentinel comment for the terminator entry of of_device_id. - Use priv->fled_torch_used directly. - Delete 0 in {}. - Use _uA instead of _UA in definition. - Refine the description. - Use usleep_range instead of udelay. - Rename config to LEDS_MT6370_FLASH. - Add missing ">" in copyright. - Change the Kconfig order - In Patch 13/13: - Add support 'exponential mode' property parsing - Add 'return dev_err_probe()' after 'if (IS_ERR(priv->enable_gpio))' - Add 'mt6372' compatible string - Revise Kconfig help text - Revise update()/get() for supporting 16384 steps (MT6372) - Revise all shift usages form using 'ffs() and fls()' to defining the _SHIFT macros. - Revise 'brightness ? 1 : 0' to '!!brightness' in gpiod_set_value() Changes in v6: - In Patch 03/13: - Add 'reg' property of led of multi-led to prevent checking error. - In Patch 08/13: - Convert tcpci as device resource managed with 'devm_add_action_or_reset' api. - Refine remvoe callback. - Refine the commit text from 'this commit add' to 'add'. - In Patch 09/13: - Using 'struct device *dev = &pdev->dev' in probe() - Revise the sixth parameter of regmap_read_poll_timeout() by Replacing '1000' with 'MILLI' - Revise the units of three macros - MT6370_AICR_400MA --> MT6370_AICR_400_mA - MT6370_ICHG_500MA --> MT6370_ICHG_500_mA - MT6370_ICHG_900MA --> MT6370_ICHG_900_mA - In patch 10/13: - Remove the varable (*psy_desc) of struct mt6370_priv - Remove the deprecated usb type (POWER_SUPPLY_TYPE_USB_CDP and POWER_SUPPLY_TYPE_USB_DCP) - Remove useless remove() - Revise all units from mini- to micro- - Revise get/set power_supply_prop (change to directly return get/set regmap_field) - Revise probe() and use devm_add_action_or_reset() for handling of the workqueue/delayed_work/mutex - Revise mt6370_chg_psy_desc - Add '.name = "mt6370-charger"' - Use 'static const' - In patch 11/13: - Remove the 'ko' from mt6370 led Kconfig description. - Add both authors for Alice and ChiYuan. - Use pdata to distinguish the code from mt6370/71 to mt6372. - Instead of 'state' define, use the 'state' enum. - Fix the typo for 'MT6372_PMW_DUTY'. - For pwm_duty define, replace with bit macro - 1. - Refine all the labels from 'out' to 'out_unlock'. - Use struct 'dev' variable and 'dev_err_probe' to optimize the LOC. - Revise for the array initialization from {0} to {}. - Move into rgb folder and rename file name to 'leds-mt6370-rgb'. - Refine the 'comma' usage in struct/enum. - In patch 12/13: - Use 'GENMASK' instead of 'BIT'. - Use dev_err_probe to decrease LOC. - Use 'dev' variable to make probe function more clean. - Refine the return of _mt6370_flash_brightness_set function. - Refine the descriptions. - Use mt6370_clamp() instead of clamp_align(). - Use device resource managed API for v4l2 flash_release. 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 the coding style. - Use "dev" instead of "&pdev->dev". - 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: flash: mt6370: Add MediaTek MT6370 flashlight support ChiYuan Huang (2): dt-bindings: leds: mt6370: Add MediaTek MT6370 current sink type LED indicator leds: rgb: mt6370: Add MediaTek MT6370 current sink type LED Indicator support ChiaEn Wu (1): iio: adc: mt6370: Add MediaTek MT6370 support .../bindings/leds/mediatek,mt6370-flashlight.yaml | 41 + .../bindings/leds/mediatek,mt6370-indicator.yaml | 82 ++ drivers/iio/adc/Kconfig | 12 + drivers/iio/adc/Makefile | 1 + drivers/iio/adc/mt6370-adc.c | 305 ++++++ drivers/leds/flash/Kconfig | 14 + drivers/leds/flash/Makefile | 1 + drivers/leds/flash/leds-mt6370-flash.c | 631 ++++++++++++ drivers/leds/rgb/Kconfig | 13 + drivers/leds/rgb/Makefile | 1 + drivers/leds/rgb/leds-mt6370-rgb.c | 1010 ++++++++++++++++++++ 11 files changed, 2111 insertions(+) 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 drivers/iio/adc/mt6370-adc.c create mode 100644 drivers/leds/flash/leds-mt6370-flash.c create mode 100644 drivers/leds/rgb/leds-mt6370-rgb.c -- 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 865A3C433F5 for ; Wed, 5 Oct 2022 11:45:37 +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=ETgqCs3A8WacNaSdBNP5FMQw3o1h2pYe27CfrWV8Wqo=; b=hMjerlH6USEWg5 326uOhGGbjo98xpe6SN70W6dzCxNCWbUE67dgTAzTYc8TUEjB8ABpbhaNeBxn8lSlZqnrV2aeXQ0R 59qxGOPo/uTfSVuVlxaRUCcRxQY9O9X3seUyux2Hd11jmdLVB+8XEAJ/xhOBpTZe8Cb0Vdzzzyix3 85OK6apWD0Mwx5ZEmEfNOJfpjlkAyqOrdysC5KcSkqfDSrZ5rsIbCJCxjNNuH9aIv9xrRbWg3kmqQ fx+cjP/exnvOQWR9OwPgnf91Ryt6MJyoQPvCsgxHh1nu/4BGsq9ctsiG+fRpa9ulEKG3zV2FatJaM i2+WEEn7yskAZ5XTD5NQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1og2pD-00DshY-Tz; Wed, 05 Oct 2022 11:44:32 +0000 Received: from mail-pg1-x52f.google.com ([2607:f8b0:4864:20::52f]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1og2p9-00DsfK-7E; Wed, 05 Oct 2022 11:44:30 +0000 Received: by mail-pg1-x52f.google.com with SMTP id c7so15042481pgt.11; Wed, 05 Oct 2022 04:44:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date; bh=UrRRVt0/paABUAHCnH843IQvcePKpNudmSaaCNiEgas=; b=bK9KG3JT878OP0vfs4TShumyoV1WaOZ4tcQauip8rm2xQv2JaCT/2UdvI4ArDxZXnq riYFvwmN8rUHOgI4BwLVdutzWfZVOGBo5vzdAT4tAxHu8LLwwK94O/cRTdd+ftqmOMhb gyl5e9RdxIcuJ1slHEdogdYOszD6qsvFIsVTEhW2beEfNRL57s82w9PKQLAiTfTIuBGI 3Agr2r2/mFMO3fvCw+wgmFX/NvmjxNVpTlX0ryDXLyc16D3TdvaYm3sYwfWn9lU66AlI Tl7KnFD3H6Tgg4QWkViJ4NT/ZdbKJzj2y/PqtGUSXanJIZLy8ZJ49/eTrN66Sq8UXe2u XZEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date; bh=UrRRVt0/paABUAHCnH843IQvcePKpNudmSaaCNiEgas=; b=4u8LdYdic3f4DKJbSdLtt12R+T1XvnXS/vjnGIQSPUUJjJo19NuX5zaT3NEOOogu7w e/6goTUH2jYHMr0MWHur+zfParxXqgrQbO1wxAUSKrDM0t3ewfCriJ3xHWVNkMg9vrSV uByZSqsVd7Ae4ASm+ofP/mObCUDclC3/qSE/ikOsGCU6xNxFdd7fC2MPuSyJ6Cx909zQ 1l39epy47EEMK4VUe3VrqVcgDrV5xeaWmdAvGnJJqX78R0iv1nC5uEO4uJHjPV/BjDor Vx2+f9WTtMSHKzoFbVtC94HK4E1lhEd4KLeg9UiCwuRWsZI1XHkEIll5d4rhUjOhn37f cfNg== X-Gm-Message-State: ACrzQf2LdGkgcO7olu/rbkpGtZK0EQWp6F8yzKM2FG18u/pBsFSP5SyK Wa2NBbRz0mu118F/mPLYm9c= X-Google-Smtp-Source: AMsMyM45m1MpWBCVQeXrDEYBSxBH+nNyff5wk1hSLxrurYvNfQ+QXMMlsIVBxzGWuNMD+5vdWG0BPg== X-Received: by 2002:a65:5901:0:b0:457:5322:65a0 with SMTP id f1-20020a655901000000b00457532265a0mr4478478pgu.585.1664970265059; Wed, 05 Oct 2022 04:44:25 -0700 (PDT) Received: from RD-3580-24288.rt.l (42-73-126-108.emome-ip.hinet.net. [42.73.126.108]) by smtp.gmail.com with ESMTPSA id y23-20020a17090264d700b00176e2fa216csm10477447pli.52.2022.10.05.04.44.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 05 Oct 2022 04:44:24 -0700 (PDT) From: ChiaEn Wu To: pavel@ucw.cz, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, matthias.bgg@gmail.com, jic23@kernel.org, lars@metafoo.de, andriy.shevchenko@linux.intel.com Cc: chiaen_wu@richtek.com, alice_chen@richtek.com, cy_huang@richtek.com, 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-iio@vger.kernel.org, szunichen@gmail.com Subject: [PATCH v13 0/5] Add MediaTek MT6370 PMIC support Date: Wed, 5 Oct 2022 19:43:52 +0800 Message-Id: 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-20221005_044427_314519_8ACE094F X-CRM114-Status: GOOD ( 23.97 ) 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 cyBhZGQgTWVkaWFUZWsgTVQ2MzcwIFBNSUMgc3VwcG9ydCBhbmQgYWRkIGEgaW5kZXggbWFjcm8K dG8gPGxpbmVhcl9yYW5nZS5oPi4gVGhlIE1UNjM3MCBpcyBhIGhpZ2hseS1pbnRlZ3JhdGVkIHNt YXJ0IHBvd2VyCm1hbmFnZW1lbnQgSUMsIHdoaWNoIGluY2x1ZGVzIGEgc2luZ2xlIGNlbGwgTGkt SW9uL0xpLVBvbHltZXIgc3dpdGNoaW5nCmJhdHRlcnkgY2hhcmdlciwgYSBVU0IgVHlwZS1DICYg UG93ZXIgRGVsaXZlcnkgKFBEKSBjb250cm9sbGVyLCBkdWFsCkZsYXNoIExFRCBjdXJyZW50IHNv dXJjZXMsIGEgUkdCIExFRCBkcml2ZXIsIGEgYmFja2xpZ2h0IFdMRUQgZHJpdmVyLAphIGRpc3Bs YXkgYmlhcyBkcml2ZXIgYW5kIGEgZ2VuZXJhbCBMRE8gZm9yIHBvcnRhYmxlIGRldmljZXMuCgpG aXJzdCwgaW4gdGhpcyBzZXJpZXMgb2YgcGF0Y2hlcywKLSAnZHQtYmluZGluZzogbWZkJyBhbmQg J21mZCBkcml2ZXInIGhhdmUgYmVlbiBhcHBsaWVkIGJ5IExlZSBpbiB0aGUgdjcuCiAgaHR0cHM6 Ly9sb3JlLmtlcm5lbC5vcmcvYWxsL1l2SmRwcTBNV05QUVp3NWNAZ29vZ2xlLmNvbS8KICBodHRw czovL2xvcmUua2VybmVsLm9yZy9hbGwvWXZKZHhFcEMyY0I1OEJxOUBnb29nbGUuY29tLwoKLSAn dGNwY2kgZHJpdmVyJyBoYXMgYmVlbiBhcHBsaWVkIGJ5IEdyZWcgaW4gdGhlIHY4LgogIGh0dHBz Oi8vZ2l0Lmtlcm5lbC5vcmcvcHViL3NjbS9saW51eC9rZXJuZWwvZ2l0L2dyZWdraC91c2IuZ2l0 L2NvbW1pdC8/aD11c2ItbmV4dCZpZD1jMmE4ZWE1OTk3ZmRmZWI0M2VkYTI1OWQ1NTMzMjM0YzNj YWUwNWQ3CgotICdkdC1iaW5kaW5nOiBiYWNrbGlnaHQnIGFuZCAnYmFja2xpZ2h0IGRyaXZlcicg aGF2ZSBiZWVuIGFwcGxpZWQKICBieSBMZWUgaW4gdjkuCiAgaHR0cHM6Ly9sb3JlLmtlcm5lbC5v cmcvYWxsL1l4WVNEU2xuT0VMTDJtUEZAZ29vZ2xlLmNvbS8KICBodHRwczovL2xvcmUua2VybmVs Lm9yZy9hbGwvWXhZUzclMkZkWkk2OWxNWGVoQGdvb2dsZS5jb20vCgotICdkdC1iaW5kaW5nOiBj aGFyZ2VyJywgJ2NoYXJnZXIgZHJpdmVyJyBhbmQgJ2xpbmVhcl9yYW5nZS5oJyBwYXRjaCBoYXZl CiAgYmVlbiBhcHBsaWVkIGJ5IFNlYmFzdGlhbiBpbiB2MTEuCiAgaHR0cHM6Ly9sb3JlLmtlcm5l bC5vcmcvYWxsLzIwMjIwOTIwMTYwODU3LjZxZmk2Nmd0bWd3ZXNxN2dAbWVyY3VyeS5lbGVrdHJh bm94Lm9yZy8KICBodHRwczovL2xvcmUua2VybmVsLm9yZy9hbGwvMjAyMjA5MjAxNjEyMTguZGtr ZnZmb21ycnVlYmFoaUBtZXJjdXJ5LmVsZWt0cmFub3gub3JnLwogIGh0dHBzOi8vbG9yZS5rZXJu ZWwub3JnL2FsbC8yMDIyMDkyMDE2MTIzOC5kc3d0bXlvbjQ2MjMyNGRtQG1lcmN1cnkuZWxla3Ry YW5veC5vcmcvCgpTZWNvbmQsIHRoZSBMRUQgUkdCIGRyaXZlciBpcyBiYXNlZCBvbiBBbmR5J3Mg cGF0Y2ggd2hpY2ggbW92ZXMKbGVkX2luaXRfZGVmYXVsdF9zdGF0ZV9nZXQoKSB0byB0aGUgZ2xv YmFsIGhlYWRlci4KaHR0cHM6Ly9sb3JlLmtlcm5lbC5vcmcvYWxsLzIwMjIwODA1MTU0OTA3LjMy MjYzLTMtYW5kcml5LnNoZXZjaGVua29AbGludXguaW50ZWwuY29tLwoKVGhpcmQsIHRoZSBQYXRj aCAzLzUgKE1UNjM3MCBBREMgRHJ2aWVyKSBkZXBlbmRzIG9uIHVubWVyZ2VkCidkdC1iaW5kaW5n Om1mZCcgcGF0Y2guCgpJbiBhZGRpdGlvbiwgd2UgbWFkZSBzb21lIGNoYW5nZXMgZm9yIE1UNjM3 MCBMRUQgaW5kaWNhdG9yIGR0LWJpbmRpbmcKKHNlZSB2MTMgc2VjdGlvbiBvZiB0aGUgY2hhbmdl IGxvZyBiZWxvdykuCgpUaGFuayB5b3UsCkNoaWFFbiBXdQotLS0KQ2hhbmdlIGluIHYxMzoKLSBJ biBQYXRjaCAxLzUgKGR0LWJpbmRpbmdzOiBNVDYzNzAgTEVEIEluZGljYXRvcikKCS0gUmVtb3Zl ICdhbGxPZicgcHJvcGVydHkKCS0gQWRkICckcmVmJyBhbmQgJ3VuZXZhbHVhdGVkUHJvcGVydGll czogZmFsc2UnIGluICdtdWx0aS1sZWQnCgoKQ2hhbmdlIGluIHYxMjoKLSBJbiBQYXRjaCA1LzUg KE1UNjM3MCBGbGFzaCk6CgktIFJlbmFtZSBhbGwgJ2xlZF9mbGFzaF9zZXR0aW5nICpzJyAtLT4g J2xlZF9mbGFzaF9zZXR0aW5nICpzZXR0aW5nJwoJLSBSZW5hbWUgJ21heF91QScgLS0+ICdtYXhf dWEnIGluIG10NjM3MF9pbml0X2ZsYXNoX3Byb3BlcnRpZXMoKQoKCkNoYW5nZSBpbiB2MTE6Ci0g SW4gUGF0Y2ggMS84IChkdC1iaW5kaW5nczogTVQ2MzcwIENoYXJnZXIpCgktIEFkZCBtb3JlIGRl dGFpbGVkIGRlc2NyaXB0aW9uIG9mIGlycXMuCgktIEFkdWp1c3QgdGhlIG9yZGVyIG9mIGlycXMK CgpDaGFuZ2UgaW4gdjEwOgotIEluIFBhdGNoIDYvOCAoTVQ2MzcwIENoYXJnZXIpOgoJLSBBZGQg YSBmZWF0dXJlIChkaXNhYmxlIGlucHV0IGN1cnJlbnQgbGltaXQpIGluCgkgICdtdDYzNzBfY2hn X2luaXRfc2V0dGluZygpJwoJLSBBZGQgdGhlIGhlYWRlciBmaWxlIDxsaW51eC9kZXZtLWhlbHBl cnMuaD4gZm9yIHVzaW5nCgkgICdkZXZtX3dvcmtfYXV0b2NhbmNlbCgpJyBhbmQgJ2Rldm1fZGVs YXllZF93b3JrX2F1dG9jYW5jZWwoKQoJLSBSZW5hbWUgJ3B3cl9yZHknIHRvICdvcHBvc2l0ZV9w d3JfcmR5JyBpbgoJICAnbXQ2MzcwX2NoZ19wd3JfcmR5X2NoZWNrKCknCgktIFJlbmFtZSBlbnVt IGVsZW1lbnRzCgkgICgnTVQ2MzcwX0FUVEFDSF9TVEFUX0FUVEFDSF9CQzEyX05PVF9ET05FJyAt LT4KCSAgICdNVDYzNzBfQVRUQUNIX1NUQVRfQVRUQUNIX1dBSVRfRk9SX0JDMTInKQoJLSBSZXZp c2UgdGhlIGFzc2lnbm1lbnQgdmFsdWUgb2YgJ3ZhbC5pbnR2YWwnIGluCgkgICdtdDYzNzBfY2hn X3B3cl9yZHlfY2hlY2soKScgdG8gbWFrZSB0aGUgY29kZSBlYXN5IHRvIHJlYWQuCgktIFJldmlz ZSB0aGUgaW5pdGlhbGl6YXRpb24gb2YgYmMxMl93b3JrIChJTklUX1dPUksoKSAtLT4KCSAgdXNp bmcgZGV2bV93b3JrX2F1dG9jYW5jZWwoKSkgYW5kIG1pdnJfZHdvcmsKCSAgKElOSVRfREVMQVlF RF9XT1JLICsgZGV2bV9hZGRfYWN0aW9uX29yX3Jlc2V0KCkgLS0+CgkgICBkZXZtX2RlbGF5ZWRf d29ya19hdXRvY2FuY2VsKCkpCgotIEluIFBhdGNoIDgvOCAoTVQ2MzcwIExFRCBGbGFzaGxpZ2h0 KToKCS0gQWRkIHRoZSByZXZlcnQgY29kZSB3aGVuICdfX210NjM3MF9mbGFzaF9icmlnaHRuZXNz X3NldCgpJwoJICByZXR1cm4gZmFpbGVkLgoJLSBSZXZpc2UgdHlwZSBvZiAnbGVkX25vJyAodTMy IC0+IHU4KQoJLSBSZXZpc2UgdHlwZSBvZiAnZGVmYXVsdF9zdGF0ZScgKHUzMiAtPiBlbnVtIGxl ZF9kZWZhdWx0X3N0YXRlKQoJLSBSZXZpc2UgdGhlIHJldHVybiB2YWx1ZSBvZiAnX210NjM3MF9m bGFzaF9icmlnaHRuZXNzX3NldCgpJwoJLSBSZW1vdmUgdGhlIHVzZWxlc3MgZnVuY3Rpb24gJ210 NjM3MF9pbml0X2NvbW1vbl9wcm9wZXJ0aWVzKCknCgktIFVzZSAnbGVkX2luaXRfZGVmYXVsdF9z dGF0ZV9nZXQoKScgdG8gaW5pdCAnbGVkLT5kZWZhdWx0X3N0YXRlJwoKCkNoYW5nZXMgaW4gdjk6 Ci0gSW4gUGF0Y2ggMDUvMTA6CgktIFJldmlzZSBMSU5FQVJfUkFOR0UoKSBhbmQgTElORUFSX1JB TkdFX0lEWCgpCgotIEluIFBhdGNoIDA3LzEwOgoJLSBGaXggd3JvbmcgJ0ZfSUlOTE1UU0VMJyBz ZXR0aW5nIGluICdtdDYzNzBfY2hnX2luaXRfc2V0dGluZygpJwoJLSBSZXZpc2UgdGhlIHVzYWdl IG9mIExJTkVBUl9SQU5HRV9JRFgoKQoKLSBJbiBQYXRjaCAwOS8xMDoKCS0gUmV2aXNlIHRoZSBm b3JtYXQgb2YgdGhlIGNvbW1lbnRzLgoKLSBJbiBQYXRjaCAxMC8xMDoKCS0gUmV2aXNlIHRoZSBm b3JtYXQgb2YgdGhlIGNvbW1lbnRzLgoKCkNoYW5nZXMgaW4gdjg6Ci0gSW4gUGF0Y2ggMDYvMTI6 CgktIEFkZCBsaW5lYXJfcmFuZ2VfaWR4IG1hY3JvIGZvciBkZWNsYXJpbmcgdGhlIGxpbmVhcl9y YW5nZQoJICBzdHJ1Y3Qgc2ltcGx5LgoKLSBJbiBQYXRjaCAwOS8xMjoKCS0gUmVtb3ZlIE1UNjM3 MF9DSEdfTElORUFSX1JBTkdFKCkgbWFjcm8sIGFuZCBjaGFuZ2UgdG8gdXNlCgkgIExJTkVBUl9S QU5HRV9JRFgoKSBtYWNybwoKLSBJbiBQYXRjaCAxMC8xMjoKCS0gQWRkIGluY2x1ZGUgaGVhZGVy IGZpbGUgPGxpbnV4L2xlZHMuaD4KCS0gUmVtb3ZlIHVzZWxlc3MgJ2VudW0gbXQ2MzcwX3N0YXRl JyBiZWNhdXNlIG9mIHVzaW5nICdlbnVtIGxlZF9kZWZhdWx0X3N0YXRlJwoJLSBSZXZpc2UgdGhl IGNhbGN1bGF0aW9uIG9mICd2YWwnIGluICdtdDYzNzBfZ2VuX2JyZWF0aF9wYXR0ZXJuKCknCgkt IFJlcGxhY2UgdGhlIG1lZHRob2Qgb2YgZ2V0dGluZyBkZWZhdWx0LXN0YXRlIGJ5IHVzaW5nCgkg IGxlZF9pbml0X2RlZmF1bHRfc3RhdGVfZ2V0KCkKCi0gSW4gUGF0Y2ggMTEvMTI6CgktIEFkZCBt aXNzaW5nICdkZXBlbmRlbmN5IGNvbmZpZycgaW4gS2NvbmZpZwoJLSBSZXZpc2UgYWxsIG11bHRp LWxpbmUgY29tbWVudHMKCi0gSW4gUGF0Y2ggMTIvMTI6CgktIEFkZCBtaXNzaW5nIGhlYWRlciBm aWxlIDxsaW51eC9wcm9wZXJ0eS5oPgoJLSBSZW1vdmUgdXNlbGVkZCBoZWFkZXIgZmlsZSA8bGlu dXgvb2ZfZGV2aWNlLmg+CgktIFJldmlzZSB0aGUgY29tbWVudCBvZiAnbXQ2MzcwX2NoZWNrX3Zl bmRvcl9pbmZvKCknCgoKQ2hhbmdlcyBpbiB2NzoKLSBJbiBQYXRjaCAwNS8xMzoKCS0gQWRkIHRo ZSBzZWNvbmQgY29tcGF0aWJsZSBzdHJpbmcgZm9yICdtdDYzNzInCgktIEFkZCAnbWVkaWF0ZWss YmxlZC1leHBvbmVudGlhbC1tb2RlLWVuYWJsZScgcHJvcGVydHkgZm9yIGVuYWJsZSB0aGUKCSAg ZXhwb25lbnRpYWwgbW9kZSBvZiBiYWNrbGlnaHQgYnJpZ2h0bmVzcwoJLSBBZGQgdmFsaWRhdGlv biBmb3IgdGhlIG1heGltdW0gdmFsdWUgb2YgJ2RlZmF1bHQtYnJpZ2h0bmVzcycgYW5kCgkgICdt YXgtYnJpZ2h0bmVzcycKCi0gSW4gUGF0Y2ggMDcvMTM6CgktIE1vdmUgJyNkZWZpbmUgTVQ2Mzcw X1JFR19NQVhBRERSJyB0byB0aGUgbmV4dCBsaW5lIG9mCgkgICcjZGVmaW5lIE1UNjM3MF9SRUdf Q0hHX01BU0sxJwoJLSBSZW5hbWUgJ01UNjM3MF9SRUdfQUREUkxFTicgdG8gJ01UNjM3MF9NQVhf QUREUkxFTicKCi0gSW4gUGF0Y2ggMDgvMTM6CgktIFJldmlzZSAnZGV2bV9hZGRfYWN0aW9uX29y X3Jlc2V0KGRldiwgLi4uKScgdG8gb25lIGxpbmUKCS0gUmV2aXNlICdyZXR1cm4gcmVnbWFwX3Vw ZGF0ZV9iaXRzKC4uLiknIHdpdGggdXNpbmcgcG9zaXRpdmUKCSAgY29uZGl0aW9uYWwKCi0gSW4g UGF0Y2ggMDkvMTM6CgktIEFkZCBBSUNSKDEwMG1BIH4gMzUwbUEpLCBJQ0hHKDEwMG1BIH4gODAw bUEpIG1hY3JvcwoJLSBSZW1vdmUgNDAwbUEgQUlDUiBhbmQgOTAwbUEgSUNIRyBtYWNyb3MKCS0g UmV2aXNlIHVzaW5nICdpZi1lbHNlJyB0byAnc3dpdGNoLWNhc2UnIGluIG10NjM3MF9hZGNfcmVh ZF9zY2FsZSgpCgkgIHdoZXJlIHRoZSBhZGMgY2hhbm5lbCBpcyBpYnVzIG9yIGliYXQKCi0gSW4g UGF0Y2ggMTAvMTM6CgktIFJldmlzZSB0aGUgbWV0aG9kIHRvIGVuYWJsZS9kaXNhYmxlIGlycQoJ LSBSZXZpc2UgYWxsICdpZiAocmV0IDwgMCknIHRvICdpZiAocmV0KScgYWZ0ZXIgdXNpbmcKCSAg bXQ2MzcwX2NoZ19maWVsZF9zZXQvZ2V0KCkKCS0gUmV2aXNlIGFsbCAnT1RHJyB0ZXh0IGFnYWlu CgotIEluIFBhdGNoIDExLzEzOgoJLSBBZGQgdGhlIGNvbW1lbnQgZm9yIHRoZSB1bmlvbiBvZiAn c3RydWN0IG10NjM3MF9sZWQnCgktIFJldmlzZSB0aGUgd3JvbmcgZGVzY3JpcHRpb24gb2YgJ0F1 dGhvcnMnCgktIFJldmlzZSBzb21lIHR5cG9zIChlLmcuIGxlZCAtLT4gTEVEKQoJLSBSZXZpc2Ug J2lmICghZndub2RlX3Byb3BlcnR5X3JlYWRfc3RyaW5nKCkpJyB0bwoJICAncmV0ID0gZndub2Rl X3Byb3BlcnR5X3JlYWRfc3RyaW5nKCknCgktIFJlcGxhY2UgJ21lbWNweSguLi4pJyB3aXRoICdw dXRfdW5hbGlnbmVkX2JlMjQoKScgaW4KCSAgbXQ2MzcwX2dlbl9icmVhdGhfcGF0dGVybigpCgkt IFJlcGxhY2UgYWxsICdMRURfT0ZGJyB3aXRoIDAKCS0gUmVtb3ZlIHRoZSByZWR1bmRhbnQgYXNz aWdubWVudCBpbiBtdDYzNzBfbWNfcGF0dGVybl9jbGVhcigpCgotIEluIFBhdGNoIDEyLzEzOgoJ LSBGaXggdGhlIGluZGVudGF0aW9uLgoJLSBGb3IgdGhlIHdlbGwgZGVmaW5lZCBtYWNybywgdGhl IHBhcmVudGhlc2lzIGlzIG5lZWRlZCBmb3IgaW5wdXQgcGFyYW1ldGVycy4KCS0gUmVwbGFjZSBz b21lIGRldl93YXJuIHRvIGRldl9pbmZvIGluICdpbml0X2ZsYXNoX3Byb3BlcnRpZXMnLgoJLSBB ZGQgc2VudGluZWwgY29tbWVudCBmb3IgdGhlIHRlcm1pbmF0b3IgZW50cnkgb2Ygb2ZfZGV2aWNl X2lkLgoJLSBVc2UgcHJpdi0+ZmxlZF90b3JjaF91c2VkIGRpcmVjdGx5LgoJLSBEZWxldGUgMCBp biB7fS4KCS0gVXNlIF91QSBpbnN0ZWFkIG9mIF9VQSBpbiBkZWZpbml0aW9uLgoJLSBSZWZpbmUg dGhlIGRlc2NyaXB0aW9uLgoJLSBVc2UgdXNsZWVwX3JhbmdlIGluc3RlYWQgb2YgdWRlbGF5LgoJ LSBSZW5hbWUgY29uZmlnIHRvIExFRFNfTVQ2MzcwX0ZMQVNILgoJLSBBZGQgbWlzc2luZyAiPiIg aW4gY29weXJpZ2h0LgoJLSBDaGFuZ2UgdGhlIEtjb25maWcgb3JkZXIKCi0gSW4gUGF0Y2ggMTMv MTM6CgktIEFkZCBzdXBwb3J0ICdleHBvbmVudGlhbCBtb2RlJyBwcm9wZXJ0eSBwYXJzaW5nCgkt IEFkZCAncmV0dXJuIGRldl9lcnJfcHJvYmUoKScgYWZ0ZXIgJ2lmIChJU19FUlIocHJpdi0+ZW5h YmxlX2dwaW8pKScKCS0gQWRkICdtdDYzNzInIGNvbXBhdGlibGUgc3RyaW5nCgktIFJldmlzZSBL Y29uZmlnIGhlbHAgdGV4dAoJLSBSZXZpc2UgdXBkYXRlKCkvZ2V0KCkgZm9yIHN1cHBvcnRpbmcg MTYzODQgc3RlcHMgKE1UNjM3MikKCS0gUmV2aXNlIGFsbCBzaGlmdCB1c2FnZXMgZm9ybSB1c2lu ZyAnZmZzKCkgYW5kIGZscygpJyB0byBkZWZpbmluZyB0aGUKCSAgX1NISUZUIG1hY3Jvcy4KCS0g UmV2aXNlICdicmlnaHRuZXNzID8gMSA6IDAnIHRvICchIWJyaWdodG5lc3MnIGluIGdwaW9kX3Nl dF92YWx1ZSgpCgoKQ2hhbmdlcyBpbiB2NjoKLSBJbiBQYXRjaCAwMy8xMzoKCS0gQWRkICdyZWcn IHByb3BlcnR5IG9mIGxlZCBvZiBtdWx0aS1sZWQgdG8gcHJldmVudCBjaGVja2luZwoJICBlcnJv ci4KCi0gSW4gUGF0Y2ggMDgvMTM6CgktIENvbnZlcnQgdGNwY2kgYXMgZGV2aWNlIHJlc291cmNl IG1hbmFnZWQgd2l0aAoJICAnZGV2bV9hZGRfYWN0aW9uX29yX3Jlc2V0JyBhcGkuCgktIFJlZmlu ZSByZW12b2UgY2FsbGJhY2suCgktIFJlZmluZSB0aGUgY29tbWl0IHRleHQgZnJvbSAndGhpcyBj b21taXQgYWRkJyB0byAnYWRkJy4KCi0gSW4gUGF0Y2ggMDkvMTM6CgktIFVzaW5nICdzdHJ1Y3Qg ZGV2aWNlICpkZXYgPSAmcGRldi0+ZGV2JyBpbiBwcm9iZSgpCgktIFJldmlzZSB0aGUgc2l4dGgg cGFyYW1ldGVyIG9mIHJlZ21hcF9yZWFkX3BvbGxfdGltZW91dCgpIGJ5CgkgIFJlcGxhY2luZyAn MTAwMCcgd2l0aCAnTUlMTEknCgktIFJldmlzZSB0aGUgdW5pdHMgb2YgdGhyZWUgbWFjcm9zCgkt IE1UNjM3MF9BSUNSXzQwME1BIC0tPiBNVDYzNzBfQUlDUl80MDBfbUEKCS0gTVQ2MzcwX0lDSEdf NTAwTUEgLS0+IE1UNjM3MF9JQ0hHXzUwMF9tQQoJLSBNVDYzNzBfSUNIR185MDBNQSAtLT4gTVQ2 MzcwX0lDSEdfOTAwX21BCgotIEluIHBhdGNoIDEwLzEzOgoJLSBSZW1vdmUgdGhlIHZhcmFibGUg KCpwc3lfZGVzYykgb2Ygc3RydWN0IG10NjM3MF9wcml2CgktIFJlbW92ZSB0aGUgZGVwcmVjYXRl ZCB1c2IgdHlwZSAoUE9XRVJfU1VQUExZX1RZUEVfVVNCX0NEUCBhbmQKCSAgUE9XRVJfU1VQUExZ X1RZUEVfVVNCX0RDUCkKCS0gUmVtb3ZlIHVzZWxlc3MgcmVtb3ZlKCkKCS0gUmV2aXNlIGFsbCB1 bml0cyBmcm9tIG1pbmktIHRvIG1pY3JvLQoJLSBSZXZpc2UgZ2V0L3NldCBwb3dlcl9zdXBwbHlf cHJvcCAoY2hhbmdlIHRvIGRpcmVjdGx5IHJldHVybiBnZXQvc2V0CgkgIHJlZ21hcF9maWVsZCkK CS0gUmV2aXNlIHByb2JlKCkgYW5kIHVzZSBkZXZtX2FkZF9hY3Rpb25fb3JfcmVzZXQoKSBmb3Ig aGFuZGxpbmcgb2YgdGhlCgkgIHdvcmtxdWV1ZS9kZWxheWVkX3dvcmsvbXV0ZXgKCS0gUmV2aXNl IG10NjM3MF9jaGdfcHN5X2Rlc2MKCQktIEFkZCAnLm5hbWUgPSAibXQ2MzcwLWNoYXJnZXIiJwoJ CS0gVXNlICdzdGF0aWMgY29uc3QnCgotIEluIHBhdGNoIDExLzEzOgoJLSBSZW1vdmUgdGhlICdr bycgZnJvbSBtdDYzNzAgbGVkIEtjb25maWcgZGVzY3JpcHRpb24uCgktIEFkZCBib3RoIGF1dGhv cnMgZm9yIEFsaWNlIGFuZCBDaGlZdWFuLgoJLSBVc2UgcGRhdGEgdG8gZGlzdGluZ3Vpc2ggdGhl IGNvZGUgZnJvbSBtdDYzNzAvNzEgdG8gbXQ2MzcyLgoJLSBJbnN0ZWFkIG9mICdzdGF0ZScgZGVm aW5lLCB1c2UgdGhlICdzdGF0ZScgZW51bS4KCS0gRml4IHRoZSB0eXBvIGZvciAnTVQ2MzcyX1BN V19EVVRZJy4KCS0gRm9yIHB3bV9kdXR5IGRlZmluZSwgcmVwbGFjZSB3aXRoIGJpdCBtYWNybyAt IDEuCgktIFJlZmluZSBhbGwgdGhlIGxhYmVscyBmcm9tICdvdXQnIHRvICdvdXRfdW5sb2NrJy4K CS0gVXNlIHN0cnVjdCAnZGV2JyB2YXJpYWJsZSBhbmQgJ2Rldl9lcnJfcHJvYmUnIHRvIG9wdGlt aXplIHRoZSBMT0MuCgktIFJldmlzZSBmb3IgdGhlIGFycmF5IGluaXRpYWxpemF0aW9uIGZyb20g ezB9IHRvIHt9LgoJLSBNb3ZlIGludG8gcmdiIGZvbGRlciBhbmQgcmVuYW1lIGZpbGUgbmFtZSB0 byAnbGVkcy1tdDYzNzAtcmdiJy4KCS0gUmVmaW5lIHRoZSAnY29tbWEnIHVzYWdlIGluIHN0cnVj dC9lbnVtLgoKLSBJbiBwYXRjaCAxMi8xMzoKCS0gVXNlICdHRU5NQVNLJyBpbnN0ZWFkIG9mICdC SVQnLgoJLSBVc2UgZGV2X2Vycl9wcm9iZSB0byBkZWNyZWFzZSBMT0MuCgktIFVzZSAnZGV2JyB2 YXJpYWJsZSB0byBtYWtlIHByb2JlIGZ1bmN0aW9uIG1vcmUgY2xlYW4uCgktIFJlZmluZSB0aGUg cmV0dXJuIG9mIF9tdDYzNzBfZmxhc2hfYnJpZ2h0bmVzc19zZXQgZnVuY3Rpb24uCgktIFJlZmlu ZSB0aGUgZGVzY3JpcHRpb25zLgoJLSBVc2UgbXQ2MzcwX2NsYW1wKCkgaW5zdGVhZCBvZiBjbGFt cF9hbGlnbigpLgoJLSBVc2UgZGV2aWNlIHJlc291cmNlIG1hbmFnZWQgQVBJIGZvciB2NGwyIGZs YXNoX3JlbGVhc2UuCgoKQ2hhbmdlcyBpbiB2NToKLSBJbiBwYXRjaCAwNy8xMzoKCS0gQWRkIHRo ZSBjb21tYSBpbiB0aGUgbGFzdCBSRUdNQVBfSVJRX1JFR19MSU5FKCksCgkgIERFRklORV9SRVNf SVJRX05BTUVEKCkgYW5kIE1GRF9DRUxMX1JFUygpCgktIEFkZCB0aGUgcHJlZml4IGluIHRoZSBm aXJzdCBwYXJhbWV0ZXIgb2YgYWxsIG1mZF9jZWxsCgktIE1vdmUgZW51bSBhbmQgc3RydWN0IG10 NjM3MF9pbmZvIHRvIG10NjM3MC5oCgktIFJlbW92ZSBzdHJ1Y3QgZGV2aWNlICpkZXYgaW4gc3Ry dWN0IG10NjM3MF9pbmZvCgktIFJldmlzZSB0aGUgZGVzY3JpcHRpb24gb2YgS2NvbmZpZyBoZWxw IHRleHQKCS0gUmV2aXNlIE1PRFVMRV9ERVNDUklQVElPTigpCgotIEluIHBhdGNoIDA4LzEzOgoJ LSBBZGQgY29tbWEgZm9yIHRoZSBsYXN0IGluZGV4IG9mIG10NjM3MF9yZWdfaW5pdC4KCS0gVXNl IGRldl9lcnJfcHJvYmUgdG8gZGVjcmVhc2UgTE9DLgoJLSBVc2UgJ2RldicgdmFyaWFibGUgdG8g bWFrZSBwcm9iZSBmdW5jdGlvbiBtb3JlIGNsZWFuLgoJLSBSZWZpbmUga2NvbmZpZyB0ZXh0LgoJ LSBSZW1vdmUgYm90aCAnZWxzZScgaW4gc2V0X3ZidXMgY2FsbGJhY2suCgktIFJlbW92ZSBjb21t YSBmb3Igb2ZfZGV2aWNlX2lkIGlmIHRoZSBhc3NpZ25lZCBtZW1iZXIgaXMgb25seSBvbmUuCgot IEluIHBhdGNoIDA5LzEzOgoJLSBSZXBsYWNlIHVzaW5nIHNucHJpbnRmKCkgd2l0aCBzeXNmc19l bWl0KCkgaW4gbXQ2MzcwX2FkY19yZWFkX2xhYmVsKCkKCS0gUmVtb3ZlIG1hY3JvIEFEQ19DT05W X1RJTUVfVVMKCS0gUmV2aXNlIGFsbCB2YXJpYWJsZSBvcmRlcmluZwoJLSBSZXZpc2UgdGhlIGRl c2NyaXB0aW9uIG9mIEtjb25maWcgaGVscCB0ZXh0CgktIFJldmlzZSBNT0RVTEVfREVTQ1JJUFRJ T04oKQoKLSBJbiBwYXRjaCAxMC8xMzoKCS0gUmVwbGFjZSB1bnNpZ25lZCBpbnQgdHlwZSBvZiBw d3JfcmR5IHdpdGggYm9vbCBpbgoJICBtdDYzNzBfY2hnX3NldF9vbmxpbmUoKQoJLSBSZW1vdmUg cmVkdW5kYW50ICdlbHNlJyBpbiBtdDYzNzBfY2hnX2ZpZWxkX2dldCgpCgktIFJldmlzZSAnaWYt ZWxzZScgaW4gbXQ2MzcwX2NoZ19maWVsZF9zZXQoKQoJLSBSZXZpc2UgJ2lmJyBjb25kaXRpb24g aW4gbXQ2MzcwX2NoZ19lbmFibGVfaXJxKCkKCS0gUmV2aXNlIGFsbCB0ZXh0ICdvdGcnIC0tPiAn T1RHJwoJLSBSZXZpc2UgTVQ2MzcwX01JVlJfSUJVU19USF8xMDBfTUEgLS0+IE1UNjM3MF9NSVZS X0lCVVNfVEhfMTAwX21BCgktIFJldmlzZSB0aGUgZGVzY3JpcHRpb24gb2YgS2NvbmZpZyBoZWxw IHRleHQKCi0gSW4gcGF0Y2ggMTIvMTM6CgktIFJlZmluZSB0aGUgY29kaW5nIHN0eWxlLgoJLSBV c2UgImRldiIgaW5zdGVhZCBvZiAiJnBkZXYtPmRldiIuCgotIEluIHBhdGNoIDEzLzEzOgoJLSBB ZGQgbWlzc2VkIDxtb2RfZGV2aWNldGFibGUuaD4KCS0gQWRkIHN0cnVjdCBkZXZpY2UgKmRldiBp biBwcm9iZSgpIHRvIG1ha2UgY29kZSBjbGVhbmluZwoJLSBSZW1vdmUgdXNlbGVzcyBpbmNsdWRp bmcgaGVhZGVyIGZpbGUgPGdwaW8vZHJpdmVyLmg+LCA8b2YuaD4KCS0gUmVtb3ZlIHVzZWxlc3Mg dmFyaWFibGUgdWFzYWdlIGluIG10NjM3MF9pbml0X2JhY2tsaWdodF9wcm9wZXJ0aWVzKCkKCS0g UmVtb3ZlIHJlZHVuZGFudCBjaGVja2luZyBlbmFibGVfZ3BpbyBpbiBtdDYzNzBfYmxfdXBkYXRl X3N0YXR1cygpCgktIFJlbW92ZSByZWR1bmRhbnQgcGFyZW50aGVzZXMgaW4gbXQ2MzcwX2JsX2dl dF9icmlnaHRuZXNzKCkKCS0gUmV2aXNlIHRoZSBkZXNjcmlwdGlvbiBvZiBLY29uZmlnIGhlbHAg dGV4dAoJLSBSZXZpc2UgdGhlIGNhbGN1bGF0aW9uIG9mIGh5c190aF9zdGVwcwoKCkNoYW5nZXMg aW4gdjQ6Ci0gSW4gcGF0Y2ggMDIvMTM6CgktIEFkZCBtaW5JdGVtcyBvZiAiaW8tY2hhbm5lbC1u YW1lcyIKCS0gUmVwbGFjZSB0ZXh0ICJNZWRpYXRlayIgd2l0aCAiTWVkaWFUZWsiCgotIEluIHBh dGNoIDA2LzEzOgoJLSBSb2xsIGJhY2sgYWxsICIkcmVmOiAiIHRvIHYyIHBhdGNoIHN0eWxlICh1 c2luZyAiL3NjaGVtYXMvLi4uIikKCi0gSW4gcGF0Y2ggMDcvMTM6CgktIFJlcGxhY2UgdGV4dCAi TWVkaWF0ZWsiIHdpdGggIk1lZGlhVGVrIiBpbiBLY29uZmlnCgktIFJlcGxhY2UgImZpcnN0IGJy ZWFrIGFuZCB0aGVuIHJldHVybiIgd2l0aCAicmV0dXJuIGRpcmVjdGx5IgoJICBpbiAibXQ2Mzcw X2NoZWNrX3ZlbmRvcl9pbmZvKCkiCgktIEFkZCBtb2R1bGUgbmFtZSByZWxhdGVkIGRlc2NyaXB0 aW9uIGluIEtjb25maWcgaGVscHRleHQKCS0gQWRkIENvcHlyaWdodCBpbiB0aGUgc291cmNlIGNv ZGUKCS0gQWRkIGhlYWRlciBmaWxlICJtdDYzNzAuaCIgZm9yIGFsbCAiI2RlZmluZSBJUlEiCgkt IEFkanVzdCBNYWtlZmlsZSBvcmRlciBvZiBNVDYzNzAKCS0gUmVmaW5lICJiYW5rX2lkeCIgYW5k ICJiYW5rX2FkZHIiIGluCgkgICJtdDYzNzVfcmVnbWFwX3JlYWQoKSIgLyAibXQ2Mzc1X3JlZ21h cF93cml0ZSgpIgoJLSBSZWZpbmUgcmVkdW5kYW50ICJlbHNlIGlmIiBpbiAibXQ2MzcwX3JlZ21h cF9yZWFkKCkiCgotIEluIHBhdGNoIDA4LzEzOgoJLSBSZXBsYWNlIHRleHQgIk1lZGlhdGVrIiB3 aXRoICJNZWRpYVRlayIgaW4gS2NvbmZpZwoJLSBSZXBsYWNlICJmaXJzdCByZXQ9cmVndWxhdG9y XyhkaXMvZW4pYWJsZSBhbmQgdGhlbiByZXR1cm4iCgkgIHdpdGggInJldHVybiBkaXJlY3RseSIg aW4gIm10NjM3MF90Y3BjX3NldF92YnVzKCkiCgktIFJlcGxhY2UgaGVhZGVyIGZpbGUgPGxpbnV4 L29mLmg+IHdpdGggPGxpbnV4L21vZF9kZXZpY2V0YWJsZS5oPgoJLSBBZGQgQ29weXJpZ2h0IGlu IHRoZSBzb3VyY2UgY29kZQoJLSBBZGQgbW9kdWxlIG5hbWUgcmVsYXRlZCBkZXNjcmlwdGlvbiBp biBLY29uZmlnIGhlbHB0ZXh0CgktIFJlbW92ZSBoZWFkZXIgZmlsZSA8bGludXgvb2YuaD4KCS0g UmVmaW5lIGFsbCBwcm9iZSBlcnJvciBieSB1c2luZyBkZXZfZXJyX3Byb2JlKCkKCi0gSW4gcGF0 Y2ggMDkvMTM6CgktIFJlcGxhY2UgdGV4dCAiTWVkaWF0ZWsiIHdpdGggIk1lZGlhVGVrIgoJLSBS ZXBsYWNlIGFsbCAiZmlyc3QgZGV2X2VycigpIGFuZCB0aGVuIHJldHVybiIgd2l0aAoJICAicmV0 dXJuIGRldl9lcnJfcHJvYmUoKSIKCS0gQWRkIENvcHlyaWdodCBpbiB0aGUgc291cmNlIGNvZGUK CS0gQWRkIG1vZHVsZSBuYW1lIHJlbGF0ZWQgZGVzY3JpcHRpb24gaW4gS2NvbmZpZwoJLSBBZGQg dW5pdCBzdWZmaXggb2YgbWFjcm8gIkFEQ19DT05WX1BPTExJTkdfVElNRSIKCS0gQWRkIG5ldyBt YWNybyAiQURDX0NPTlZfVElNRV9NUyIKCS0gQWRqdXN0IHRoZSBwb3NpdGlvbiBvZiBpbmNsdWRl IGZpbGUgPG1lZGlhdGVrLG10NjM3MF9hZGMuaD4KCS0gQWRqdXN0IHRoZSBwb3N0aW9ucyBiZXR3 ZWVuIDxsaW51eC9tb2R1bGUuaD4gYW5kCgkgICA8bGludXgvbW9kX2RldmljZXRhYmxlLmg+Cgkt IEZpeCBzb21lIGluY29ycmVjdCBjaGFyYWN0ZXJzCgotIEluIHBhdGNoIDEwLzEzOgoJLSBSZXBs YWNlIHRleHQgIk1lZGlhdGVrIiB3aXRoICJNZWRpYVRlayIgaW4gS2NvbmZpZyBhbmQKCSAgTU9E VUxFX0RFU0NSSVBUSU9OKCkKCS0gUmVwbGFjZSAibXQ2MzcwX2NoZ192YWxfdG9fcmVnIiBhbmQg Im10NjM3MF9jaGdfcmVnX3RvX3ZhbCIKCSAgd2l0aCAibGluZWFyX3JhbmdlIiBBUEkKCS0gUmVw bGFjZSAiZmlyc3QgYnJlYWsgYW5kIHRoZW4gcmV0dXJuIiB3aXRoICJyZXR1cm4gZGlyZWN0bHki CgkgIGluIGFsbCBjYXNlcyBvZiBnZXQvc2V0IHBvd2VyX3N1cHBseV9wcm9wZXJ0eQoJLSBSZXBs YWNlIGFsbCAiZmlyc3QgZGV2X2VycigpIGFuZCB0aGVuIHJldHVybiIgd2l0aCAicmV0dXJuCgkg IGRldl9lcnJfcHJvYmUoKSIKCS0gUmVwbGFjZSBhbGwgInJldHVybiBJU19FUlIocHJpdi0+cmRl dikgPyBQVFJfRVJSKHByaXYtPnJkZXYpIDogMCIKCSAgd2l0aCAiUFRSX0VSUl9PUl9aRVJPKCki CgktIFJlcGxhY2UgInByaXYtPmRldi0+b2Zfbm9kZSIgd2l0aCAiZGV2X29mX25vZGUoKSIKCS0g QWRkIENvcHlyaWdodCBpbiB0aGUgc291cmNlIGNvZGUKCS0gQWRkIG1vZHVsZSBuYW1lIHJlbGF0 ZWQgZGVzY3JpcHRpb24gaW4gS2NvbmZpZyBoZWxwdGV4dAoJLSBBZGQgcHJvcGVyIHVuaXQgb2Yg Ik1UNjM3MF9NSVZSX0lCVVNfVEgiCgktIEFkZCBlcnJvciBjaGVjayBpbiAibXQ2MzcwX2NoZ19n ZXRfc3RhdHVzIgoJLSBSZW1vdmUgaW5jbHVkaW5nIDxtZWRpYXRlayxtdDYzNzBfYWRjLmg+IGhl YWRlciBmaWxlCgktIFJlbW92ZSByZWR1bmRhbnQgY29tbWEgb2YgZXZlcnkgZW51bSB0ZXJtaW5h dG9yIGxpbmUKCS0gUmVtb3ZlIHVud2FudGVkIGJsYW5rIGxpbmVzCgktIFJlbW92ZSB0aGUgdXNl bGVzcyBsYWJlbCAodG9nZ2xlX2Nmb19leGl0OikKCS0gUmVtb3ZlIHVzaW5nIGF0b21pYwoJLSBS ZW1vdmUgdXNpbmcgb2ZfbWF0Y2hfcHRyKCkKCS0gRml4IHNvbWUgaW5jb3JyZWN0IGNoYXJhY3Rl cnMKCS0gRml4IHVwZGF0aW5nIHdyb25nIGJpdHMgd2hlbiB1c2luZyBlbmFfZ3Bpb2Qgb2YgT1RH IHJlZ3VsYXRvcgoJLSBBZGp1c3QgdGhlIHByb2JlIG9yZGVyIGluIHByb2JlKCkKCi0gSW4gcGF0 Y2ggMTEvMTM6CgktIFJlcGxhY2UgdGV4dCAiTWVkaWF0ZWsiIHdpdGggIk1lZGlhVGVrIiBpbiBL Y29uZmlnCgktIFJlcGxhY2UgdGV4dCAiY29uc3QiIHdpdGggImNvbnN0YW50IiBpbiBLY29uZmln CgktIEFkZCBDb3B5cmlnaHQgaW4gdGhlIHNvdXJjZSBjb2RlCgotIEluIHBhdGNoIDEyLzEzOgoJ LSBSZXBsYWNlIHRleHQgIk1lZGlhdGVrIiB3aXRoICJNZWRpYVRlayIgaW4gS2NvbmZpZwoJLSBB ZGQgQ29weXJpZ2h0IGluIHRoZSBzb3VyY2UgY29kZQoKLSBJbiBwYXRjaCAxMy8xMzoKCS0gUmVw bGFjZSB0ZXh0ICJNZWRpYXRlayIgd2l0aCAiTWVkaWFUZWsiIGluIEtjb25maWcKCS0gQWRkIENv cHlyaWdodCBpbiB0aGUgc291cmNlIGNvZGUKCS0gUmV2aXNlIHRoZSBjb21tZW50IG9mICJQV00g SFlTIFNURVBTIgoKCkNoYW5nZXMgaW4gdjM6Ci0gUmVtb3ZlIEFEQyBBQkkgZmlsZSwgd2hpY2gg aXMgYWRkZWQgaW4gdjIgUGF0Y2ggNwotIEluIHBhdGNoIDAyLzE0OgoJLSBBZGQgaXRlbXMgYW5k IHJlbW92ZSBtYXhJdGVtcyBvZiBpby1jaGFubmVscwoJLSBBZGQgaW8tY2hhbm5lbC1uYW1lcyBh bmQgZGVzY3JpYmUgZWFjaCBpdGVtCgktIEFkZCAidW5ldmFsdWF0ZWRQcm9wZXJ0aWVzOiBmYWxz ZSIgaW4gInVzYi1vdGctdmJ1cy1yZWd1bGF0b3IiCgktIFJlbmFtZSAiZW5hYmxlLWdwaW8iIHRv ICJlbmFibGUtZ3Bpb3MiIGluICJ1c2Itb3RnLXZidXMtcmVndWxhdG9yIgoKLSBJbiBwYXRjaCAw My8xNDoKCS0gVXNlIGxlZHMtY2xhc3MtbXVsdGljb2xvci55YW1sIGluc3RlYWQgb2YgY29tbW9u LnlhbWwuCgktIFNwbGl0IG11bHRpLWxlZCBhbmQgbGVkIG5vZGUuCgktIEFkZCBzdWJkZXZpY2Ug ImxlZCIgaW4gIm11bHRpLWxlZCIuCgotIEluIHBhdGNoIDA0LzE0OgoJLSBSZW1vdmUgdGhlIGRl c2NyaXB0aW9uIG9mIGVudW0uCgotIEluIHBhdGNoIDA1LzE0OgoJLSBSZW5hbWUgIm1lZGlhdGVr LGJsZWQtcHdtLWh5cy1pbnB1dC10aHJlc2hvbGQtc3RlcHMiIHRvCgkgICJtZWRpYXRlayxibGVk LXB3bS1oeXMtaW5wdXQtdGgtc3RlcHMiCgktIFJlZmluZSAiYmxlZC1wd20taHlzLWlucHV0LXRo LXN0ZXBzIiwgImJsZWQtb3ZwLW1pY3Jvdm9sdCIsCgkgICJibGVkLW9jcC1taWNyb2FtcCIgZW51 bSB2YWx1ZXMKCi0gSW4gcGF0Y2ggMDYvMTQ6CgktIFVzZSAiIGluIGVudGlyZSBwYXRjaHNldAoJ LSBSZWZpbmUgQURDIGRlc2NyaXB0aW9uCgktIFJlbmFtZSAiZW5hYmxlLWdwaW8iIHRvICJlbmFi bGUtZ3Bpb3MiIGluICJyZWd1YWx0b3IiCgotIEluIHBhdGNoIDA3LzE0OgoJLSBSZWZpbmUgS2Nv bmZpZyBoZWxwIHRleHQKCS0gUmVmaW5lIGVycm9yIG1lc3NhZ2Ugb2YgdW5rbm93biB2ZW5kb3Ig SUQgaW4KCSAgbXQ2MzcwX2NoZWNrX3ZlbmRvcl9pbmZvKCkKCS0gUmVmaW5lIHJldHVybiB2YWx1 ZSBoYW5kbGluZyBvZiBtdDYzNzBfcmVnbWFwX3JlYWQoKQoJLSBSZWZpbmUgYWxsIHByb2JlIGVy cm9yIGJ5IHVzaW5nIGRldl9lcnJfcHJvYmUoKQoJLSBSZWZpbmUgImJhbmtfaWR4IiBhbmQgImJh bmtfYWRkciIgaW4gbXQ2MzcwX3JlZ21hcF9yZWFkKCkgYW5kCgkgIG10NjM3MF9yZWdtYXBfd3Jp dGUoKQoJLSBBZGQgIiNkZWZpbmUgVkVOSUQqIiBhbmQgZHJvcCB0aGUgY29tbWVudHMgaW4KCSAg bXQ2MzcwX2NoZWNrX3ZlbmRvcl9pbmZvKCkKCS0gRHJvcCAiTUZEIiBpbiBNT0RVTEVfREVTQ1JJ UFRJT04oKQoKLSBJbiBwYXRjaCAwOS8xNDoKCS0gUmVmaW5lIEtjb25maWcgaGVscCB0ZXh0Cgot IEluIHBhdGNoIDEwLzE0OgoJLSBSZWZpbmUgS2NvbmZpZyBoZWxwIHRleHQKCS0gUmVmaW5lIGFs bCBjaGFubmVsIHZhbHVlIGluIHJlYWRfc2NhbGUoKQoJCWEuIGN1cnJlbnQ6IHVBIC0tPiBtQQoJ CWIuIHZvbHRhZ2U6IHVWIC0tPiBtVgoJCWMuIHRlbXBlcmF0dXJlOiBkZWdyZWVzIENlbHNpdXMg LS0+IG1pbGxpIGRlZ3JlZXMgQ2Vsc2l1cwoJLSBBZGQgImRlZmF1bHQ6IiBjb25kaXRpb24gb2Yg c3dpdGNoIHN0YXRlbWVudCBpbiByZWFkX3NjYWxlKCkgYW5kIHJlYWRfcmF3KCkKCS0gQWRkIGVy cm9yIG1lc3NhZ2UgZm9yIHJlYWRpbmcgQURDIHJlZ2lzdGVyIGZhaWxlZAoJLSBBZGQgdGhlIGNv bW1lbnQgZm9yIGFkY19sb2NrCgktIEFkZCA8bGludXgvbW9kX2RldmljZXRhYmxlLmg+IGhlYWRl ciBmaWxlIGZvciBzdHJ1Y3Qgb2ZfZGV2aWNlX2lkCgktIFJlcGxhY2UgImFkYyIgdGV4dCB3aXRo ICJBREMiIGluIGFsbCBvZiB0aGUgZXJyb3IgbWVzc2FnZXMKCi0gSW4gcGF0Y2ggMTIvMTQ6Cgkt IFJlZmluZSB0aGUgZ3JhbW1lciBvZiB0aGUgS2NvbmZpZy4KCS0gQ2hhbmdlIHJlZyBtb2RlIHRv IHRoZSBjb25zdCBjdXJyZW50IG1vZGUuCgotIEluIHBhdGNoIDE0LzE0OgoJLSBSZWZpbmUgYm9v bCBwcm9wZXJ0aWVzIHBhcnNpbmcgKHB3bS1lbmFibGUsIG92cC1zaHV0ZG93biwgb2NwLXNodXRk b3duKSBpbiBEVAoJICBwYXJzaW5nIGZ1bmN0aW9uCgktIFJlZmluZSB1MzIgYW5kIHU4IHByb3Bl cnRpZXMgcGFyc2luZyAocHdtLWh5cy1pbnB1dC10aC1zdGVwcywgb3ZwLW1pY3Jvdm9sdCwKCSAg b2NwLW1pY3JvYW1wKSwgZnJvbSB1c2luZyByZWdpc3RlciB2YWx1ZSB0byB1c2luZyBhY3R1YWwg dmFsdWUKCS0gUmVmaW5lIGVycm9yIHN0cmluZyBvZiAiY2hhbm5sZS11c2UiIHBhcnNpbmcgZmFp bGVkCgktIFJlZmluZSBLY29uZmlnIGhlbHAgdGV4dAoKCkNoYW5nZXMgaW4gdjI6Ci0gSW4gcGF0 Y2ggMDEvMTU6CgktIEFkZCAidW5ldmFsdWF0ZWRQcm9wZXJ0aWVzOiBmYWxzZSIuCgktIERlbGV0 ZSAiRFQgYmluZGluZ3MiLgoJLSBSZWZpbmUgdGhlIGRlc2NyaXB0aW9uIHRvIGZpdCBpbiA4MCBj b2x1bW5zLgoJLSBTa2lwIHRoZSBjb25uZWN0b3IgZGVzY3JpcHRpb24uCgotIEluIHBhdGNoIDAy LzE1OgoJLSBSZWZpbmUgaXRlbXMgZGVzY3JpcHRpb24gb2YgaW50ZXJydXB0LW5hbWUKCS0gUmVu YW1lICJ1c2Itb3RnLXZidXMiIHRvICJ1c2Itb3RnLXZidXMtcmVndWxhdG9yIgoJLSBBZGQgY29u c3RyYWludCBwcm9wZXJ0aWVzIGZvciBBREMKCi0gSW4gcGF0Y2ggMDMvMTU6CgktIFNraXAgbm90 IHVzZWZ1bCBkZXNjcmlwdGlvbiBvZiAiXihtdWx0aS0pP2xlZEBbMC0zXSQiCgkgIGFuZCByZWcu CgktIER1ZSB0byB0aGUgZGVwZW5kZW5jeSwgcmVtb3ZlIHRoZSBtZW50aW9uIG9mIG1mZAoJICBk b2N1bWVudCBkaXJlY3RvcnkuCgktIERlbGV0ZSBTb2Z0LXN0YXJ0IHByb3BlcnR5LiBJbiBkZXNp Z24gYXNwZWN0LCB3ZSB0aGluawoJICBzb2Z0LXJlc3RhcnQgc2hvdWxkIGFsd2F5cyBiZSBlbmFi bGVkLCBvdXIgbmV3IGNoaXAKCSAgaGFzIGRlbGV0ZWQgdGhlIHJlbGF0ZWQgc2V0dGluZyByZWdp c3RlciAsIGFsc28sIHdlIGRvbuKAmXQKCSAgYWxsb3cgdXNlciBhZGp1c3QgdGhpcyBwYXJhbWV0 ZXIgaW4gdGhpcyBjaGlwLgoJLSBSZWZpbmUgdGhlIGNvbW1pdCBtZXNzYWdlLgoKLSBJbiBwYXRj aCAwNC8xNToKCS0gU2tpcCBub3QgdXNlZnVsIGRlc2NyaXB0aW9uIG9mICJebGVkQFswLTFdJCIg YW5kIHJlZy4KCS0gQWRkIGFwYWNlIGFmdGVyICcjJy4KCS0gUmVmaW5lIHRoZSBjb21taXQgbWVz c2FnZS4KCi0gSW4gcGF0Y2ggMDUvMTU6CgktIFJlbW92ZSAiYmluZGluZyBkb2N1bWVudGF0aW9u IiBpbiBzdWJqZWN0IHRpdGxlCgktIFJlZmluZSBkZXNjcmlwdGlvbiBvZiBtdDYzNzAgYmFja2xp Z2h0IGJpbmRpbmcKCSAgZG9jdW1lbnQKCS0gUmVmaW5lIHByb3BlcnRpZXMgbmFtZShibGVkLXB3 bS1oeXMtaW5wdXQtYml0LAoJICBibGVkLW92cC1taWNyb3ZvbHQsIGJsZWQtb2NwLW1pY3JvYW1w KSBhbmQgdGhlaXIKCSAgZGVzY3JpcHRpb24KCi0gSW4gcGF0Y2ggMDYvMTU6CgktIFJlZmluZSBB REMgYW5kIFJlZ3VsYXRvciBkZXNjcmlwdGlvbnMKCS0gUmVmaW5lIGluY2x1ZGUgaGVhZGVyIHVz YWdlIGluIGV4YW1wbGUKCS0gUmVmaW5lIG5vZGUgbmFtZSB0byBnZW5lcmljIG5vZGUgbmFtZSgi cG1pY0AzNCIpCgktIFJlZmluZSBsZWQgZXhhbXBsZSBpbmRlbnRhdGlvbgoJLSBSZWZpbmUgbGlj ZW5zZSBvZiBtZWRpYXRlayxtdDYzNzBfYWRjLmgKCS0gUmVuYW1lIHRoZSBkdHMgZXhhbXBsZSBm cm9tIElSUSBkZWZpbmUgdG8gbnVtYmVyLgoJLSBSZW1vdmUgbWVkaWF0ZWssbXQ2MzcwLmgKCi0g SW4gcGF0Y2ggMDcvMTU6CgktIEFkZCBBQkkgZG9jdW1lbnRhdGlvbiBmb3IgbXQ2MzcwIG5vbi1z dGFuZGFyZCBBREMKCSAgc3lzZnMgaW50ZXJmYWNlcy4KCi0gSW4gcGF0Y2ggMDgvMTU6CgktIEFk ZCBhbGwgSVJRIGRlZmluZSBpbnRvIG10NjM3MC5jLgoJLSBSZWZpbmUgaW5jbHVkZSBoZWFkZXIg dXNhZ2UKCi0gSW4gcGF0Y2ggMDkvMTU6CgktIE5vIGNoYW5nZXMuCgotIEluIHBhdGNoIDEwLzE1 OgoJLSBVc2UgJ2dwaW9kX2dldF9mcm9tX29mX25vZGUnIHRvIHJlcGxhY2UKCSAgJ2Z3bm9kZV9n cGlvZF9nZXRfaW5kZXgnLgoKLSBJbiBwYXRjaCAxMS8xNToKCS0gUmVmaW5lIEtjb25maWcgbXQ2 MzcwIGhlbHAgdGV4dAoJLSBSZWZpbmUgbWFzayZzaGlmdCB0byBGSUVMRF9QUkVQKCkKCS0gUmVm aW5lIG11dGV4IGxvY2sgbmFtZSAoImxvY2siIC0+ICJhZGNfbG9jayIpCgktIFJlZmluZSBtdDYz NzBfYWRjX3JlYWRfc2NhbGUoKQoJLSBSZWZpbmUgbXQ2MzcwX2FkY19yZWFkX29mZnNldCgpCgkt IFJlZmluZSBtdDYzNzBfY2hhbm5lbF9sYWJlbHNbXSBieSB1c2luZyBlbnVtIHRvIGluZGV4Cgkg IGNoYW4gc3BlYwoJLSBSZWZpbmUgTVQ2MzcwX0FEQ19DSEFOKCkKCS0gUmVmaW5lIGluZGlvX2Rl di0+bmFtZQoJLSBSZW1vdmUgdXNlbGVzcyBpbmNsdWRlIGhlYWRlciBmaWxlcwoKLSBJbiBwYXRj aCAxMi8xNToKCS0gUmVmaW5lIG10NjM3MF9jaGdfb3RnX3JkZXNjLm9mX21hdGNoCgkgICgibXQ2 MzcwLG90Zy12YnVzIiAtPiAidXNiLW90Zy12YnVzLXJlZ3VsYXRvciIpIHRvIG1hdGNoCgkgIERU IGJpbmRpbmcKCi0gSW4gcGF0Y2ggMTMvMTU6CgktIFJlZmluZSBLY29uZmlnIGRlc2NyaXB0aW9u LgoJLSBSZW1vdmUgaW5jbHVkZSAibGludXgvb2YuaCIgYW5kIHVzZQoJICAibGludXgvbW9kX2Rl dmljZXRhYmxlLmgiLgoJLSBQbGFjZSBhIGNvbW1hIGZvciB0aGUgbGFzdCBlbGVtZW50IG9mIHRo ZSBjb25zdAoJICB1bnNpZ25lZCBpbnQgYXJyYXkuCgktIEFkZCBhIGNvbW1lbnQgbGluZSBmb3Ig dGhlIG11dGV4ICdsb2NrJy4KCS0gSW4gcHJvYmUgZnVuY3Rpb24sIHVzZSAnZGV2X2Vycl9wcm9i ZScgaW4gc29tZQoJICBqdWRnZW1lbnQgdG8gcmVkdWNlIHRoZSBMT0MuCgktIFJlZmluZSBpbmNs dWRlIGhlYWRlciB1c2FnZS4KCSAgQklUL0dFTk1BU0sgLT4gbGludXgvYml0cy5oCgkgIEZJRUxE X0dFVCAtPiBsaW51eC9iaXRmaWVsZC5oCgotIEluIHBhdGNoIDE0LzE1OgoJLSBBZGQgYmxhbmsg bGluZS4KCS0gUmVwbGFjZSBjb250YWluZXJfb2YoKSB3aXRoIHRvX210NjM3MF9sZWQoKSAuCgkt IFJlZmluZSBkZXNjcmlwdGlvbiBvZiByYW1waW5nLgoJLSBSZWZpbmUgdGhlIG10NjM3MF9pbml0 X2NvbW1vbl9wcm9wZXJ0aWVzIGZ1bmN0aW9uLgoJLSBSZWZpbmUgdGhlIHByb2JlIHJldHVybi4K Ci0gSW4gcGF0Y2ggMTUvMTU6CgktIFJlZmluZSBNVDYzNzAgaGVscCB0ZXh0IGluIEtjb25maWcK CS0gUmVmaW5lIERUIFBhcnNlIGZ1bmN0aW9uCgktIFJlbW92ZSB1c2VsZXNzIGVudW0KCS0gQWRk IGNvbW1lbnQgZm9yIDYzNzIgYmFja3dhcmQgY29tcGF0aWJsZSBpbgoJICBibF91cGRhdGVfc3Rh dHVzKCkgYW5kCgkgIGNoZWNrX3ZlbmRvcl9pbmZvKCkKCS0gVXNpbmcgZGV2X2Vycl9wcm9iZSgp OyBpbnN0ZWFkcyBkZXZfZXJyKCkmcmV0dXJuOyBpbgoJICB0aGUgcHJvYmUoKQoKCgoKCgpBbGlj ZSBDaGVuICgyKToKICBkdC1iaW5kaW5nczogbGVkczogQWRkIE1lZGlhVGVrIE1UNjM3MCBmbGFz aGxpZ2h0CiAgbGVkczogZmxhc2g6IG10NjM3MDogQWRkIE1lZGlhVGVrIE1UNjM3MCBmbGFzaGxp Z2h0IHN1cHBvcnQKCkNoaVl1YW4gSHVhbmcgKDIpOgogIGR0LWJpbmRpbmdzOiBsZWRzOiBtdDYz NzA6IEFkZCBNZWRpYVRlayBNVDYzNzAgY3VycmVudCBzaW5rIHR5cGUgTEVECiAgICBpbmRpY2F0 b3IKICBsZWRzOiByZ2I6IG10NjM3MDogQWRkIE1lZGlhVGVrIE1UNjM3MCBjdXJyZW50IHNpbmsg dHlwZSBMRUQgSW5kaWNhdG9yCiAgICBzdXBwb3J0CgpDaGlhRW4gV3UgKDEpOgogIGlpbzogYWRj OiBtdDYzNzA6IEFkZCBNZWRpYVRlayBNVDYzNzAgc3VwcG9ydAoKIC4uLi9iaW5kaW5ncy9sZWRz L21lZGlhdGVrLG10NjM3MC1mbGFzaGxpZ2h0LnlhbWwgIHwgICA0MSArCiAuLi4vYmluZGluZ3Mv bGVkcy9tZWRpYXRlayxtdDYzNzAtaW5kaWNhdG9yLnlhbWwgICB8ICAgODIgKysKIGRyaXZlcnMv aWlvL2FkYy9LY29uZmlnICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgICAxMiArCiBkcml2 ZXJzL2lpby9hZGMvTWFrZWZpbGUgICAgICAgICAgICAgICAgICAgICAgICAgICB8ICAgIDEgKwog ZHJpdmVycy9paW8vYWRjL210NjM3MC1hZGMuYyAgICAgICAgICAgICAgICAgICAgICAgfCAgMzA1 ICsrKysrKwogZHJpdmVycy9sZWRzL2ZsYXNoL0tjb25maWcgICAgICAgICAgICAgICAgICAgICAg ICAgfCAgIDE0ICsKIGRyaXZlcnMvbGVkcy9mbGFzaC9NYWtlZmlsZSAgICAgICAgICAgICAgICAg ICAgICAgIHwgICAgMSArCiBkcml2ZXJzL2xlZHMvZmxhc2gvbGVkcy1tdDYzNzAtZmxhc2guYyAg ICAgICAgICAgICB8ICA2MzEgKysrKysrKysrKysrCiBkcml2ZXJzL2xlZHMvcmdiL0tjb25maWcg ICAgICAgICAgICAgICAgICAgICAgICAgICB8ICAgMTMgKwogZHJpdmVycy9sZWRzL3JnYi9NYWtl ZmlsZSAgICAgICAgICAgICAgICAgICAgICAgICAgfCAgICAxICsKIGRyaXZlcnMvbGVkcy9yZ2Iv bGVkcy1tdDYzNzAtcmdiLmMgICAgICAgICAgICAgICAgIHwgMTAxMCArKysrKysrKysrKysrKysr KysrKwogMTEgZmlsZXMgY2hhbmdlZCwgMjExMSBpbnNlcnRpb25zKCspCiBjcmVhdGUgbW9kZSAx MDA2NDQgRG9jdW1lbnRhdGlvbi9kZXZpY2V0cmVlL2JpbmRpbmdzL2xlZHMvbWVkaWF0ZWssbXQ2 MzcwLWZsYXNobGlnaHQueWFtbAogY3JlYXRlIG1vZGUgMTAwNjQ0IERvY3VtZW50YXRpb24vZGV2 aWNldHJlZS9iaW5kaW5ncy9sZWRzL21lZGlhdGVrLG10NjM3MC1pbmRpY2F0b3IueWFtbAogY3Jl YXRlIG1vZGUgMTAwNjQ0IGRyaXZlcnMvaWlvL2FkYy9tdDYzNzAtYWRjLmMKIGNyZWF0ZSBtb2Rl IDEwMDY0NCBkcml2ZXJzL2xlZHMvZmxhc2gvbGVkcy1tdDYzNzAtZmxhc2guYwogY3JlYXRlIG1v ZGUgMTAwNjQ0IGRyaXZlcnMvbGVkcy9yZ2IvbGVkcy1tdDYzNzAtcmdiLmMKCi0tIAoyLjcuNAoK Cl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4LWFy bS1rZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFkZWFkLm9y ZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFybS1r ZXJuZWwK