From mboxrd@z Thu Jan 1 00:00:00 1970 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="gkKJDvgM" Received: from mail-qv1-xf31.google.com (mail-qv1-xf31.google.com [IPv6:2607:f8b0:4864:20::f31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A27D41A5 for ; Tue, 5 Dec 2023 13:24:40 -0800 (PST) Received: by mail-qv1-xf31.google.com with SMTP id 6a1803df08f44-67ad531686eso1783806d6.1 for ; Tue, 05 Dec 2023 13:24:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1701811480; x=1702416280; darn=vger.kernel.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=I+Zh/59BXAZw04KlgIGnr6QtEam8qAlktoWUx+lSDLE=; b=gkKJDvgMv/ISDieJjGJqDpD/Nh7Y5g7py5cg62tNIdfROvDCnM1M8/WP0/eIsOawKW 9uijbTVeRL0yBG3FMNYH3u0cv6xirCwhyZ8jNekR1F4Veoc9IVFfgP2HwA2Hj17MQVm1 qSeDDXmkrpZIkQOmS5j5MenIecajQrMwLjJ+a+RArcSdIaMIXMIoRv/YY1Zx8e2Dp1da JX69XjgUNlg+1+x3uF5NbqipgQX2Ka3hMU5sllYknykayjDTObjj6/n+Op8c9LsuKGSx 0gXA8F+KiiVgsWG4fuCCk8hm10+U3tU7Hb3krKSTcBNct8tCWUxT1YivNtQ6fwqPrNml EQww== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1701811480; x=1702416280; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=I+Zh/59BXAZw04KlgIGnr6QtEam8qAlktoWUx+lSDLE=; b=GGkBrRieuXm+F4P5DHe/FlIUrmSmedAQYixHSKLf5pet9KHpNAGqK+Rda7x0xTBwrV sHNXjhJMcQHH03+CEgp9yzAq20ZdBJlU4rzQHBKi5vREI+nM0JSDL0UDthd7sepz5htT WxwRl0vD4uHEjk/a9flWLiGzVR1bbGWwNqb96uxRiNBjlyChw2HaewXsGJimlUqaN7/e VlM1zyCecabgNtt9PMXfQx1/1gtDdMTA6IRKMIDYi04ZzCnZtreW7fVVgmBEHOItOuwW AXhS7ChW6OFCc24yyVN8WjhOG8O3aM85RJkAXiQsojwfCunNB8Z8nsklsPcrFj4fDpP9 3KxA== X-Gm-Message-State: AOJu0Ywl3ZQWF8dT+4zRpA1PhE9s370MYbC9ZlCwFQWpMIG09gprsNbO GhHHqU6Z/Ua0HaJBcXLLFm7jvri38XFX52cpGqEbGw== X-Google-Smtp-Source: AGHT+IHGrwfoXR9dgLkuQhG24SlqBkj4ksLhAxMbg0X8Wz0N9cGgXzPI3/YlsWoPe0oJMONnAl2YcZ6IaDrYffNhzvI= X-Received: by 2002:a05:6214:500c:b0:67a:2f1b:dd33 with SMTP id jo12-20020a056214500c00b0067a2f1bdd33mr3614120qvb.2.1701811479711; Tue, 05 Dec 2023 13:24:39 -0800 (PST) Precedence: bulk X-Mailing-List: linux-gpio@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 References: <20231201160925.3136868-1-peter.griffin@linaro.org> <20231201160925.3136868-15-peter.griffin@linaro.org> In-Reply-To: From: Peter Griffin Date: Tue, 5 Dec 2023 21:24:28 +0000 Message-ID: Subject: Re: [PATCH v5 14/20] pinctrl: samsung: Add gs101 SoC pinctrl configuration To: Sam Protsenko Cc: robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, mturquette@baylibre.com, conor+dt@kernel.org, sboyd@kernel.org, tomasz.figa@gmail.com, s.nawrocki@samsung.com, linus.walleij@linaro.org, wim@linux-watchdog.org, linux@roeck-us.net, catalin.marinas@arm.com, will@kernel.org, arnd@arndb.de, olof@lixom.net, gregkh@linuxfoundation.org, jirislaby@kernel.org, cw00.choi@samsung.com, alim.akhtar@samsung.com, tudor.ambarus@linaro.org, andre.draszik@linaro.org, saravanak@google.com, willmcvicker@google.com, soc@kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-gpio@vger.kernel.org, linux-watchdog@vger.kernel.org, kernel-team@android.com, linux-serial@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Hi Sam, Thanks for the review. On Sat, 2 Dec 2023 at 00:40, Sam Protsenko wro= te: > > On Fri, Dec 1, 2023 at 10:11=E2=80=AFAM Peter Griffin wrote: > > > > Add support for the pin-controller found on the gs101 SoC used in > > Pixel 6 phones. > > > > Signed-off-by: Peter Griffin > > --- > > .../pinctrl/samsung/pinctrl-exynos-arm64.c | 159 ++++++++++++++++++ > > drivers/pinctrl/samsung/pinctrl-exynos.c | 2 + > > drivers/pinctrl/samsung/pinctrl-exynos.h | 34 ++++ > > drivers/pinctrl/samsung/pinctrl-samsung.c | 2 + > > drivers/pinctrl/samsung/pinctrl-samsung.h | 1 + > > 5 files changed, 198 insertions(+) > > > > diff --git a/drivers/pinctrl/samsung/pinctrl-exynos-arm64.c b/drivers/p= inctrl/samsung/pinctrl-exynos-arm64.c > > index cb965cf93705..e1a0668ecb16 100644 > > --- a/drivers/pinctrl/samsung/pinctrl-exynos-arm64.c > > +++ b/drivers/pinctrl/samsung/pinctrl-exynos-arm64.c > > @@ -796,3 +796,162 @@ const struct samsung_pinctrl_of_match_data fsd_of= _data __initconst =3D { > > .ctrl =3D fsd_pin_ctrl, > > .num_ctrl =3D ARRAY_SIZE(fsd_pin_ctrl), > > }; > > + > > +/* > > + * bank type for non-alive type > > + * (CON bit field: 4, DAT bit field: 1, PUD bit field: 4, DRV bit fiel= d: 4) > > + * (CONPDN bit field: 2, PUDPDN bit field: 4) > > + */ > > +static struct samsung_pin_bank_type gs101_bank_type_off =3D { > > + .fld_width =3D { 4, 1, 4, 4, 2, 4, }, > > + .reg_offset =3D { 0x00, 0x04, 0x08, 0x0c, 0x10, 0x14, }, > > +}; > > This is just the same as exynos850_bank_type_off (100% duplication). Ah nice, I hadn't spotted that these structs matched exynos850. > Here is what I suggest. Now that it's obvious there is some common > platform for moder Exynos SoCs, and it's probably Exynos9, I'd suggest > next course of action (if maintainers agree): > 1. Remove this one > 2. Rename exynos850_bank_type_off to exynos9_bank_type_off > 3. Use it for both gs101 and exynos850 > > Does it make sense? Yes, sounds like a good plan to me. I just checked downstream and they were called bank_type_6 and bank_type_7 originally. @Krzysztof - are you OK with the proposed generic name above (exynos9_bank_type_off?) to be used by both exynos850 and gs101 (and also future Tensor exynos based SoCs)? > > > + > > +/* > > + * bank type for alive type > > + * (CON bit field: 4, DAT bit field: 1, PUD bit field: 4, DRV bit fiel= d: 4) > > + */ > > +static const struct samsung_pin_bank_type gs101_bank_type_alive =3D { > > + .fld_width =3D { 4, 1, 4, 4, }, > > + .reg_offset =3D { 0x00, 0x04, 0x08, 0x0c, }, > > +}; > > Ditto, it's a duplication of exynos850_bank_type_alive . > > > + > > +/* pin banks of gs101 pin-controller (ALIVE) */ > > +static const struct samsung_pin_bank_data gs101_pin_alive[] =3D { > > + EXYNOS9_PIN_BANK_EINTW(8, 0x0, "gpa0", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTW(7, 0x20, "gpa1", 0x04, 0x08), > > + EXYNOS9_PIN_BANK_EINTW(5, 0x40, "gpa2", 0x08, 0x10), > > + EXYNOS9_PIN_BANK_EINTW(4, 0x60, "gpa3", 0x0c, 0x18), > > + EXYNOS9_PIN_BANK_EINTW(4, 0x80, "gpa4", 0x10, 0x1c), > > + EXYNOS9_PIN_BANK_EINTW(7, 0xa0, "gpa5", 0x14, 0x20), > > + EXYNOS9_PIN_BANK_EINTW(8, 0xc0, "gpa9", 0x18, 0x28), > > + EXYNOS9_PIN_BANK_EINTW(2, 0xe0, "gpa10", 0x1c, 0x30), > > +}; > > + > > +/* pin banks of gs101 pin-controller (FAR_ALIVE) */ > > +static const struct samsung_pin_bank_data gs101_pin_far_alive[] =3D { > > + EXYNOS9_PIN_BANK_EINTW(8, 0x0, "gpa6", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTW(4, 0x20, "gpa7", 0x04, 0x08), > > + EXYNOS9_PIN_BANK_EINTW(8, 0x40, "gpa8", 0x08, 0x0c), > > + EXYNOS9_PIN_BANK_EINTW(2, 0x60, "gpa11", 0x0c, 0x14), > > +}; > > + > > +/* pin banks of gs101 pin-controller (GSACORE) */ > > +static const struct samsung_pin_bank_data gs101_pin_gsacore[] =3D { > > + EXYNOS9_PIN_BANK_EINTG(2, 0x0, "gps0", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTG(8, 0x20, "gps1", 0x04, 0x04), > > + EXYNOS9_PIN_BANK_EINTG(3, 0x40, "gps2", 0x08, 0x0c), > > +}; > > + > > +/* pin banks of gs101 pin-controller (GSACTRL) */ > > +static const struct samsung_pin_bank_data gs101_pin_gsactrl[] =3D { > > + EXYNOS9_PIN_BANK_EINTW(6, 0x0, "gps3", 0x00, 0x00), > > +}; > > + > > +/* pin banks of gs101 pin-controller (PERIC0) */ > > +static const struct samsung_pin_bank_data gs101_pin_peric0[] =3D { > > + EXYNOS9_PIN_BANK_EINTG(5, 0x0, "gpp0", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x20, "gpp1", 0x04, 0x08), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x40, "gpp2", 0x08, 0x0c), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x60, "gpp3", 0x0c, 0x10), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x80, "gpp4", 0x10, 0x14), > > + EXYNOS9_PIN_BANK_EINTG(2, 0xa0, "gpp5", 0x14, 0x18), > > + EXYNOS9_PIN_BANK_EINTG(4, 0xc0, "gpp6", 0x18, 0x1c), > > + EXYNOS9_PIN_BANK_EINTG(2, 0xe0, "gpp7", 0x1c, 0x20), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x100, "gpp8", 0x20, 0x24), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x120, "gpp9", 0x24, 0x28), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x140, "gpp10", 0x28, 0x2c), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x160, "gpp11", 0x2c, 0x30), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x180, "gpp12", 0x30, 0x34), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x1a0, "gpp13", 0x34, 0x38), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x1c0, "gpp14", 0x38, 0x3c), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x1e0, "gpp15", 0x3c, 0x40), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x200, "gpp16", 0x40, 0x44), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x220, "gpp17", 0x44, 0x48), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x240, "gpp18", 0x48, 0x4c), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x260, "gpp19", 0x4c, 0x50), > > +}; > > + > > +/* pin banks of gs101 pin-controller (PERIC1) */ > > +static const struct samsung_pin_bank_data gs101_pin_peric1[] =3D { > > + EXYNOS9_PIN_BANK_EINTG(8, 0x0, "gpp20", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x20, "gpp21", 0x04, 0x08), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x40, "gpp22", 0x08, 0x0c), > > + EXYNOS9_PIN_BANK_EINTG(8, 0x60, "gpp23", 0x0c, 0x10), > > + EXYNOS9_PIN_BANK_EINTG(4, 0x80, "gpp24", 0x10, 0x18), > > + EXYNOS9_PIN_BANK_EINTG(4, 0xa0, "gpp25", 0x14, 0x1c), > > + EXYNOS9_PIN_BANK_EINTG(5, 0xc0, "gpp26", 0x18, 0x20), > > + EXYNOS9_PIN_BANK_EINTG(4, 0xe0, "gpp27", 0x1c, 0x28), > > +}; > > + > > +/* pin banks of gs101 pin-controller (HSI1) */ > > +static const struct samsung_pin_bank_data gs101_pin_hsi1[] =3D { > > + EXYNOS9_PIN_BANK_EINTG(6, 0x0, "gph0", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTG(7, 0x20, "gph1", 0x04, 0x08), > > +}; > > + > > +/* pin banks of gs101 pin-controller (HSI2) */ > > +static const struct samsung_pin_bank_data gs101_pin_hsi2[] =3D { > > + EXYNOS9_PIN_BANK_EINTG(6, 0x0, "gph2", 0x00, 0x00), > > + EXYNOS9_PIN_BANK_EINTG(2, 0x20, "gph3", 0x04, 0x08), > > + EXYNOS9_PIN_BANK_EINTG(6, 0x40, "gph4", 0x08, 0x0c), > > +}; > > + > > +static const struct samsung_pin_ctrl gs101_pin_ctrl[] __initconst =3D = { > > + { > > + /* pin banks of gs101 pin-controller (ALIVE) */ > > + .pin_banks =3D gs101_pin_alive, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_alive), > > + .eint_wkup_init =3D exynos_eint_wkup_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, { > > + /* pin banks of gs101 pin-controller (FAR_ALIVE) */ > > + .pin_banks =3D gs101_pin_far_alive, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_far_alive), > > + .eint_wkup_init =3D exynos_eint_wkup_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, { > > + /* pin banks of gs101 pin-controller (GSACORE) */ > > + .pin_banks =3D gs101_pin_gsacore, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_gsacore), > > + }, { > > + /* pin banks of gs101 pin-controller (GSACTRL) */ > > + .pin_banks =3D gs101_pin_gsactrl, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_gsactrl), > > + }, { > > + /* pin banks of gs101 pin-controller (PERIC0) */ > > + .pin_banks =3D gs101_pin_peric0, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_peric0), > > + .eint_gpio_init =3D exynos_eint_gpio_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, { > > + /* pin banks of gs101 pin-controller (PERIC1) */ > > + .pin_banks =3D gs101_pin_peric1, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_peric1), > > + .eint_gpio_init =3D exynos_eint_gpio_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, { > > + /* pin banks of gs101 pin-controller (HSI1) */ > > + .pin_banks =3D gs101_pin_hsi1, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_hsi1), > > + .eint_gpio_init =3D exynos_eint_gpio_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, { > > + /* pin banks of gs101 pin-controller (HSI2) */ > > + .pin_banks =3D gs101_pin_hsi2, > > + .nr_banks =3D ARRAY_SIZE(gs101_pin_hsi2), > > + .eint_gpio_init =3D exynos_eint_gpio_init, > > + .suspend =3D exynos_pinctrl_suspend, > > + .resume =3D exynos_pinctrl_resume, > > + }, > > +}; > > + > > +const struct samsung_pinctrl_of_match_data gs101_of_data __initconst = =3D { > > + .ctrl =3D gs101_pin_ctrl, > > + .num_ctrl =3D ARRAY_SIZE(gs101_pin_ctrl), > > +}; > > diff --git a/drivers/pinctrl/samsung/pinctrl-exynos.c b/drivers/pinctrl= /samsung/pinctrl-exynos.c > > index 56fc11a1fe2f..75b9cf72ce73 100644 > > --- a/drivers/pinctrl/samsung/pinctrl-exynos.c > > +++ b/drivers/pinctrl/samsung/pinctrl-exynos.c > > @@ -537,6 +537,8 @@ static const struct of_device_id exynos_wkup_irq_id= s[] =3D { > > .data =3D &exynos7_wkup_irq_chip }, > > { .compatible =3D "samsung,exynosautov9-wakeup-eint", > > .data =3D &exynos7_wkup_irq_chip }, > > + { .compatible =3D "google,gs101-wakeup-eint", > > + .data =3D &exynos7_wkup_irq_chip }, > > { } > > }; > > > > diff --git a/drivers/pinctrl/samsung/pinctrl-exynos.h b/drivers/pinctrl= /samsung/pinctrl-exynos.h > > index e2799ff1b5e9..1ffc90db079d 100644 > > --- a/drivers/pinctrl/samsung/pinctrl-exynos.h > > +++ b/drivers/pinctrl/samsung/pinctrl-exynos.h > > @@ -147,6 +147,40 @@ > > .name =3D id \ > > } > > > > +#define EXYNOS9_PIN_BANK_EINTN(types, pins, reg, id) \ > > + { \ > > + .type =3D &types, \ > > + .pctl_offset =3D reg, \ > > + .nr_pins =3D pins, \ > > + .eint_type =3D EINT_TYPE_NONE, \ > > + .fltcon_type =3D FLT_DEFAULT \ > > + .name =3D id \ > > + } > > Where exactly it is used? What is 'types'? EXYNOS9_PIN_BANK_EINTN macro can be dropped completely for gs101 as it isn't used anywhere. I checked downstream code and it is declared and not used there as well. >Moreover, it doesn't look > very different from EXYNOS850_PIN_BANK_EINTN() -- just because I > created EXYNOS850_PIN_BANK_EINTN() exactly from this downstream macro. > I was strictly prohibited adding EXYNOS9_* stuff back at the time. But > now I guess it should be apparent we are actually dealing with Exynos9 > common platform. So I suggest renaming EXYNOS850_PIN_BANK_EINTN() to > EXYNOS9_PIN_BANK_EINTN(). > > > + > > +#define EXYNOS9_PIN_BANK_EINTG(pins, reg, id, offs, fltcon_offs) \ > > + { \ > > + .type =3D &gs101_bank_type_off, \ > > + .pctl_offset =3D reg, \ > > + .nr_pins =3D pins, \ > > + .eint_type =3D EINT_TYPE_GPIO, \ > > + .eint_offset =3D offs, \ > > + .fltcon_type =3D FLT_DEFAULT, \ > > + .fltcon_offset =3D fltcon_offs, \ > > + .name =3D id \ > > + } > > Ditto. Please add filter fields to EXYNOS850_PIN_BANK_EINTG() instead > of adding pretty much the same macro (it is the same, I created > EXYNOS850_PIN_BANK_EINTG() from exactly this macro). Also I suggest > renaming EXYNOS850_PIN_BANK_EINTG() to EXYNOS9_PIN_BANK_EINTG(), to > avoid confusion. If you need any help with reworking Exynos850 pinctrl > correspondingly, please let me know. The only issue for me migrating Exynos850 to EXYNOS9_PIN_BANK_EINTG is knowing what the fltcon_offset is. Can you provide the fltcon_offset offsets for the relevant Exynos850 banks and help test? Thanks, Peter. > > > + > > +#define EXYNOS9_PIN_BANK_EINTW(pins, reg, id, offs, fltcon_offs) \ > > + { \ > > + .type =3D &gs101_bank_type_alive, \ > > + .pctl_offset =3D reg, \ > > + .nr_pins =3D pins, \ > > + .eint_type =3D EINT_TYPE_WKUP, \ > > + .eint_offset =3D offs, \ > > + .fltcon_type =3D FLT_SELECTABLE, \ > > + .fltcon_offset =3D fltcon_offs, \ > > + .name =3D id \ > > + } > > Ditto. > > > + > > /** > > * struct exynos_weint_data: irq specific data for all the wakeup inte= rrupts > > * generated by the external wakeup interrupt controller. > > diff --git a/drivers/pinctrl/samsung/pinctrl-samsung.c b/drivers/pinctr= l/samsung/pinctrl-samsung.c > > index 50c360b4753a..982a5702714c 100644 > > --- a/drivers/pinctrl/samsung/pinctrl-samsung.c > > +++ b/drivers/pinctrl/samsung/pinctrl-samsung.c > > @@ -1323,6 +1323,8 @@ static const struct of_device_id samsung_pinctrl_= dt_match[] =3D { > > .data =3D &exynosautov9_of_data }, > > { .compatible =3D "tesla,fsd-pinctrl", > > .data =3D &fsd_of_data }, > > + { .compatible =3D "google,gs101-pinctrl", > > + .data =3D &gs101_of_data }, > > #endif > > #ifdef CONFIG_PINCTRL_S3C64XX > > { .compatible =3D "samsung,s3c64xx-pinctrl", > > diff --git a/drivers/pinctrl/samsung/pinctrl-samsung.h b/drivers/pinctr= l/samsung/pinctrl-samsung.h > > index 5fab3885a7d7..f6856290608c 100644 > > --- a/drivers/pinctrl/samsung/pinctrl-samsung.h > > +++ b/drivers/pinctrl/samsung/pinctrl-samsung.h > > @@ -373,6 +373,7 @@ extern const struct samsung_pinctrl_of_match_data e= xynos7885_of_data; > > extern const struct samsung_pinctrl_of_match_data exynos850_of_data; > > extern const struct samsung_pinctrl_of_match_data exynosautov9_of_data= ; > > extern const struct samsung_pinctrl_of_match_data fsd_of_data; > > +extern const struct samsung_pinctrl_of_match_data gs101_of_data; > > extern const struct samsung_pinctrl_of_match_data s3c64xx_of_data; > > extern const struct samsung_pinctrl_of_match_data s3c2412_of_data; > > extern const struct samsung_pinctrl_of_match_data s3c2416_of_data; > > -- > > 2.43.0.rc2.451.g8631bc7472-goog > > 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 0820CC4167B for ; Tue, 5 Dec 2023 21:25:18 +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:Cc:To:Subject:Message-ID:Date:From: In-Reply-To:References:MIME-Version:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=Ue+Xn1fXEhb7f+L92t6y14ldQ7xITLvYl4d5Lm3Z05U=; b=crcI6gWBk8WzAR RxGo30QMON2D7eLNzWGoqxt+00Y8A/puvfc9ESqdkeF0r8cryeL4Y62JJUasA0LoesMOEwMyzEXDJ 6q8D+dctDaQJ1ug7bV9Jy9mOOK5XP338dMhbCvPm+Os8S7K6k9MsLA35LiNC3FkScdnAtaaaNtgDp m1HD5fipW2jP1nhe8Y6G59zwVqpkeeBqwigHHr5yDWGdHAnkRG+GKsMOTphPDioqD6+Tsr4qNUCDy +QUQFdSnacRPhYXeWcAhGnKY1W5sPQFQCo4Rp6My24r6Z6LN7YasHkHwzNVBjYQ2stmxwu+MSqxC5 RUxYNtCA7u6PTQPmSn/A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1rAcuM-008R95-1t; Tue, 05 Dec 2023 21:24:46 +0000 Received: from mail-qv1-xf2c.google.com ([2607:f8b0:4864:20::f2c]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1rAcuI-008R7U-29 for linux-arm-kernel@lists.infradead.org; Tue, 05 Dec 2023 21:24:45 +0000 Received: by mail-qv1-xf2c.google.com with SMTP id 6a1803df08f44-67ad531686eso1783846d6.1 for ; Tue, 05 Dec 2023 13:24:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1701811480; x=1702416280; darn=lists.infradead.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=I+Zh/59BXAZw04KlgIGnr6QtEam8qAlktoWUx+lSDLE=; b=UaUpDk761JlPeLJBNs4l2EU0JswvkVdIN7PHNX7Nw98Z1z3jEXaHrTqO31hxeKTuhK aL43N4eoOwNfQkUe9nGrgfbRAkyr8Z3s781yvBBpE/JJp1hDqvgBOWAGdkBvpDQurq5N Hk3tAji8Z70jCBcxQBQHr0l61lfylS9QDsle/SkP92xXYk0PFWTS1TWYZyCF+XgeXjHe 9rpw+t/YUZnWsa3MpqZcdETjxTmY4/lNUxb9B7lSpvTX9oA2Xfbc9nKbc0tQveBsH2GU htlKo6LiZysvkTltJQHHK+qIldnjpm8ONgHucyk3NUwMdI4A4duVI+I7ZioC4BH38DFL aH4g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1701811480; x=1702416280; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=I+Zh/59BXAZw04KlgIGnr6QtEam8qAlktoWUx+lSDLE=; b=JlT+HX7crtt09vdU39xsMU+iXFjVcUakb5hjA2aazQhSxz5Y1p16m2S+jCusGfYZbv cZ3tnVPMi+5ZjzMu3m3KlQjQvH5HqUBuU7gBk+WyznS10wSQtrdNGmLAPnPk6H4bsfWC q1TpP48VkpFUmULeXXa1vcDOj6VZY+xjCwq7MfPu0ncCQd/yCo+NtVGEeqfo5DE4aSfC VkUEErglbxHIGD0fGU9tV0+2Ez65Gg0A/kjGitnCT3SFNmL2VkoYD0XG9/xj2W3LgrF8 IRsiVrob481VA3BFNUhca6Xkpk10YoZWHVEcRcYhOsTqgJyxv/rqFid4OWoor99KJ0F5 u+cQ== X-Gm-Message-State: AOJu0YyPQermdXJkTbJEBHa8KYmsOIW7s6prZGio9GUfhauiDavStNSd waW7iI+5EnPnaoNDeUwHFAE/FfMD0yxbBWn1u8h0jA== X-Google-Smtp-Source: AGHT+IHGrwfoXR9dgLkuQhG24SlqBkj4ksLhAxMbg0X8Wz0N9cGgXzPI3/YlsWoPe0oJMONnAl2YcZ6IaDrYffNhzvI= X-Received: by 2002:a05:6214:500c:b0:67a:2f1b:dd33 with SMTP id jo12-20020a056214500c00b0067a2f1bdd33mr3614120qvb.2.1701811479711; Tue, 05 Dec 2023 13:24:39 -0800 (PST) MIME-Version: 1.0 References: <20231201160925.3136868-1-peter.griffin@linaro.org> <20231201160925.3136868-15-peter.griffin@linaro.org> In-Reply-To: From: Peter Griffin Date: Tue, 5 Dec 2023 21:24:28 +0000 Message-ID: Subject: Re: [PATCH v5 14/20] pinctrl: samsung: Add gs101 SoC pinctrl configuration To: Sam Protsenko Cc: robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, mturquette@baylibre.com, conor+dt@kernel.org, sboyd@kernel.org, tomasz.figa@gmail.com, s.nawrocki@samsung.com, linus.walleij@linaro.org, wim@linux-watchdog.org, linux@roeck-us.net, catalin.marinas@arm.com, will@kernel.org, arnd@arndb.de, olof@lixom.net, gregkh@linuxfoundation.org, jirislaby@kernel.org, cw00.choi@samsung.com, alim.akhtar@samsung.com, tudor.ambarus@linaro.org, andre.draszik@linaro.org, saravanak@google.com, willmcvicker@google.com, soc@kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-gpio@vger.kernel.org, linux-watchdog@vger.kernel.org, kernel-team@android.com, linux-serial@vger.kernel.org X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20231205_132442_722656_6DFE6B64 X-CRM114-Status: GOOD ( 28.37 ) 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 SGkgU2FtLAoKVGhhbmtzIGZvciB0aGUgcmV2aWV3LgoKT24gU2F0LCAyIERlYyAyMDIzIGF0IDAw OjQwLCBTYW0gUHJvdHNlbmtvIDxzZW1lbi5wcm90c2Vua29AbGluYXJvLm9yZz4gd3JvdGU6Cj4K PiBPbiBGcmksIERlYyAxLCAyMDIzIGF0IDEwOjEx4oCvQU0gUGV0ZXIgR3JpZmZpbiA8cGV0ZXIu Z3JpZmZpbkBsaW5hcm8ub3JnPiB3cm90ZToKPiA+Cj4gPiBBZGQgc3VwcG9ydCBmb3IgdGhlIHBp bi1jb250cm9sbGVyIGZvdW5kIG9uIHRoZSBnczEwMSBTb0MgdXNlZCBpbgo+ID4gUGl4ZWwgNiBw aG9uZXMuCj4gPgo+ID4gU2lnbmVkLW9mZi1ieTogUGV0ZXIgR3JpZmZpbiA8cGV0ZXIuZ3JpZmZp bkBsaW5hcm8ub3JnPgo+ID4gLS0tCj4gPiAgLi4uL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLWV4 eW5vcy1hcm02NC5jICAgIHwgMTU5ICsrKysrKysrKysrKysrKysrKwo+ID4gIGRyaXZlcnMvcGlu Y3RybC9zYW1zdW5nL3BpbmN0cmwtZXh5bm9zLmMgICAgICB8ICAgMiArCj4gPiAgZHJpdmVycy9w aW5jdHJsL3NhbXN1bmcvcGluY3RybC1leHlub3MuaCAgICAgIHwgIDM0ICsrKysKPiA+ICBkcml2 ZXJzL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLXNhbXN1bmcuYyAgICAgfCAgIDIgKwo+ID4gIGRy aXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwtc2Ftc3VuZy5oICAgICB8ICAgMSArCj4gPiAg NSBmaWxlcyBjaGFuZ2VkLCAxOTggaW5zZXJ0aW9ucygrKQo+ID4KPiA+IGRpZmYgLS1naXQgYS9k cml2ZXJzL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLWV4eW5vcy1hcm02NC5jIGIvZHJpdmVycy9w aW5jdHJsL3NhbXN1bmcvcGluY3RybC1leHlub3MtYXJtNjQuYwo+ID4gaW5kZXggY2I5NjVjZjkz NzA1Li5lMWEwNjY4ZWNiMTYgMTAwNjQ0Cj4gPiAtLS0gYS9kcml2ZXJzL3BpbmN0cmwvc2Ftc3Vu Zy9waW5jdHJsLWV4eW5vcy1hcm02NC5jCj4gPiArKysgYi9kcml2ZXJzL3BpbmN0cmwvc2Ftc3Vu Zy9waW5jdHJsLWV4eW5vcy1hcm02NC5jCj4gPiBAQCAtNzk2LDMgKzc5NiwxNjIgQEAgY29uc3Qg c3RydWN0IHNhbXN1bmdfcGluY3RybF9vZl9tYXRjaF9kYXRhIGZzZF9vZl9kYXRhIF9faW5pdGNv bnN0ID0gewo+ID4gICAgICAgICAuY3RybCAgICAgICAgICAgPSBmc2RfcGluX2N0cmwsCj4gPiAg ICAgICAgIC5udW1fY3RybCAgICAgICA9IEFSUkFZX1NJWkUoZnNkX3Bpbl9jdHJsKSwKPiA+ICB9 Owo+ID4gKwo+ID4gKy8qCj4gPiArICogYmFuayB0eXBlIGZvciBub24tYWxpdmUgdHlwZQo+ID4g KyAqIChDT04gYml0IGZpZWxkOiA0LCBEQVQgYml0IGZpZWxkOiAxLCBQVUQgYml0IGZpZWxkOiA0 LCBEUlYgYml0IGZpZWxkOiA0KQo+ID4gKyAqIChDT05QRE4gYml0IGZpZWxkOiAyLCBQVURQRE4g Yml0IGZpZWxkOiA0KQo+ID4gKyAqLwo+ID4gK3N0YXRpYyBzdHJ1Y3Qgc2Ftc3VuZ19waW5fYmFu a190eXBlIGdzMTAxX2JhbmtfdHlwZV9vZmYgID0gewo+ID4gKyAgICAgICAuZmxkX3dpZHRoID0g eyA0LCAxLCA0LCA0LCAyLCA0LCB9LAo+ID4gKyAgICAgICAucmVnX29mZnNldCA9IHsgMHgwMCwg MHgwNCwgMHgwOCwgMHgwYywgMHgxMCwgMHgxNCwgfSwKPiA+ICt9Owo+Cj4gVGhpcyBpcyBqdXN0 IHRoZSBzYW1lIGFzIGV4eW5vczg1MF9iYW5rX3R5cGVfb2ZmICgxMDAlIGR1cGxpY2F0aW9uKS4K CkFoIG5pY2UsIEkgaGFkbid0IHNwb3R0ZWQgdGhhdCB0aGVzZSBzdHJ1Y3RzIG1hdGNoZWQgZXh5 bm9zODUwLgoKPiBIZXJlIGlzIHdoYXQgSSBzdWdnZXN0LiBOb3cgdGhhdCBpdCdzIG9idmlvdXMg dGhlcmUgaXMgc29tZSBjb21tb24KPiBwbGF0Zm9ybSBmb3IgbW9kZXIgRXh5bm9zIFNvQ3MsIGFu ZCBpdCdzIHByb2JhYmx5IEV4eW5vczksIEknZCBzdWdnZXN0Cj4gbmV4dCBjb3Vyc2Ugb2YgYWN0 aW9uIChpZiBtYWludGFpbmVycyBhZ3JlZSk6Cj4gICAxLiBSZW1vdmUgdGhpcyBvbmUKPiAgIDIu IFJlbmFtZSBleHlub3M4NTBfYmFua190eXBlX29mZiB0byBleHlub3M5X2JhbmtfdHlwZV9vZmYK PiAgIDMuIFVzZSBpdCBmb3IgYm90aCBnczEwMSBhbmQgZXh5bm9zODUwCj4KPiBEb2VzIGl0IG1h a2Ugc2Vuc2U/CgpZZXMsIHNvdW5kcyBsaWtlIGEgZ29vZCBwbGFuIHRvIG1lLiBJIGp1c3QgY2hl Y2tlZCBkb3duc3RyZWFtIGFuZCB0aGV5CndlcmUgY2FsbGVkIGJhbmtfdHlwZV82IGFuZCBiYW5r X3R5cGVfNyBvcmlnaW5hbGx5LgoKQEtyenlzenRvZiAtIGFyZSB5b3UgT0sgd2l0aCB0aGUgcHJv cG9zZWQgZ2VuZXJpYyBuYW1lIGFib3ZlCihleHlub3M5X2JhbmtfdHlwZV9vZmY/KSB0byBiZSB1 c2VkIGJ5IGJvdGggZXh5bm9zODUwIGFuZCBnczEwMSAoYW5kCmFsc28gZnV0dXJlIFRlbnNvciBl eHlub3MgYmFzZWQgU29Dcyk/Cgo+Cj4gPiArCj4gPiArLyoKPiA+ICsgKiBiYW5rIHR5cGUgZm9y IGFsaXZlIHR5cGUKPiA+ICsgKiAoQ09OIGJpdCBmaWVsZDogNCwgREFUIGJpdCBmaWVsZDogMSwg UFVEIGJpdCBmaWVsZDogNCwgRFJWIGJpdCBmaWVsZDogNCkKPiA+ICsgKi8KPiA+ICtzdGF0aWMg Y29uc3Qgc3RydWN0IHNhbXN1bmdfcGluX2JhbmtfdHlwZSBnczEwMV9iYW5rX3R5cGVfYWxpdmUg PSB7Cj4gPiArICAgICAgIC5mbGRfd2lkdGggPSB7IDQsIDEsIDQsIDQsIH0sCj4gPiArICAgICAg IC5yZWdfb2Zmc2V0ID0geyAweDAwLCAweDA0LCAweDA4LCAweDBjLCB9LAo+ID4gK307Cj4KPiBE aXR0bywgaXQncyBhIGR1cGxpY2F0aW9uIG9mIGV4eW5vczg1MF9iYW5rX3R5cGVfYWxpdmUgLgo+ Cj4gPiArCj4gPiArLyogcGluIGJhbmtzIG9mIGdzMTAxIHBpbi1jb250cm9sbGVyIChBTElWRSkg Ki8KPiA+ICtzdGF0aWMgY29uc3Qgc3RydWN0IHNhbXN1bmdfcGluX2JhbmtfZGF0YSBnczEwMV9w aW5fYWxpdmVbXSA9IHsKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5UVyg4LCAweDAs ICJncGEwIiwgMHgwMCwgMHgwMCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVFco NywgMHgyMCwgImdwYTEiLCAweDA0LCAweDA4KSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFO S19FSU5UVyg1LCAweDQwLCAiZ3BhMiIsIDB4MDgsIDB4MTApLAo+ID4gKyAgICAgICBFWFlOT1M5 X1BJTl9CQU5LX0VJTlRXKDQsIDB4NjAsICJncGEzIiwgMHgwYywgMHgxOCksCj4gPiArICAgICAg IEVYWU5PUzlfUElOX0JBTktfRUlOVFcoNCwgMHg4MCwgImdwYTQiLCAweDEwLCAweDFjKSwKPiA+ ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5UVyg3LCAweGEwLCAiZ3BhNSIsIDB4MTQsIDB4 MjApLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRXKDgsIDB4YzAsICJncGE5Iiwg MHgxOCwgMHgyOCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVFcoMiwgMHhlMCwg ImdwYTEwIiwgMHgxYywgMHgzMCksCj4gPiArfTsKPiA+ICsKPiA+ICsvKiBwaW4gYmFua3Mgb2Yg Z3MxMDEgcGluLWNvbnRyb2xsZXIgKEZBUl9BTElWRSkgKi8KPiA+ICtzdGF0aWMgY29uc3Qgc3Ry dWN0IHNhbXN1bmdfcGluX2JhbmtfZGF0YSBnczEwMV9waW5fZmFyX2FsaXZlW10gPSB7Cj4gPiAr ICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVFcoOCwgMHgwLCAiZ3BhNiIsIDB4MDAsIDB4MDAp LAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRXKDQsIDB4MjAsICJncGE3IiwgMHgw NCwgMHgwOCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVFcoOCwgMHg0MCwgImdw YTgiLCAweDA4LCAweDBjKSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5UVygyLCAw eDYwLCAiZ3BhMTEiLCAweDBjLCAweDE0KSwKPiA+ICt9Owo+ID4gKwo+ID4gKy8qIHBpbiBiYW5r cyBvZiBnczEwMSBwaW4tY29udHJvbGxlciAoR1NBQ09SRSkgKi8KPiA+ICtzdGF0aWMgY29uc3Qg c3RydWN0IHNhbXN1bmdfcGluX2JhbmtfZGF0YSBnczEwMV9waW5fZ3NhY29yZVtdID0gewo+ID4g KyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDIsIDB4MCwgImdwczAiLCAweDAwLCAweDAw KSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5URyg4LCAweDIwLCAiZ3BzMSIsIDB4 MDQsIDB4MDQpLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDMsIDB4NDAsICJn cHMyIiwgMHgwOCwgMHgwYyksCj4gPiArfTsKPiA+ICsKPiA+ICsvKiBwaW4gYmFua3Mgb2YgZ3Mx MDEgcGluLWNvbnRyb2xsZXIgKEdTQUNUUkwpICovCj4gPiArc3RhdGljIGNvbnN0IHN0cnVjdCBz YW1zdW5nX3Bpbl9iYW5rX2RhdGEgZ3MxMDFfcGluX2dzYWN0cmxbXSA9IHsKPiA+ICsgICAgICAg RVhZTk9TOV9QSU5fQkFOS19FSU5UVyg2LCAweDAsICJncHMzIiwgMHgwMCwgMHgwMCksCj4gPiAr fTsKPiA+ICsKPiA+ICsvKiBwaW4gYmFua3Mgb2YgZ3MxMDEgcGluLWNvbnRyb2xsZXIgKFBFUklD MCkgKi8KPiA+ICtzdGF0aWMgY29uc3Qgc3RydWN0IHNhbXN1bmdfcGluX2JhbmtfZGF0YSBnczEw MV9waW5fcGVyaWMwW10gPSB7Cj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNSwg MHgwLCAiZ3BwMCIsIDB4MDAsIDB4MDApLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJ TlRHKDQsIDB4MjAsICJncHAxIiwgMHgwNCwgMHgwOCksCj4gPiArICAgICAgIEVYWU5PUzlfUElO X0JBTktfRUlOVEcoNCwgMHg0MCwgImdwcDIiLCAweDA4LCAweDBjKSwKPiA+ICsgICAgICAgRVhZ Tk9TOV9QSU5fQkFOS19FSU5URygyLCAweDYwLCAiZ3BwMyIsIDB4MGMsIDB4MTApLAo+ID4gKyAg ICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDQsIDB4ODAsICJncHA0IiwgMHgxMCwgMHgxNCks Cj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoMiwgMHhhMCwgImdwcDUiLCAweDE0 LCAweDE4KSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5URyg0LCAweGMwLCAiZ3Bw NiIsIDB4MTgsIDB4MWMpLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDIsIDB4 ZTAsICJncHA3IiwgMHgxYywgMHgyMCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlO VEcoNCwgMHgxMDAsICJncHA4IiwgMHgyMCwgMHgyNCksCj4gPiArICAgICAgIEVYWU5PUzlfUElO X0JBTktfRUlOVEcoMiwgMHgxMjAsICJncHA5IiwgMHgyNCwgMHgyOCksCj4gPiArICAgICAgIEVY WU5PUzlfUElOX0JBTktfRUlOVEcoNCwgMHgxNDAsICJncHAxMCIsIDB4MjgsIDB4MmMpLAo+ID4g KyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDIsIDB4MTYwLCAiZ3BwMTEiLCAweDJjLCAw eDMwKSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5URyg0LCAweDE4MCwgImdwcDEy IiwgMHgzMCwgMHgzNCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoMiwgMHgx YTAsICJncHAxMyIsIDB4MzQsIDB4MzgpLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJ TlRHKDQsIDB4MWMwLCAiZ3BwMTQiLCAweDM4LCAweDNjKSwKPiA+ICsgICAgICAgRVhZTk9TOV9Q SU5fQkFOS19FSU5URygyLCAweDFlMCwgImdwcDE1IiwgMHgzYywgMHg0MCksCj4gPiArICAgICAg IEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNCwgMHgyMDAsICJncHAxNiIsIDB4NDAsIDB4NDQpLAo+ ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDIsIDB4MjIwLCAiZ3BwMTciLCAweDQ0 LCAweDQ4KSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5URyg0LCAweDI0MCwgImdw cDE4IiwgMHg0OCwgMHg0YyksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNCwg MHgyNjAsICJncHAxOSIsIDB4NGMsIDB4NTApLAo+ID4gK307Cj4gPiArCj4gPiArLyogcGluIGJh bmtzIG9mIGdzMTAxIHBpbi1jb250cm9sbGVyIChQRVJJQzEpICovCj4gPiArc3RhdGljIGNvbnN0 IHN0cnVjdCBzYW1zdW5nX3Bpbl9iYW5rX2RhdGEgZ3MxMDFfcGluX3BlcmljMVtdID0gewo+ID4g KyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDgsIDB4MCwgImdwcDIwIiwgMHgwMCwgMHgw MCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNCwgMHgyMCwgImdwcDIxIiwg MHgwNCwgMHgwOCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoMiwgMHg0MCwg ImdwcDIyIiwgMHgwOCwgMHgwYyksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEco OCwgMHg2MCwgImdwcDIzIiwgMHgwYywgMHgxMCksCj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JB TktfRUlOVEcoNCwgMHg4MCwgImdwcDI0IiwgMHgxMCwgMHgxOCksCj4gPiArICAgICAgIEVYWU5P UzlfUElOX0JBTktfRUlOVEcoNCwgMHhhMCwgImdwcDI1IiwgMHgxNCwgMHgxYyksCj4gPiArICAg ICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNSwgMHhjMCwgImdwcDI2IiwgMHgxOCwgMHgyMCks Cj4gPiArICAgICAgIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoNCwgMHhlMCwgImdwcDI3IiwgMHgx YywgMHgyOCksCj4gPiArfTsKPiA+ICsKPiA+ICsvKiBwaW4gYmFua3Mgb2YgZ3MxMDEgcGluLWNv bnRyb2xsZXIgKEhTSTEpICovCj4gPiArc3RhdGljIGNvbnN0IHN0cnVjdCBzYW1zdW5nX3Bpbl9i YW5rX2RhdGEgZ3MxMDFfcGluX2hzaTFbXSA9IHsKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFO S19FSU5URyg2LCAweDAsICJncGgwIiwgMHgwMCwgMHgwMCksCj4gPiArICAgICAgIEVYWU5PUzlf UElOX0JBTktfRUlOVEcoNywgMHgyMCwgImdwaDEiLCAweDA0LCAweDA4KSwKPiA+ICt9Owo+ID4g Kwo+ID4gKy8qIHBpbiBiYW5rcyBvZiBnczEwMSBwaW4tY29udHJvbGxlciAoSFNJMikgKi8KPiA+ ICtzdGF0aWMgY29uc3Qgc3RydWN0IHNhbXN1bmdfcGluX2JhbmtfZGF0YSBnczEwMV9waW5faHNp MltdID0gewo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRHKDYsIDB4MCwgImdwaDIi LCAweDAwLCAweDAwKSwKPiA+ICsgICAgICAgRVhZTk9TOV9QSU5fQkFOS19FSU5URygyLCAweDIw LCAiZ3BoMyIsIDB4MDQsIDB4MDgpLAo+ID4gKyAgICAgICBFWFlOT1M5X1BJTl9CQU5LX0VJTlRH KDYsIDB4NDAsICJncGg0IiwgMHgwOCwgMHgwYyksCj4gPiArfTsKPiA+ICsKPiA+ICtzdGF0aWMg Y29uc3Qgc3RydWN0IHNhbXN1bmdfcGluX2N0cmwgZ3MxMDFfcGluX2N0cmxbXSBfX2luaXRjb25z dCA9IHsKPiA+ICsgICAgICAgewo+ID4gKyAgICAgICAgICAgICAgIC8qIHBpbiBiYW5rcyBvZiBn czEwMSBwaW4tY29udHJvbGxlciAoQUxJVkUpICovCj4gPiArICAgICAgICAgICAgICAgLnBpbl9i YW5rcyAgICAgID0gZ3MxMDFfcGluX2FsaXZlLAo+ID4gKyAgICAgICAgICAgICAgIC5ucl9iYW5r cyAgICAgICA9IEFSUkFZX1NJWkUoZ3MxMDFfcGluX2FsaXZlKSwKPiA+ICsgICAgICAgICAgICAg ICAuZWludF93a3VwX2luaXQgPSBleHlub3NfZWludF93a3VwX2luaXQsCj4gPiArICAgICAgICAg ICAgICAgLnN1c3BlbmQgICAgICAgID0gZXh5bm9zX3BpbmN0cmxfc3VzcGVuZCwKPiA+ICsgICAg ICAgICAgICAgICAucmVzdW1lICAgICAgICAgPSBleHlub3NfcGluY3RybF9yZXN1bWUsCj4gPiAr ICAgICAgIH0sIHsKPiA+ICsgICAgICAgICAgICAgICAvKiBwaW4gYmFua3Mgb2YgZ3MxMDEgcGlu LWNvbnRyb2xsZXIgKEZBUl9BTElWRSkgKi8KPiA+ICsgICAgICAgICAgICAgICAucGluX2Jhbmtz ICAgICAgPSBnczEwMV9waW5fZmFyX2FsaXZlLAo+ID4gKyAgICAgICAgICAgICAgIC5ucl9iYW5r cyAgICAgICA9IEFSUkFZX1NJWkUoZ3MxMDFfcGluX2Zhcl9hbGl2ZSksCj4gPiArICAgICAgICAg ICAgICAgLmVpbnRfd2t1cF9pbml0ID0gZXh5bm9zX2VpbnRfd2t1cF9pbml0LAo+ID4gKyAgICAg ICAgICAgICAgIC5zdXNwZW5kICAgICAgICA9IGV4eW5vc19waW5jdHJsX3N1c3BlbmQsCj4gPiAr ICAgICAgICAgICAgICAgLnJlc3VtZSAgICAgICAgID0gZXh5bm9zX3BpbmN0cmxfcmVzdW1lLAo+ ID4gKyAgICAgICB9LCB7Cj4gPiArICAgICAgICAgICAgICAgLyogcGluIGJhbmtzIG9mIGdzMTAx IHBpbi1jb250cm9sbGVyIChHU0FDT1JFKSAqLwo+ID4gKyAgICAgICAgICAgICAgIC5waW5fYmFu a3MgICAgICA9IGdzMTAxX3Bpbl9nc2Fjb3JlLAo+ID4gKyAgICAgICAgICAgICAgIC5ucl9iYW5r cyAgICAgICA9IEFSUkFZX1NJWkUoZ3MxMDFfcGluX2dzYWNvcmUpLAo+ID4gKyAgICAgICB9LCB7 Cj4gPiArICAgICAgICAgICAgICAgLyogcGluIGJhbmtzIG9mIGdzMTAxIHBpbi1jb250cm9sbGVy IChHU0FDVFJMKSAqLwo+ID4gKyAgICAgICAgICAgICAgIC5waW5fYmFua3MgICAgICA9IGdzMTAx X3Bpbl9nc2FjdHJsLAo+ID4gKyAgICAgICAgICAgICAgIC5ucl9iYW5rcyAgICAgICA9IEFSUkFZ X1NJWkUoZ3MxMDFfcGluX2dzYWN0cmwpLAo+ID4gKyAgICAgICB9LCB7Cj4gPiArICAgICAgICAg ICAgICAgLyogcGluIGJhbmtzIG9mIGdzMTAxIHBpbi1jb250cm9sbGVyIChQRVJJQzApICovCj4g PiArICAgICAgICAgICAgICAgLnBpbl9iYW5rcyAgICAgID0gZ3MxMDFfcGluX3BlcmljMCwKPiA+ ICsgICAgICAgICAgICAgICAubnJfYmFua3MgICAgICAgPSBBUlJBWV9TSVpFKGdzMTAxX3Bpbl9w ZXJpYzApLAo+ID4gKyAgICAgICAgICAgICAgIC5laW50X2dwaW9faW5pdCA9IGV4eW5vc19laW50 X2dwaW9faW5pdCwKPiA+ICsgICAgICAgICAgICAgICAuc3VzcGVuZCAgICAgICAgPSBleHlub3Nf cGluY3RybF9zdXNwZW5kLAo+ID4gKyAgICAgICAgICAgICAgIC5yZXN1bWUgICAgICAgICA9IGV4 eW5vc19waW5jdHJsX3Jlc3VtZSwKPiA+ICsgICAgICAgfSwgewo+ID4gKyAgICAgICAgICAgICAg IC8qIHBpbiBiYW5rcyBvZiBnczEwMSBwaW4tY29udHJvbGxlciAoUEVSSUMxKSAqLwo+ID4gKyAg ICAgICAgICAgICAgIC5waW5fYmFua3MgICAgICA9IGdzMTAxX3Bpbl9wZXJpYzEsCj4gPiArICAg ICAgICAgICAgICAgLm5yX2JhbmtzICAgICAgID0gQVJSQVlfU0laRShnczEwMV9waW5fcGVyaWMx KSwKPiA+ICsgICAgICAgICAgICAgICAuZWludF9ncGlvX2luaXQgPSBleHlub3NfZWludF9ncGlv X2luaXQsCj4gPiArICAgICAgICAgICAgICAgLnN1c3BlbmQgICAgICAgID0gZXh5bm9zX3BpbmN0 cmxfc3VzcGVuZCwKPiA+ICsgICAgICAgICAgICAgICAucmVzdW1lID0gZXh5bm9zX3BpbmN0cmxf cmVzdW1lLAo+ID4gKyAgICAgICB9LCB7Cj4gPiArICAgICAgICAgICAgICAgLyogcGluIGJhbmtz IG9mIGdzMTAxIHBpbi1jb250cm9sbGVyIChIU0kxKSAqLwo+ID4gKyAgICAgICAgICAgICAgIC5w aW5fYmFua3MgICAgICA9IGdzMTAxX3Bpbl9oc2kxLAo+ID4gKyAgICAgICAgICAgICAgIC5ucl9i YW5rcyAgICAgICA9IEFSUkFZX1NJWkUoZ3MxMDFfcGluX2hzaTEpLAo+ID4gKyAgICAgICAgICAg ICAgIC5laW50X2dwaW9faW5pdCA9IGV4eW5vc19laW50X2dwaW9faW5pdCwKPiA+ICsgICAgICAg ICAgICAgICAuc3VzcGVuZCAgICAgICAgPSBleHlub3NfcGluY3RybF9zdXNwZW5kLAo+ID4gKyAg ICAgICAgICAgICAgIC5yZXN1bWUgICAgICAgICA9IGV4eW5vc19waW5jdHJsX3Jlc3VtZSwKPiA+ ICsgICAgICAgfSwgewo+ID4gKyAgICAgICAgICAgICAgIC8qIHBpbiBiYW5rcyBvZiBnczEwMSBw aW4tY29udHJvbGxlciAoSFNJMikgKi8KPiA+ICsgICAgICAgICAgICAgICAucGluX2JhbmtzICAg ICAgPSBnczEwMV9waW5faHNpMiwKPiA+ICsgICAgICAgICAgICAgICAubnJfYmFua3MgICAgICAg PSBBUlJBWV9TSVpFKGdzMTAxX3Bpbl9oc2kyKSwKPiA+ICsgICAgICAgICAgICAgICAuZWludF9n cGlvX2luaXQgPSBleHlub3NfZWludF9ncGlvX2luaXQsCj4gPiArICAgICAgICAgICAgICAgLnN1 c3BlbmQgICAgICAgID0gZXh5bm9zX3BpbmN0cmxfc3VzcGVuZCwKPiA+ICsgICAgICAgICAgICAg ICAucmVzdW1lICAgICAgICAgPSBleHlub3NfcGluY3RybF9yZXN1bWUsCj4gPiArICAgICAgIH0s Cj4gPiArfTsKPiA+ICsKPiA+ICtjb25zdCBzdHJ1Y3Qgc2Ftc3VuZ19waW5jdHJsX29mX21hdGNo X2RhdGEgZ3MxMDFfb2ZfZGF0YSBfX2luaXRjb25zdCA9IHsKPiA+ICsgICAgICAgLmN0cmwgICAg ICAgICAgID0gZ3MxMDFfcGluX2N0cmwsCj4gPiArICAgICAgIC5udW1fY3RybCAgICAgICA9IEFS UkFZX1NJWkUoZ3MxMDFfcGluX2N0cmwpLAo+ID4gK307Cj4gPiBkaWZmIC0tZ2l0IGEvZHJpdmVy cy9waW5jdHJsL3NhbXN1bmcvcGluY3RybC1leHlub3MuYyBiL2RyaXZlcnMvcGluY3RybC9zYW1z dW5nL3BpbmN0cmwtZXh5bm9zLmMKPiA+IGluZGV4IDU2ZmMxMWExZmUyZi4uNzViOWNmNzJjZTcz IDEwMDY0NAo+ID4gLS0tIGEvZHJpdmVycy9waW5jdHJsL3NhbXN1bmcvcGluY3RybC1leHlub3Mu Ywo+ID4gKysrIGIvZHJpdmVycy9waW5jdHJsL3NhbXN1bmcvcGluY3RybC1leHlub3MuYwo+ID4g QEAgLTUzNyw2ICs1MzcsOCBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IG9mX2RldmljZV9pZCBleHlu b3Nfd2t1cF9pcnFfaWRzW10gPSB7Cj4gPiAgICAgICAgICAgICAgICAgICAgICAgICAuZGF0YSA9 ICZleHlub3M3X3drdXBfaXJxX2NoaXAgfSwKPiA+ICAgICAgICAgeyAuY29tcGF0aWJsZSA9ICJz YW1zdW5nLGV4eW5vc2F1dG92OS13YWtldXAtZWludCIsCj4gPiAgICAgICAgICAgICAgICAgICAg ICAgICAuZGF0YSA9ICZleHlub3M3X3drdXBfaXJxX2NoaXAgfSwKPiA+ICsgICAgICAgeyAuY29t cGF0aWJsZSA9ICJnb29nbGUsZ3MxMDEtd2FrZXVwLWVpbnQiLAo+ID4gKyAgICAgICAgICAgICAg ICAgICAgICAgLmRhdGEgPSAmZXh5bm9zN193a3VwX2lycV9jaGlwIH0sCj4gPiAgICAgICAgIHsg fQo+ID4gIH07Cj4gPgo+ID4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvcGluY3RybC9zYW1zdW5nL3Bp bmN0cmwtZXh5bm9zLmggYi9kcml2ZXJzL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLWV4eW5vcy5o Cj4gPiBpbmRleCBlMjc5OWZmMWI1ZTkuLjFmZmM5MGRiMDc5ZCAxMDA2NDQKPiA+IC0tLSBhL2Ry aXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwtZXh5bm9zLmgKPiA+ICsrKyBiL2RyaXZlcnMv cGluY3RybC9zYW1zdW5nL3BpbmN0cmwtZXh5bm9zLmgKPiA+IEBAIC0xNDcsNiArMTQ3LDQwIEBA Cj4gPiAgICAgICAgICAgICAgICAgLm5hbWUgICAgICAgICAgID0gaWQgICAgICAgICAgICAgICAg ICAgICAgICAgICAgXAo+ID4gICAgICAgICB9Cj4gPgo+ID4gKyNkZWZpbmUgRVhZTk9TOV9QSU5f QkFOS19FSU5UTih0eXBlcywgcGlucywgcmVnLCBpZCkgICBcCj4gPiArICAgICAgIHsgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwKPiA+ICsgICAgICAgICAg ICAgICAudHlwZSAgICAgICAgICAgPSAmdHlwZXMsICAgICAgICAgICAgICAgXAo+ID4gKyAgICAg ICAgICAgICAgIC5wY3RsX29mZnNldCAgICA9IHJlZywgICAgICAgICAgICAgICAgICBcCj4gPiAr ICAgICAgICAgICAgICAgLm5yX3BpbnMgICAgICAgID0gcGlucywgICAgICAgICAgICAgICAgIFwK PiA+ICsgICAgICAgICAgICAgICAuZWludF90eXBlICAgICAgPSBFSU5UX1RZUEVfTk9ORSwgICAg ICAgXAo+ID4gKyAgICAgICAgICAgICAgIC5mbHRjb25fdHlwZSAgICA9IEZMVF9ERUZBVUxUICAg ICAgICAgICBcCj4gPiArICAgICAgICAgICAgICAgLm5hbWUgICAgICAgICAgID0gaWQgICAgICAg ICAgICAgICAgICAgIFwKPiA+ICsgICAgICAgfQo+Cj4gV2hlcmUgZXhhY3RseSBpdCBpcyB1c2Vk PyBXaGF0IGlzICd0eXBlcyc/CgpFWFlOT1M5X1BJTl9CQU5LX0VJTlROIG1hY3JvIGNhbiBiZSBk cm9wcGVkIGNvbXBsZXRlbHkgZm9yIGdzMTAxIGFzIGl0Cmlzbid0IHVzZWQgYW55d2hlcmUuIEkg Y2hlY2tlZCBkb3duc3RyZWFtIGNvZGUgYW5kIGl0IGlzIGRlY2xhcmVkIGFuZApub3QgdXNlZCB0 aGVyZSBhcyB3ZWxsLgoKPk1vcmVvdmVyLCBpdCBkb2Vzbid0IGxvb2sKPiB2ZXJ5IGRpZmZlcmVu dCBmcm9tIEVYWU5PUzg1MF9QSU5fQkFOS19FSU5UTigpIC0tIGp1c3QgYmVjYXVzZSBJCj4gY3Jl YXRlZCBFWFlOT1M4NTBfUElOX0JBTktfRUlOVE4oKSBleGFjdGx5IGZyb20gdGhpcyBkb3duc3Ry ZWFtIG1hY3JvLgo+IEkgd2FzIHN0cmljdGx5IHByb2hpYml0ZWQgYWRkaW5nIEVYWU5PUzlfKiBz dHVmZiBiYWNrIGF0IHRoZSB0aW1lLiBCdXQKPiBub3cgSSBndWVzcyBpdCBzaG91bGQgYmUgYXBw YXJlbnQgd2UgYXJlIGFjdHVhbGx5IGRlYWxpbmcgd2l0aCBFeHlub3M5Cj4gY29tbW9uIHBsYXRm b3JtLiBTbyBJIHN1Z2dlc3QgcmVuYW1pbmcgRVhZTk9TODUwX1BJTl9CQU5LX0VJTlROKCkgdG8K PiBFWFlOT1M5X1BJTl9CQU5LX0VJTlROKCkuCj4KPiA+ICsKPiA+ICsjZGVmaW5lIEVYWU5PUzlf UElOX0JBTktfRUlOVEcocGlucywgcmVnLCBpZCwgb2ZmcywgZmx0Y29uX29mZnMpIFwKPiA+ICsg ICAgICAgeyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXAo+ ID4gKyAgICAgICAgICAgICAgIC50eXBlICAgICAgICAgICA9ICZnczEwMV9iYW5rX3R5cGVfb2Zm LCBcCj4gPiArICAgICAgICAgICAgICAgLnBjdGxfb2Zmc2V0ICAgID0gcmVnLCAgICAgICAgICAg ICAgICAgIFwKPiA+ICsgICAgICAgICAgICAgICAubnJfcGlucyAgICAgICAgPSBwaW5zLCAgICAg ICAgICAgICAgICAgXAo+ID4gKyAgICAgICAgICAgICAgIC5laW50X3R5cGUgICAgICA9IEVJTlRf VFlQRV9HUElPLCAgICAgICBcCj4gPiArICAgICAgICAgICAgICAgLmVpbnRfb2Zmc2V0ICAgID0g b2ZmcywgICAgICAgICAgICAgICAgIFwKPiA+ICsgICAgICAgICAgICAgICAuZmx0Y29uX3R5cGUg ICAgPSBGTFRfREVGQVVMVCwgICAgICAgICAgXAo+ID4gKyAgICAgICAgICAgICAgIC5mbHRjb25f b2Zmc2V0ICA9IGZsdGNvbl9vZmZzLCAgICAgICAgICBcCj4gPiArICAgICAgICAgICAgICAgLm5h bWUgICAgICAgICAgID0gaWQgICAgICAgICAgICAgICAgICAgIFwKPiA+ICsgICAgICAgfQo+Cj4g RGl0dG8uIFBsZWFzZSBhZGQgZmlsdGVyIGZpZWxkcyB0byBFWFlOT1M4NTBfUElOX0JBTktfRUlO VEcoKSBpbnN0ZWFkCj4gb2YgYWRkaW5nIHByZXR0eSBtdWNoIHRoZSBzYW1lIG1hY3JvIChpdCBp cyB0aGUgc2FtZSwgSSBjcmVhdGVkCj4gRVhZTk9TODUwX1BJTl9CQU5LX0VJTlRHKCkgZnJvbSBl eGFjdGx5IHRoaXMgbWFjcm8pLiBBbHNvIEkgc3VnZ2VzdAo+IHJlbmFtaW5nIEVYWU5PUzg1MF9Q SU5fQkFOS19FSU5URygpIHRvIEVYWU5PUzlfUElOX0JBTktfRUlOVEcoKSwgdG8KPiBhdm9pZCBj b25mdXNpb24uIElmIHlvdSBuZWVkIGFueSBoZWxwIHdpdGggcmV3b3JraW5nIEV4eW5vczg1MCBw aW5jdHJsCj4gY29ycmVzcG9uZGluZ2x5LCBwbGVhc2UgbGV0IG1lIGtub3cuCgpUaGUgb25seSBp c3N1ZSBmb3IgbWUgbWlncmF0aW5nIEV4eW5vczg1MCB0byBFWFlOT1M5X1BJTl9CQU5LX0VJTlRH IGlzCmtub3dpbmcgd2hhdCB0aGUgZmx0Y29uX29mZnNldCBpcy4gQ2FuIHlvdSBwcm92aWRlIHRo ZSBmbHRjb25fb2Zmc2V0Cm9mZnNldHMgZm9yIHRoZSByZWxldmFudCBFeHlub3M4NTAgYmFua3Mg YW5kIGhlbHAgdGVzdD8KClRoYW5rcywKClBldGVyLgoKPgo+ID4gKwo+ID4gKyNkZWZpbmUgRVhZ Tk9TOV9QSU5fQkFOS19FSU5UVyhwaW5zLCByZWcsIGlkLCBvZmZzLCBmbHRjb25fb2ZmcykgXAo+ ID4gKyAgICAgICB7ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgIFwKPiA+ICsgICAgICAgICAgICAgICAudHlwZSAgICAgICAgICAgPSAmZ3MxMDFf YmFua190eXBlX2FsaXZlLCAgICAgICBcCj4gPiArICAgICAgICAgICAgICAgLnBjdGxfb2Zmc2V0 ICAgID0gcmVnLCAgICAgICAgICAgICAgICAgICAgICAgICAgXAo+ID4gKyAgICAgICAgICAgICAg IC5ucl9waW5zICAgICAgICA9IHBpbnMsICAgICAgICAgICAgICAgICAgICAgICAgIFwKPiA+ICsg ICAgICAgICAgICAgICAuZWludF90eXBlICAgICAgPSBFSU5UX1RZUEVfV0tVUCwgICAgICAgICAg ICAgICBcCj4gPiArICAgICAgICAgICAgICAgLmVpbnRfb2Zmc2V0ICAgID0gb2ZmcywgICAgICAg ICAgICAgICAgICAgICAgICAgXAo+ID4gKyAgICAgICAgICAgICAgIC5mbHRjb25fdHlwZSAgICA9 IEZMVF9TRUxFQ1RBQkxFLCAgICAgICAgICAgICAgIFwKPiA+ICsgICAgICAgICAgICAgICAuZmx0 Y29uX29mZnNldCAgPSBmbHRjb25fb2ZmcywgICAgICAgICAgICAgICAgICBcCj4gPiArICAgICAg ICAgICAgICAgLm5hbWUgICAgICAgICAgID0gaWQgICAgICAgICAgICAgICAgICAgICAgICAgICAg XAo+ID4gKyAgICAgICB9Cj4KPiBEaXR0by4KPgo+ID4gKwo+ID4gIC8qKgo+ID4gICAqIHN0cnVj dCBleHlub3Nfd2VpbnRfZGF0YTogaXJxIHNwZWNpZmljIGRhdGEgZm9yIGFsbCB0aGUgd2FrZXVw IGludGVycnVwdHMKPiA+ICAgKiBnZW5lcmF0ZWQgYnkgdGhlIGV4dGVybmFsIHdha2V1cCBpbnRl cnJ1cHQgY29udHJvbGxlci4KPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL3BpbmN0cmwvc2Ftc3Vu Zy9waW5jdHJsLXNhbXN1bmcuYyBiL2RyaXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwtc2Ft c3VuZy5jCj4gPiBpbmRleCA1MGMzNjBiNDc1M2EuLjk4MmE1NzAyNzE0YyAxMDA2NDQKPiA+IC0t LSBhL2RyaXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwtc2Ftc3VuZy5jCj4gPiArKysgYi9k cml2ZXJzL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLXNhbXN1bmcuYwo+ID4gQEAgLTEzMjMsNiAr MTMyMyw4IEBAIHN0YXRpYyBjb25zdCBzdHJ1Y3Qgb2ZfZGV2aWNlX2lkIHNhbXN1bmdfcGluY3Ry bF9kdF9tYXRjaFtdID0gewo+ID4gICAgICAgICAgICAgICAgIC5kYXRhID0gJmV4eW5vc2F1dG92 OV9vZl9kYXRhIH0sCj4gPiAgICAgICAgIHsgLmNvbXBhdGlibGUgPSAidGVzbGEsZnNkLXBpbmN0 cmwiLAo+ID4gICAgICAgICAgICAgICAgIC5kYXRhID0gJmZzZF9vZl9kYXRhIH0sCj4gPiArICAg ICAgIHsgLmNvbXBhdGlibGUgPSAiZ29vZ2xlLGdzMTAxLXBpbmN0cmwiLAo+ID4gKyAgICAgICAg ICAgICAgIC5kYXRhID0gJmdzMTAxX29mX2RhdGEgfSwKPiA+ICAjZW5kaWYKPiA+ICAjaWZkZWYg Q09ORklHX1BJTkNUUkxfUzNDNjRYWAo+ID4gICAgICAgICB7IC5jb21wYXRpYmxlID0gInNhbXN1 bmcsczNjNjR4eC1waW5jdHJsIiwKPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL3BpbmN0cmwvc2Ft c3VuZy9waW5jdHJsLXNhbXN1bmcuaCBiL2RyaXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwt c2Ftc3VuZy5oCj4gPiBpbmRleCA1ZmFiMzg4NWE3ZDcuLmY2ODU2MjkwNjA4YyAxMDA2NDQKPiA+ IC0tLSBhL2RyaXZlcnMvcGluY3RybC9zYW1zdW5nL3BpbmN0cmwtc2Ftc3VuZy5oCj4gPiArKysg Yi9kcml2ZXJzL3BpbmN0cmwvc2Ftc3VuZy9waW5jdHJsLXNhbXN1bmcuaAo+ID4gQEAgLTM3Myw2 ICszNzMsNyBAQCBleHRlcm4gY29uc3Qgc3RydWN0IHNhbXN1bmdfcGluY3RybF9vZl9tYXRjaF9k YXRhIGV4eW5vczc4ODVfb2ZfZGF0YTsKPiA+ICBleHRlcm4gY29uc3Qgc3RydWN0IHNhbXN1bmdf cGluY3RybF9vZl9tYXRjaF9kYXRhIGV4eW5vczg1MF9vZl9kYXRhOwo+ID4gIGV4dGVybiBjb25z dCBzdHJ1Y3Qgc2Ftc3VuZ19waW5jdHJsX29mX21hdGNoX2RhdGEgZXh5bm9zYXV0b3Y5X29mX2Rh dGE7Cj4gPiAgZXh0ZXJuIGNvbnN0IHN0cnVjdCBzYW1zdW5nX3BpbmN0cmxfb2ZfbWF0Y2hfZGF0 YSBmc2Rfb2ZfZGF0YTsKPiA+ICtleHRlcm4gY29uc3Qgc3RydWN0IHNhbXN1bmdfcGluY3RybF9v Zl9tYXRjaF9kYXRhIGdzMTAxX29mX2RhdGE7Cj4gPiAgZXh0ZXJuIGNvbnN0IHN0cnVjdCBzYW1z dW5nX3BpbmN0cmxfb2ZfbWF0Y2hfZGF0YSBzM2M2NHh4X29mX2RhdGE7Cj4gPiAgZXh0ZXJuIGNv bnN0IHN0cnVjdCBzYW1zdW5nX3BpbmN0cmxfb2ZfbWF0Y2hfZGF0YSBzM2MyNDEyX29mX2RhdGE7 Cj4gPiAgZXh0ZXJuIGNvbnN0IHN0cnVjdCBzYW1zdW5nX3BpbmN0cmxfb2ZfbWF0Y2hfZGF0YSBz M2MyNDE2X29mX2RhdGE7Cj4gPiAtLQo+ID4gMi40My4wLnJjMi40NTEuZzg2MzFiYzc0NzItZ29v Zwo+ID4KCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxp bnV4LWFybS1rZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFk ZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4 LWFybS1rZXJuZWwK