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 X-Spam-Level: X-Spam-Status: No, score=-0.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 456D4C433F5 for ; Sat, 8 Sep 2018 05:45:56 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id DC22B20844 for ; Sat, 8 Sep 2018 05:45:55 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org DC22B20844 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=suse.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726431AbeIHKaW (ORCPT ); Sat, 8 Sep 2018 06:30:22 -0400 Received: from mx2.suse.de ([195.135.220.15]:47874 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726248AbeIHKaW (ORCPT ); Sat, 8 Sep 2018 06:30:22 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id C8659ADEF; Sat, 8 Sep 2018 05:45:50 +0000 (UTC) Subject: Re: [PATCH v2] x86/paravirt: Get rid of patch_site and patch_default labels To: Borislav Petkov , LKML Cc: x86@kernel.org, virtualization@lists.linux-foundation.org References: <20180907104917.12502-1-bp@alien8.de> <20180907105112.GD12849@zn.tnic> <20180907201050.GF12849@zn.tnic> From: Juergen Gross Openpgp: preference=signencrypt Autocrypt: addr=jgross@suse.com; prefer-encrypt=mutual; keydata= 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 Message-ID: <65bb69fa-855f-9efc-19ba-c0fab69f468c@suse.com> Date: Sat, 8 Sep 2018 07:45:49 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180907201050.GF12849@zn.tnic> Content-Type: text/plain; charset=utf-8 Content-Language: de-DE Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 07/09/18 22:10, Borislav Petkov wrote: > On Fri, Sep 07, 2018 at 12:51:12PM +0200, Borislav Petkov wrote: >> Whoops, no, it is still being used. Lemme see if I can remove all the >> labels in that function. > > Ok, I think I've gotten rid of them all, in both 32- and 64-bit > versions. It boots here and a bunch of all*config builds pass. > > --- > From: Borislav Petkov > Date: Fri, 7 Sep 2018 12:47:10 +0200 > MIME-Version: 1.0 > Content-Type: text/plain; charset=UTF-8 > Content-Transfer-Encoding: 8bit > > When CONFIG_PARAVIRT_SPINLOCKS=n, it fires > > arch/x86/kernel/paravirt_patch_64.c: In function ‘native_patch’: > arch/x86/kernel/paravirt_patch_64.c:89:1: warning: label ‘patch_site’ defined but not used [-Wunused-label] > patch_site: > > but those labels can simply be removed by directly calling the > respective functions there. > > Signed-off-by: Borislav Petkov > Cc: Juergen Gross > Cc: x86@kernel.org > Cc: virtualization@lists.linux-foundation.org > --- > arch/x86/kernel/paravirt_patch_32.c | 21 ++++++++++----------- > arch/x86/kernel/paravirt_patch_64.c | 20 +++++++++----------- > 2 files changed, 19 insertions(+), 22 deletions(-) > > diff --git a/arch/x86/kernel/paravirt_patch_32.c b/arch/x86/kernel/paravirt_patch_32.c > index d460cbcabcfe..af57f0d0789f 100644 > --- a/arch/x86/kernel/paravirt_patch_32.c > +++ b/arch/x86/kernel/paravirt_patch_32.c > @@ -34,14 +34,16 @@ extern bool pv_is_native_vcpu_is_preempted(void); > > unsigned native_patch(u8 type, void *ibuf, unsigned long addr, unsigned len) > { > - const unsigned char *start, *end; > + const unsigned char *start __maybe_unused, *end __maybe_unused; > unsigned ret; > > #define PATCH_SITE(ops, x) \ > case PARAVIRT_PATCH(ops.x): \ > start = start_##ops##_##x; \ > end = end_##ops##_##x; \ > - goto patch_site > + \ > + return paravirt_patch_insns(ibuf, len, start, end); > + > switch (type) { > #ifdef CONFIG_PARAVIRT_XXL > PATCH_SITE(irq, irq_disable); > @@ -58,27 +60,24 @@ unsigned native_patch(u8 type, void *ibuf, unsigned long addr, unsigned len) > if (pv_is_native_spin_unlock()) { > start = start_lock_queued_spin_unlock; > end = end_lock_queued_spin_unlock; > - goto patch_site; > + > + return paravirt_patch_insns(ibuf, len, start, end); > } > - goto patch_default; > + return paravirt_patch_default(type, ibuf, addr, len); > > case PARAVIRT_PATCH(lock.vcpu_is_preempted): > if (pv_is_native_vcpu_is_preempted()) { > start = start_lock_vcpu_is_preempted; > end = end_lock_vcpu_is_preempted; > - goto patch_site; > + > + return paravirt_patch_insns(ibuf, len, start, end); > } > - goto patch_default; > + return paravirt_patch_default(type, ibuf, addr, len); > #endif > > default: > -patch_default: __maybe_unused > ret = paravirt_patch_default(type, ibuf, addr, len); > break; > - > -patch_site: > - ret = paravirt_patch_insns(ibuf, len, start, end); > - break; > } > #undef PATCH_SITE > return ret; > diff --git a/arch/x86/kernel/paravirt_patch_64.c b/arch/x86/kernel/paravirt_patch_64.c > index 5ad5bcda9dc6..2db6c615932f 100644 > --- a/arch/x86/kernel/paravirt_patch_64.c > +++ b/arch/x86/kernel/paravirt_patch_64.c > @@ -42,14 +42,15 @@ extern bool pv_is_native_vcpu_is_preempted(void); > > unsigned native_patch(u8 type, void *ibuf, unsigned long addr, unsigned len) > { > - const unsigned char *start, *end; > + const unsigned char *start __maybe_unused, *end __maybe_unused; Drop start and end and ... > unsigned ret; > > #define PATCH_SITE(ops, x) \ > case PARAVIRT_PATCH(ops.x): \ > start = start_##ops##_##x; \ > end = end_##ops##_##x; \ > - goto patch_site > + \ > + return paravirt_patch_insns(ibuf, len, start, end); ... do: return paravirt_patch_insns(ibuf, len, start_##ops##_##x, end_##ops##_##x) and please omit the semicolon after the last instruction in the macro. (below the same) > switch(type) { > #ifdef CONFIG_PARAVIRT_XXL > PATCH_SITE(irq, restore_fl); > @@ -68,27 +69,24 @@ unsigned native_patch(u8 type, void *ibuf, unsigned long addr, unsigned len) > if (pv_is_native_spin_unlock()) { > start = start_lock_queued_spin_unlock; > end = end_lock_queued_spin_unlock; > - goto patch_site; > + > + return paravirt_patch_insns(ibuf, len, start, end); > } > - goto patch_default; > + return paravirt_patch_default(type, ibuf, addr, len); > > case PARAVIRT_PATCH(lock.vcpu_is_preempted): > if (pv_is_native_vcpu_is_preempted()) { > start = start_lock_vcpu_is_preempted; > end = end_lock_vcpu_is_preempted; > - goto patch_site; > + > + return paravirt_patch_insns(ibuf, len, start, end); > } > - goto patch_default; > + return paravirt_patch_default(type, ibuf, addr, len); > #endif > > default: > -patch_default: __maybe_unused > ret = paravirt_patch_default(type, ibuf, addr, len); > break; > - > -patch_site: > - ret = paravirt_patch_insns(ibuf, len, start, end); > - break; > } > #undef PATCH_SITE > return ret; > Juergen From mboxrd@z Thu Jan 1 00:00:00 1970 From: Juergen Gross Subject: Re: [PATCH v2] x86/paravirt: Get rid of patch_site and patch_default labels Date: Sat, 8 Sep 2018 07:45:49 +0200 Message-ID: <65bb69fa-855f-9efc-19ba-c0fab69f468c@suse.com> References: <20180907104917.12502-1-bp@alien8.de> <20180907105112.GD12849@zn.tnic> <20180907201050.GF12849@zn.tnic> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <20180907201050.GF12849@zn.tnic> Content-Language: de-DE List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: virtualization-bounces@lists.linux-foundation.org Errors-To: virtualization-bounces@lists.linux-foundation.org To: Borislav Petkov , LKML Cc: x86@kernel.org, virtualization@lists.linux-foundation.org List-Id: virtualization@lists.linuxfoundation.org T24gMDcvMDkvMTggMjI6MTAsIEJvcmlzbGF2IFBldGtvdiB3cm90ZToKPiBPbiBGcmksIFNlcCAw NywgMjAxOCBhdCAxMjo1MToxMlBNICswMjAwLCBCb3Jpc2xhdiBQZXRrb3Ygd3JvdGU6Cj4+IFdo b29wcywgbm8sIGl0IGlzIHN0aWxsIGJlaW5nIHVzZWQuIExlbW1lIHNlZSBpZiBJIGNhbiByZW1v dmUgYWxsIHRoZQo+PiBsYWJlbHMgaW4gdGhhdCBmdW5jdGlvbi4KPiAKPiBPaywgSSB0aGluayBJ J3ZlIGdvdHRlbiByaWQgb2YgdGhlbSBhbGwsIGluIGJvdGggMzItIGFuZCA2NC1iaXQKPiB2ZXJz aW9ucy4gSXQgYm9vdHMgaGVyZSBhbmQgYSBidW5jaCBvZiBhbGwqY29uZmlnIGJ1aWxkcyBwYXNz Lgo+IAo+IC0tLQo+IEZyb206IEJvcmlzbGF2IFBldGtvdiA8YnBAc3VzZS5kZT4KPiBEYXRlOiBG cmksIDcgU2VwIDIwMTggMTI6NDc6MTAgKzAyMDAKPiBNSU1FLVZlcnNpb246IDEuMAo+IENvbnRl bnQtVHlwZTogdGV4dC9wbGFpbjsgY2hhcnNldD1VVEYtOAo+IENvbnRlbnQtVHJhbnNmZXItRW5j b2Rpbmc6IDhiaXQKPiAKPiBXaGVuIENPTkZJR19QQVJBVklSVF9TUElOTE9DS1M9biwgaXQgZmly ZXMKPiAKPiAgIGFyY2gveDg2L2tlcm5lbC9wYXJhdmlydF9wYXRjaF82NC5jOiBJbiBmdW5jdGlv biDigJhuYXRpdmVfcGF0Y2jigJk6Cj4gICBhcmNoL3g4Ni9rZXJuZWwvcGFyYXZpcnRfcGF0Y2hf NjQuYzo4OToxOiB3YXJuaW5nOiBsYWJlbCDigJhwYXRjaF9zaXRl4oCZIGRlZmluZWQgYnV0IG5v dCB1c2VkIFstV3VudXNlZC1sYWJlbF0KPiAgICBwYXRjaF9zaXRlOgo+IAo+IGJ1dCB0aG9zZSBs YWJlbHMgY2FuIHNpbXBseSBiZSByZW1vdmVkIGJ5IGRpcmVjdGx5IGNhbGxpbmcgdGhlCj4gcmVz cGVjdGl2ZSBmdW5jdGlvbnMgdGhlcmUuCj4gCj4gU2lnbmVkLW9mZi1ieTogQm9yaXNsYXYgUGV0 a292IDxicEBzdXNlLmRlPgo+IENjOiBKdWVyZ2VuIEdyb3NzIDxqZ3Jvc3NAc3VzZS5jb20+Cj4g Q2M6IHg4NkBrZXJuZWwub3JnCj4gQ2M6IHZpcnR1YWxpemF0aW9uQGxpc3RzLmxpbnV4LWZvdW5k YXRpb24ub3JnCj4gLS0tCj4gIGFyY2gveDg2L2tlcm5lbC9wYXJhdmlydF9wYXRjaF8zMi5jIHwg MjEgKysrKysrKysrKy0tLS0tLS0tLS0tCj4gIGFyY2gveDg2L2tlcm5lbC9wYXJhdmlydF9wYXRj aF82NC5jIHwgMjAgKysrKysrKysrLS0tLS0tLS0tLS0KPiAgMiBmaWxlcyBjaGFuZ2VkLCAxOSBp bnNlcnRpb25zKCspLCAyMiBkZWxldGlvbnMoLSkKPiAKPiBkaWZmIC0tZ2l0IGEvYXJjaC94ODYv a2VybmVsL3BhcmF2aXJ0X3BhdGNoXzMyLmMgYi9hcmNoL3g4Ni9rZXJuZWwvcGFyYXZpcnRfcGF0 Y2hfMzIuYwo+IGluZGV4IGQ0NjBjYmNhYmNmZS4uYWY1N2YwZDA3ODlmIDEwMDY0NAo+IC0tLSBh L2FyY2gveDg2L2tlcm5lbC9wYXJhdmlydF9wYXRjaF8zMi5jCj4gKysrIGIvYXJjaC94ODYva2Vy bmVsL3BhcmF2aXJ0X3BhdGNoXzMyLmMKPiBAQCAtMzQsMTQgKzM0LDE2IEBAIGV4dGVybiBib29s IHB2X2lzX25hdGl2ZV92Y3B1X2lzX3ByZWVtcHRlZCh2b2lkKTsKPiAgCj4gIHVuc2lnbmVkIG5h dGl2ZV9wYXRjaCh1OCB0eXBlLCB2b2lkICppYnVmLCB1bnNpZ25lZCBsb25nIGFkZHIsIHVuc2ln bmVkIGxlbikKPiAgewo+IC0JY29uc3QgdW5zaWduZWQgY2hhciAqc3RhcnQsICplbmQ7Cj4gKwlj b25zdCB1bnNpZ25lZCBjaGFyICpzdGFydCBfX21heWJlX3VudXNlZCwgKmVuZCBfX21heWJlX3Vu dXNlZDsKPiAgCXVuc2lnbmVkIHJldDsKPiAgCj4gICNkZWZpbmUgUEFUQ0hfU0lURShvcHMsIHgp CQkJCQlcCj4gIAkJY2FzZSBQQVJBVklSVF9QQVRDSChvcHMueCk6CQkJXAo+ICAJCQlzdGFydCA9 IHN0YXJ0XyMjb3BzIyNfIyN4OwkJXAo+ICAJCQllbmQgPSBlbmRfIyNvcHMjI18jI3g7CQkJXAo+ IC0JCQlnb3RvIHBhdGNoX3NpdGUKPiArCQkJCQkJCQlcCj4gKwkJCXJldHVybiBwYXJhdmlydF9w YXRjaF9pbnNucyhpYnVmLCBsZW4sIHN0YXJ0LCBlbmQpOwo+ICsKPiAgCXN3aXRjaCAodHlwZSkg ewo+ICAjaWZkZWYgQ09ORklHX1BBUkFWSVJUX1hYTAo+ICAJCVBBVENIX1NJVEUoaXJxLCBpcnFf ZGlzYWJsZSk7Cj4gQEAgLTU4LDI3ICs2MCwyNCBAQCB1bnNpZ25lZCBuYXRpdmVfcGF0Y2godTgg dHlwZSwgdm9pZCAqaWJ1ZiwgdW5zaWduZWQgbG9uZyBhZGRyLCB1bnNpZ25lZCBsZW4pCj4gIAkJ CWlmIChwdl9pc19uYXRpdmVfc3Bpbl91bmxvY2soKSkgewo+ICAJCQkJc3RhcnQgPSBzdGFydF9s b2NrX3F1ZXVlZF9zcGluX3VubG9jazsKPiAgCQkJCWVuZCAgID0gZW5kX2xvY2tfcXVldWVkX3Nw aW5fdW5sb2NrOwo+IC0JCQkJZ290byBwYXRjaF9zaXRlOwo+ICsKPiArCQkJCXJldHVybiBwYXJh dmlydF9wYXRjaF9pbnNucyhpYnVmLCBsZW4sIHN0YXJ0LCBlbmQpOwo+ICAJCQl9Cj4gLQkJCWdv dG8gcGF0Y2hfZGVmYXVsdDsKPiArCQkJcmV0dXJuIHBhcmF2aXJ0X3BhdGNoX2RlZmF1bHQodHlw ZSwgaWJ1ZiwgYWRkciwgbGVuKTsKPiAgCj4gIAkJY2FzZSBQQVJBVklSVF9QQVRDSChsb2NrLnZj cHVfaXNfcHJlZW1wdGVkKToKPiAgCQkJaWYgKHB2X2lzX25hdGl2ZV92Y3B1X2lzX3ByZWVtcHRl ZCgpKSB7Cj4gIAkJCQlzdGFydCA9IHN0YXJ0X2xvY2tfdmNwdV9pc19wcmVlbXB0ZWQ7Cj4gIAkJ CQllbmQgICA9IGVuZF9sb2NrX3ZjcHVfaXNfcHJlZW1wdGVkOwo+IC0JCQkJZ290byBwYXRjaF9z aXRlOwo+ICsKPiArCQkJCXJldHVybiBwYXJhdmlydF9wYXRjaF9pbnNucyhpYnVmLCBsZW4sIHN0 YXJ0LCBlbmQpOwo+ICAJCQl9Cj4gLQkJCWdvdG8gcGF0Y2hfZGVmYXVsdDsKPiArCQkJcmV0dXJu IHBhcmF2aXJ0X3BhdGNoX2RlZmF1bHQodHlwZSwgaWJ1ZiwgYWRkciwgbGVuKTsKPiAgI2VuZGlm Cj4gIAo+ICAJZGVmYXVsdDoKPiAtcGF0Y2hfZGVmYXVsdDogX19tYXliZV91bnVzZWQKPiAgCQly ZXQgPSBwYXJhdmlydF9wYXRjaF9kZWZhdWx0KHR5cGUsIGlidWYsIGFkZHIsIGxlbik7Cj4gIAkJ YnJlYWs7Cj4gLQo+IC1wYXRjaF9zaXRlOgo+IC0JCXJldCA9IHBhcmF2aXJ0X3BhdGNoX2luc25z KGlidWYsIGxlbiwgc3RhcnQsIGVuZCk7Cj4gLQkJYnJlYWs7Cj4gIAl9Cj4gICN1bmRlZiBQQVRD SF9TSVRFCj4gIAlyZXR1cm4gcmV0Owo+IGRpZmYgLS1naXQgYS9hcmNoL3g4Ni9rZXJuZWwvcGFy YXZpcnRfcGF0Y2hfNjQuYyBiL2FyY2gveDg2L2tlcm5lbC9wYXJhdmlydF9wYXRjaF82NC5jCj4g aW5kZXggNWFkNWJjZGE5ZGM2Li4yZGI2YzYxNTkzMmYgMTAwNjQ0Cj4gLS0tIGEvYXJjaC94ODYv a2VybmVsL3BhcmF2aXJ0X3BhdGNoXzY0LmMKPiArKysgYi9hcmNoL3g4Ni9rZXJuZWwvcGFyYXZp cnRfcGF0Y2hfNjQuYwo+IEBAIC00MiwxNCArNDIsMTUgQEAgZXh0ZXJuIGJvb2wgcHZfaXNfbmF0 aXZlX3ZjcHVfaXNfcHJlZW1wdGVkKHZvaWQpOwo+ICAKPiAgdW5zaWduZWQgbmF0aXZlX3BhdGNo KHU4IHR5cGUsIHZvaWQgKmlidWYsIHVuc2lnbmVkIGxvbmcgYWRkciwgdW5zaWduZWQgbGVuKQo+ ICB7Cj4gLQljb25zdCB1bnNpZ25lZCBjaGFyICpzdGFydCwgKmVuZDsKPiArCWNvbnN0IHVuc2ln bmVkIGNoYXIgKnN0YXJ0IF9fbWF5YmVfdW51c2VkLCAqZW5kIF9fbWF5YmVfdW51c2VkOwoKRHJv cCBzdGFydCBhbmQgZW5kIGFuZCAuLi4KCj4gIAl1bnNpZ25lZCByZXQ7Cj4gIAo+ICAjZGVmaW5l IFBBVENIX1NJVEUob3BzLCB4KQkJCQkJXAo+ICAJCWNhc2UgUEFSQVZJUlRfUEFUQ0gob3BzLngp OgkJCVwKPiAgCQkJc3RhcnQgPSBzdGFydF8jI29wcyMjXyMjeDsJCVwKPiAgCQkJZW5kID0gZW5k XyMjb3BzIyNfIyN4OwkJCVwKPiAtCQkJZ290byBwYXRjaF9zaXRlCj4gKwkJCQkJCQkJXAo+ICsJ CQlyZXR1cm4gcGFyYXZpcnRfcGF0Y2hfaW5zbnMoaWJ1ZiwgbGVuLCBzdGFydCwgZW5kKTsKCi4u LiBkbzogcmV0dXJuIHBhcmF2aXJ0X3BhdGNoX2luc25zKGlidWYsIGxlbiwgc3RhcnRfIyNvcHMj I18jI3gsCmVuZF8jI29wcyMjXyMjeCkKCmFuZCBwbGVhc2Ugb21pdCB0aGUgc2VtaWNvbG9uIGFm dGVyIHRoZSBsYXN0IGluc3RydWN0aW9uIGluIHRoZSBtYWNyby4KCihiZWxvdyB0aGUgc2FtZSkK Cj4gIAlzd2l0Y2godHlwZSkgewo+ICAjaWZkZWYgQ09ORklHX1BBUkFWSVJUX1hYTAo+ICAJCVBB VENIX1NJVEUoaXJxLCByZXN0b3JlX2ZsKTsKPiBAQCAtNjgsMjcgKzY5LDI0IEBAIHVuc2lnbmVk IG5hdGl2ZV9wYXRjaCh1OCB0eXBlLCB2b2lkICppYnVmLCB1bnNpZ25lZCBsb25nIGFkZHIsIHVu c2lnbmVkIGxlbikKPiAgCQkJaWYgKHB2X2lzX25hdGl2ZV9zcGluX3VubG9jaygpKSB7Cj4gIAkJ CQlzdGFydCA9IHN0YXJ0X2xvY2tfcXVldWVkX3NwaW5fdW5sb2NrOwo+ICAJCQkJZW5kICAgPSBl bmRfbG9ja19xdWV1ZWRfc3Bpbl91bmxvY2s7Cj4gLQkJCQlnb3RvIHBhdGNoX3NpdGU7Cj4gKwo+ ICsJCQkJcmV0dXJuIHBhcmF2aXJ0X3BhdGNoX2luc25zKGlidWYsIGxlbiwgc3RhcnQsIGVuZCk7 Cj4gIAkJCX0KPiAtCQkJZ290byBwYXRjaF9kZWZhdWx0Owo+ICsJCQlyZXR1cm4gcGFyYXZpcnRf cGF0Y2hfZGVmYXVsdCh0eXBlLCBpYnVmLCBhZGRyLCBsZW4pOwo+ICAKPiAgCQljYXNlIFBBUkFW SVJUX1BBVENIKGxvY2sudmNwdV9pc19wcmVlbXB0ZWQpOgo+ICAJCQlpZiAocHZfaXNfbmF0aXZl X3ZjcHVfaXNfcHJlZW1wdGVkKCkpIHsKPiAgCQkJCXN0YXJ0ID0gc3RhcnRfbG9ja192Y3B1X2lz X3ByZWVtcHRlZDsKPiAgCQkJCWVuZCAgID0gZW5kX2xvY2tfdmNwdV9pc19wcmVlbXB0ZWQ7Cj4g LQkJCQlnb3RvIHBhdGNoX3NpdGU7Cj4gKwo+ICsJCQkJcmV0dXJuIHBhcmF2aXJ0X3BhdGNoX2lu c25zKGlidWYsIGxlbiwgc3RhcnQsIGVuZCk7Cj4gIAkJCX0KPiAtCQkJZ290byBwYXRjaF9kZWZh dWx0Owo+ICsJCQlyZXR1cm4gcGFyYXZpcnRfcGF0Y2hfZGVmYXVsdCh0eXBlLCBpYnVmLCBhZGRy LCBsZW4pOwo+ICAjZW5kaWYKPiAgCj4gIAlkZWZhdWx0Ogo+IC1wYXRjaF9kZWZhdWx0OiBfX21h eWJlX3VudXNlZAo+ICAJCXJldCA9IHBhcmF2aXJ0X3BhdGNoX2RlZmF1bHQodHlwZSwgaWJ1Ziwg YWRkciwgbGVuKTsKPiAgCQlicmVhazsKPiAtCj4gLXBhdGNoX3NpdGU6Cj4gLQkJcmV0ID0gcGFy YXZpcnRfcGF0Y2hfaW5zbnMoaWJ1ZiwgbGVuLCBzdGFydCwgZW5kKTsKPiAtCQlicmVhazsKPiAg CX0KPiAgI3VuZGVmIFBBVENIX1NJVEUKPiAgCXJldHVybiByZXQ7Cj4gCgpKdWVyZ2VuCl9fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fClZpcnR1YWxpemF0aW9u IG1haWxpbmcgbGlzdApWaXJ0dWFsaXphdGlvbkBsaXN0cy5saW51eC1mb3VuZGF0aW9uLm9yZwpo dHRwczovL2xpc3RzLmxpbnV4Zm91bmRhdGlvbi5vcmcvbWFpbG1hbi9saXN0aW5mby92aXJ0dWFs aXphdGlvbg==