From mboxrd@z Thu Jan 1 00:00:00 1970 From: Eugene Syromiatnikov Subject: Re: [PATCH v4 3/6] parisc: add system call table generation support Date: Sun, 14 Oct 2018 03:06:58 +0200 Message-ID: <20181014010658.GB717@asgard.redhat.com> References: <1539337442-3676-1-git-send-email-firoz.khan@linaro.org> <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Cc: Kate Stewart , linux-arch@vger.kernel.org, arnd@arndb.de, linux-parisc@vger.kernel.org, y2038@lists.linaro.org, Greg Kroah-Hartman , Helge Deller , "James E . J . Bottomley" , linux-kernel@vger.kernel.org, marcin.juszkiewicz@linaro.org, deepa.kernel@gmail.com, Philippe Ombredanne , Thomas Gleixner To: Firoz Khan Return-path: In-Reply-To: <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: y2038-bounces@lists.linaro.org List-ID: T24gRnJpLCBPY3QgMTIsIDIwMTggYXQgMDM6MTM6NTlQTSArMDUzMCwgRmlyb3ogS2hhbiB3cm90 ZToKPiBkaWZmIC0tZ2l0IGEvYXJjaC9wYXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGwudGJs IGIvYXJjaC9wYXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGwudGJsCj4gbmV3IGZpbGUgbW9k ZSAxMDA2NDQKPiBpbmRleCAwMDAwMDAwLi43YzlmMjY4Cgo+ICs4NiAgICAgIGNvbW1vbiAgdXNl bGliICAgICAgICAgICAgICAgICAgICAgICAgICBzeXNfbmlfc3lzY2FsbAoKQWdhaW4sIHdoeSBp cyB0aGlzIGRlZmluaXRpb24gbGVmdCwgd2hpbGUgb3RoZXJzIGhhdmUgYmVlbiByZW1vdmVkPwoK PiArMzQ4ICAgICBjb21tb24gIHB3cml0ZXYyICAgICAgICAgICAgICAgICAgICAgICAgc3lzX3B3 cml0ZXYyICAgICAgICAgICAgICAgICAgICBjb21wYXRfc3lzX3B3cml0ZXYyCj4gKzM0OSAgICAg Y29tbW9uICBzdGF0eCAgICAgICAgICAgICAgICAgICAgICAgICAgIHN5c19zdGF0eAo+ICszNTAJ Y29tbW9uICBpb19wZ2V0ZXZlbnRzCQkJc3lzX2lvX3BnZXRldmVudHMJCWNvbXBhdF9zeXNfaW9f cGdldGV2ZW50cwoKVGFiIGluc3RlYWQgb2Ygc3BhY2VzLgoKPiBkaWZmIC0tZ2l0IGEvYXJjaC9w YXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGxoZHIuc2ggYi9hcmNoL3BhcmlzYy9rZXJuZWwv c3lzY2FsbHMvc3lzY2FsbGhkci5zaAo+IG5ldyBmaWxlIG1vZGUgMTAwNjQ0Cj4gaW5kZXggMDAw MDAwMC4uNjA3ZDRjYQo+IC0tLSAvZGV2L251bGwKPiArKysgYi9hcmNoL3BhcmlzYy9rZXJuZWwv c3lzY2FsbHMvc3lzY2FsbGhkci5zaAo+IEBAIC0wLDAgKzEsMzUgQEAKPiArIyEvYmluL3NoCgov YmluL3NoIC1lZnUKCj4gKyMgU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEdQTC0yLjAKCiJleHBv cnQgTEFORz1DIiwgZHVlIHRvIHVzYWdlIG9mIHNlZC9ncmVwL3NvcnQuCgo+ICsKPiAraW49IiQx Igo+ICtvdXQ9IiQyIgo+ICtteV9hYmlzPWBlY2hvICIoJDMpIiB8IHRyICcsJyAnfCdgCj4gK3By ZWZpeD0iJDQiCj4gK29mZnNldD0iJDUiCj4gKwo+ICtmaWxlZ3VhcmQ9X1VBUElfQVNNX1BBUklT Q19gYmFzZW5hbWUgIiRvdXQiIHwgc2VkIFwKPiArICAgIC1lICd5L2FiY2RlZmdoaWprbG1ub3Bx cnN0dXZ3eHl6L0FCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaLycgXAo+ICsgICAgLWUgJ3MvW15B LVowLTlfXS9fL2cnIC1lICdzL19fL18vZydgCj4gK2dyZXAgLUUgIl5bMC05QS1GYS1mWHhdK1tb OnNwYWNlOl1dKyR7bXlfYWJpc30iICIkaW4iIHwgc29ydCAtbiB8ICgKCmdyZXAgLUUgJ15bWzp4 ZGlnaXQ6XVh4XStbWzpzcGFjZTpdXSsnIiR7bXlfYWJpc30iICIkaW4iCnNvcnQgLW4gLWsxLDEK Cj4gKyAgICBlY2hvICIjaWZuZGVmICR7ZmlsZWd1YXJkfSIKPiArICAgIGVjaG8gIiNkZWZpbmUg JHtmaWxlZ3VhcmR9Igo+ICsgICAgZWNobyAiIgoKCWNhdCA8PC1FT0YKCQkjaWZuZGVmICR7Zmls ZWd1YXJkfQoJCSNkZWZpbmUgJHtmaWxlZ3VhcmR9CgoJRU9GCgo+ICsKPiArICAgIG54dD0wCj4g KyAgICB3aGlsZSByZWFkIG5yIGFiaSBuYW1lIGVudHJ5IGNvbXBhdCA7IGRvCj4gKwlpZiBbIC16 ICIkb2Zmc2V0IiBdOyB0aGVuCj4gKwkgICAgZWNobyAtZSAiI2RlZmluZSBfX05SXyR7cHJlZml4 fSR7bmFtZX1cdCRuciIKPiArCWVsc2UKPiArCSAgICBlY2hvIC1lICIjZGVmaW5lIF9fTlJfJHtw cmVmaXh9JHtuYW1lfVx0KCRvZmZzZXQgKyAkbnIpIgo+ICsJZmkKCmVjaG8gb3B0aW9ucyBhcmUg bm90IHBvcnRhYmxlOyBzb21ldGhpbmcgbGlrZQoKCXByaW50ZiAiI2RlZmluZSBfX05SXyVzJXNc dCglcyArICVzKSIgIiR7cHJlZml4fSIgIiR7bmFtZX0iICIke29mZnNldH0iICIke25yfSIKCj4g KwlueHQ9JG5yCj4gKwlsZXQgbnh0PW54dCsxCgoibGV0IiBpcyBhIGJhc2ggZXh0ZW5zaW9uLCBw b3NpeC1jb25mb3JtYW50IGV4cHJlc3Npb24gd291bGQgYmUKCglueHQ9JCgobnIgKyAxKSkKCihJ IHdvdWxkIGFsc28gY2hlY2sgdGhhdCBuciA+PSBueHQsIGhvd2V2ZXIpCgo+ICsgICAgZG9uZQo+ ICsKPiArICAgIGVjaG8gIiIKPiArICAgIGVjaG8gIiNpZmRlZiBfX0tFUk5FTF9fIgo+ICsgICAg ZWNobyAtZSAiI2RlZmluZSBfX05SX3N5c2NhbGxzXHQkbnh0Igo+ICsgICAgZWNobyAiI2VuZGlm Igo+ICsgICAgZWNobyAiIgo+ICsgICAgZWNobyAiI2VuZGlmIC8qICR7ZmlsZWd1YXJkfSAqLyIK CgljYXQgPDwtRU9GCgoJCSNpZmRlZiBfX0tFUk5FTF9fCgkJIyBkZWZpbmUgX19OUl9zeXNjYWxs c1x0JHtueHR9CgkJI2VuZGlmCgoJCSNlbmRpZiAvKiAke2ZpbGVndWFyZH0gKi8KCUVPRgoKPiAr KSA+ICIkb3V0Igo+IGRpZmYgLS1naXQgYS9hcmNoL3BhcmlzYy9rZXJuZWwvc3lzY2FsbHMvc3lz Y2FsbHRibC5zaCBiL2FyY2gvcGFyaXNjL2tlcm5lbC9zeXNjYWxscy9zeXNjYWxsdGJsLnNoCj4g bmV3IGZpbGUgbW9kZSAxMDA2NDQKPiBpbmRleCAwMDAwMDAwLi4wNGFiZGU3Cj4gLS0tIC9kZXYv bnVsbAo+ICsrKyBiL2FyY2gvcGFyaXNjL2tlcm5lbC9zeXNjYWxscy9zeXNjYWxsdGJsLnNoCj4g QEAgLTAsMCArMSw0NiBAQAo+ICsjIS9iaW4vc2gKPiArIyBTUERYLUxpY2Vuc2UtSWRlbnRpZmll cjogR1BMLTIuMAo+ICsKPiAraW49IiQxIgo+ICtvdXQ9IiQyIgo+ICtteV9hYmlzPWBlY2hvICIo JDMpIiB8IHRyICcsJyAnfCdgCj4gK29mZnNldD0iJDQiCj4gKwo+ICtlbWl0KCkgewo+ICsgICAg bnh0PSIkMSIKPiArICAgIGlmIFsgLXogIiRvZmZzZXQiIF07IHRoZW4KPiArCW5yPSIkMiIKPiAr ICAgIGVsc2UKPiArCW5yPSIkMiIKPiArCW5yPSQoKG5yK29mZnNldCkpCj4gKyAgICBmaQo+ICsg ICAgZW50cnk9IiQzIgo+ICsKPiArICAgIHdoaWxlIFsgJG54dCAtbHQgJG5yIF07IGRvCgpJdCB3 b3VsZCBicmVhayBuaWNlbHkgaWYgbnh0PSItbiB4IC1vIDEiIG9yIHNvbWV0aGluZyBsaWtlIHRo YXQuCgo+ICsJZWNobyAiX19TWVNDQUxMKCRueHQsIHN5c19uaV9zeXNjYWxsLCApIgo+ICsgICAg ICAgIGxldCBueHQ9bnh0KzEKPiArICAgIGRvbmUKPiArICAgIGVjaG8gIl9fU1lTQ0FMTCgkbnh0 LCAkZW50cnksICkiCj4gK30KPiArCj4gK2dyZXAgLUUgIl5bMC05QS1GYS1mWHhdK1tbOnNwYWNl Ol1dKyR7bXlfYWJpc30iICIkaW4iIHwgc29ydCAtbiB8ICgKPiArICAgIGlmIFsgLXogIiRvZmZz ZXQiIF07IHRoZW4KPiArCW54dD0wCj4gKyAgICBlbHNlCj4gKwlueHQ9JG9mZnNldAo+ICsgICAg ZmkKPiArCj4gKyAgICBteV9hYmk9IiQoY3V0IC1kJ3wnIC1mMiA8PDwgJG15X2FiaXMpIgoKCW15 X2FiaT0iJHtteV9hYmlzIyp8fSIKCkJ1dCBpdCBsb29rcyBsaWtlIHRoYXQgJG15X2FiaXMgaW5j bHVkZXMgcGFyZW50aGVzZXMgYW5kIHRoaXMgY29kZQppcyBicm9rZW4uCgo+ICsgICAgd2hpbGUg cmVhZCBuciBhYmkgbmFtZSBlbnRyeSBjb21wYXQgOyBkbwo+ICsJaWYgWyAkbXlfYWJpID0gImNv bXBhdCIgXTsgdGhlbgo+ICsJICAgIGlmIFsgLXogIiRjb21wYXQiIF07IHRoZW4KPiArCQllbWl0 ICRueHQgJG5yICRlbnRyeQo+ICsJICAgIGVsc2UKPiArCQllbWl0ICRueHQgJG5yICRjb21wYXQK PiArCSAgICBmaQo+ICsJZWxzZQo+ICsJICAgIGVtaXQgJG54dCAkbnIgJGVudHJ5Cj4gKwlmaQo+ ICsgICAgICAgIGxldCBueHQ9bnh0KzEKPiArICAgIGRvbmUKPiArKSA+ICIkb3V0Igo+IC0tIAo+ IDEuOS4xCj4gCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f ClkyMDM4IG1haWxpbmcgbGlzdApZMjAzOEBsaXN0cy5saW5hcm8ub3JnCmh0dHBzOi8vbGlzdHMu bGluYXJvLm9yZy9tYWlsbWFuL2xpc3RpbmZvL3kyMDM4Cg== 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=-5.2 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_PASS,URIBL_BLOCKED,USER_AGENT_MUTT 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 91ED0C28CF8 for ; Sun, 14 Oct 2018 01:06:45 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 4999A20693 for ; Sun, 14 Oct 2018 01:06:45 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 4999A20693 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.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 S1726147AbeJNIpu (ORCPT ); Sun, 14 Oct 2018 04:45:50 -0400 Received: from mx1.redhat.com ([209.132.183.28]:34630 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725733AbeJNIpu (ORCPT ); Sun, 14 Oct 2018 04:45:50 -0400 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.phx2.redhat.com [10.5.11.16]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id B05C93082133; Sun, 14 Oct 2018 01:06:41 +0000 (UTC) Received: from asgard.redhat.com (ovpn-200-28.brq.redhat.com [10.40.200.28]) by smtp.corp.redhat.com (Postfix) with ESMTPS id A239280795; Sun, 14 Oct 2018 01:06:36 +0000 (UTC) Date: Sun, 14 Oct 2018 03:06:58 +0200 From: Eugene Syromiatnikov To: Firoz Khan Cc: linux-parisc@vger.kernel.org, "James E . J . Bottomley" , Helge Deller , Thomas Gleixner , Greg Kroah-Hartman , Philippe Ombredanne , Kate Stewart , y2038@lists.linaro.org, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org, arnd@arndb.de, deepa.kernel@gmail.com, marcin.juszkiewicz@linaro.org Subject: Re: [PATCH v4 3/6] parisc: add system call table generation support Message-ID: <20181014010658.GB717@asgard.redhat.com> References: <1539337442-3676-1-git-send-email-firoz.khan@linaro.org> <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> User-Agent: Mutt/1.5.23 (2014-03-12) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.16 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.42]); Sun, 14 Oct 2018 01:06:41 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Oct 12, 2018 at 03:13:59PM +0530, Firoz Khan wrote: > diff --git a/arch/parisc/kernel/syscalls/syscall.tbl b/arch/parisc/kernel/syscalls/syscall.tbl > new file mode 100644 > index 0000000..7c9f268 > +86 common uselib sys_ni_syscall Again, why is this definition left, while others have been removed? > +348 common pwritev2 sys_pwritev2 compat_sys_pwritev2 > +349 common statx sys_statx > +350 common io_pgetevents sys_io_pgetevents compat_sys_io_pgetevents Tab instead of spaces. > diff --git a/arch/parisc/kernel/syscalls/syscallhdr.sh b/arch/parisc/kernel/syscalls/syscallhdr.sh > new file mode 100644 > index 0000000..607d4ca > --- /dev/null > +++ b/arch/parisc/kernel/syscalls/syscallhdr.sh > @@ -0,0 +1,35 @@ > +#!/bin/sh /bin/sh -efu > +# SPDX-License-Identifier: GPL-2.0 "export LANG=C", due to usage of sed/grep/sort. > + > +in="$1" > +out="$2" > +my_abis=`echo "($3)" | tr ',' '|'` > +prefix="$4" > +offset="$5" > + > +fileguard=_UAPI_ASM_PARISC_`basename "$out" | sed \ > + -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/' \ > + -e 's/[^A-Z0-9_]/_/g' -e 's/__/_/g'` > +grep -E "^[0-9A-Fa-fXx]+[[:space:]]+${my_abis}" "$in" | sort -n | ( grep -E '^[[:xdigit:]Xx]+[[:space:]]+'"${my_abis}" "$in" sort -n -k1,1 > + echo "#ifndef ${fileguard}" > + echo "#define ${fileguard}" > + echo "" cat <<-EOF #ifndef ${fileguard} #define ${fileguard} EOF > + > + nxt=0 > + while read nr abi name entry compat ; do > + if [ -z "$offset" ]; then > + echo -e "#define __NR_${prefix}${name}\t$nr" > + else > + echo -e "#define __NR_${prefix}${name}\t($offset + $nr)" > + fi echo options are not portable; something like printf "#define __NR_%s%s\t(%s + %s)" "${prefix}" "${name}" "${offset}" "${nr}" > + nxt=$nr > + let nxt=nxt+1 "let" is a bash extension, posix-conformant expression would be nxt=$((nr + 1)) (I would also check that nr >= nxt, however) > + done > + > + echo "" > + echo "#ifdef __KERNEL__" > + echo -e "#define __NR_syscalls\t$nxt" > + echo "#endif" > + echo "" > + echo "#endif /* ${fileguard} */" cat <<-EOF #ifdef __KERNEL__ # define __NR_syscalls\t${nxt} #endif #endif /* ${fileguard} */ EOF > +) > "$out" > diff --git a/arch/parisc/kernel/syscalls/syscalltbl.sh b/arch/parisc/kernel/syscalls/syscalltbl.sh > new file mode 100644 > index 0000000..04abde7 > --- /dev/null > +++ b/arch/parisc/kernel/syscalls/syscalltbl.sh > @@ -0,0 +1,46 @@ > +#!/bin/sh > +# SPDX-License-Identifier: GPL-2.0 > + > +in="$1" > +out="$2" > +my_abis=`echo "($3)" | tr ',' '|'` > +offset="$4" > + > +emit() { > + nxt="$1" > + if [ -z "$offset" ]; then > + nr="$2" > + else > + nr="$2" > + nr=$((nr+offset)) > + fi > + entry="$3" > + > + while [ $nxt -lt $nr ]; do It would break nicely if nxt="-n x -o 1" or something like that. > + echo "__SYSCALL($nxt, sys_ni_syscall, )" > + let nxt=nxt+1 > + done > + echo "__SYSCALL($nxt, $entry, )" > +} > + > +grep -E "^[0-9A-Fa-fXx]+[[:space:]]+${my_abis}" "$in" | sort -n | ( > + if [ -z "$offset" ]; then > + nxt=0 > + else > + nxt=$offset > + fi > + > + my_abi="$(cut -d'|' -f2 <<< $my_abis)" my_abi="${my_abis#*|}" But it looks like that $my_abis includes parentheses and this code is broken. > + while read nr abi name entry compat ; do > + if [ $my_abi = "compat" ]; then > + if [ -z "$compat" ]; then > + emit $nxt $nr $entry > + else > + emit $nxt $nr $compat > + fi > + else > + emit $nxt $nr $entry > + fi > + let nxt=nxt+1 > + done > +) > "$out" > -- > 1.9.1 > From mboxrd@z Thu Jan 1 00:00:00 1970 From: Eugene Syromiatnikov Subject: Re: [PATCH v4 3/6] parisc: add system call table generation support Date: Sun, 14 Oct 2018 03:06:58 +0200 Message-ID: <20181014010658.GB717@asgard.redhat.com> References: <1539337442-3676-1-git-send-email-firoz.khan@linaro.org> <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Content-Disposition: inline In-Reply-To: <1539337442-3676-4-git-send-email-firoz.khan@linaro.org> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: y2038-bounces@lists.linaro.org Sender: "Y2038" To: Firoz Khan Cc: Kate Stewart , linux-arch@vger.kernel.org, arnd@arndb.de, linux-parisc@vger.kernel.org, y2038@lists.linaro.org, Greg Kroah-Hartman , Helge Deller , "James E . J . Bottomley" , linux-kernel@vger.kernel.org, marcin.juszkiewicz@linaro.org, deepa.kernel@gmail.com, Philippe Ombredanne , Thomas Gleixner List-Id: linux-arch.vger.kernel.org T24gRnJpLCBPY3QgMTIsIDIwMTggYXQgMDM6MTM6NTlQTSArMDUzMCwgRmlyb3ogS2hhbiB3cm90 ZToKPiBkaWZmIC0tZ2l0IGEvYXJjaC9wYXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGwudGJs IGIvYXJjaC9wYXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGwudGJsCj4gbmV3IGZpbGUgbW9k ZSAxMDA2NDQKPiBpbmRleCAwMDAwMDAwLi43YzlmMjY4Cgo+ICs4NiAgICAgIGNvbW1vbiAgdXNl bGliICAgICAgICAgICAgICAgICAgICAgICAgICBzeXNfbmlfc3lzY2FsbAoKQWdhaW4sIHdoeSBp cyB0aGlzIGRlZmluaXRpb24gbGVmdCwgd2hpbGUgb3RoZXJzIGhhdmUgYmVlbiByZW1vdmVkPwoK PiArMzQ4ICAgICBjb21tb24gIHB3cml0ZXYyICAgICAgICAgICAgICAgICAgICAgICAgc3lzX3B3 cml0ZXYyICAgICAgICAgICAgICAgICAgICBjb21wYXRfc3lzX3B3cml0ZXYyCj4gKzM0OSAgICAg Y29tbW9uICBzdGF0eCAgICAgICAgICAgICAgICAgICAgICAgICAgIHN5c19zdGF0eAo+ICszNTAJ Y29tbW9uICBpb19wZ2V0ZXZlbnRzCQkJc3lzX2lvX3BnZXRldmVudHMJCWNvbXBhdF9zeXNfaW9f cGdldGV2ZW50cwoKVGFiIGluc3RlYWQgb2Ygc3BhY2VzLgoKPiBkaWZmIC0tZ2l0IGEvYXJjaC9w YXJpc2Mva2VybmVsL3N5c2NhbGxzL3N5c2NhbGxoZHIuc2ggYi9hcmNoL3BhcmlzYy9rZXJuZWwv c3lzY2FsbHMvc3lzY2FsbGhkci5zaAo+IG5ldyBmaWxlIG1vZGUgMTAwNjQ0Cj4gaW5kZXggMDAw MDAwMC4uNjA3ZDRjYQo+IC0tLSAvZGV2L251bGwKPiArKysgYi9hcmNoL3BhcmlzYy9rZXJuZWwv c3lzY2FsbHMvc3lzY2FsbGhkci5zaAo+IEBAIC0wLDAgKzEsMzUgQEAKPiArIyEvYmluL3NoCgov YmluL3NoIC1lZnUKCj4gKyMgU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEdQTC0yLjAKCiJleHBv cnQgTEFORz1DIiwgZHVlIHRvIHVzYWdlIG9mIHNlZC9ncmVwL3NvcnQuCgo+ICsKPiAraW49IiQx Igo+ICtvdXQ9IiQyIgo+ICtteV9hYmlzPWBlY2hvICIoJDMpIiB8IHRyICcsJyAnfCdgCj4gK3By ZWZpeD0iJDQiCj4gK29mZnNldD0iJDUiCj4gKwo+ICtmaWxlZ3VhcmQ9X1VBUElfQVNNX1BBUklT Q19gYmFzZW5hbWUgIiRvdXQiIHwgc2VkIFwKPiArICAgIC1lICd5L2FiY2RlZmdoaWprbG1ub3Bx cnN0dXZ3eHl6L0FCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaLycgXAo+ICsgICAgLWUgJ3MvW15B LVowLTlfXS9fL2cnIC1lICdzL19fL18vZydgCj4gK2dyZXAgLUUgIl5bMC05QS1GYS1mWHhdK1tb OnNwYWNlOl1dKyR7bXlfYWJpc30iICIkaW4iIHwgc29ydCAtbiB8ICgKCmdyZXAgLUUgJ15bWzp4 ZGlnaXQ6XVh4XStbWzpzcGFjZTpdXSsnIiR7bXlfYWJpc30iICIkaW4iCnNvcnQgLW4gLWsxLDEK Cj4gKyAgICBlY2hvICIjaWZuZGVmICR7ZmlsZWd1YXJkfSIKPiArICAgIGVjaG8gIiNkZWZpbmUg JHtmaWxlZ3VhcmR9Igo+ICsgICAgZWNobyAiIgoKCWNhdCA8PC1FT0YKCQkjaWZuZGVmICR7Zmls ZWd1YXJkfQoJCSNkZWZpbmUgJHtmaWxlZ3VhcmR9CgoJRU9GCgo+ICsKPiArICAgIG54dD0wCj4g KyAgICB3aGlsZSByZWFkIG5yIGFiaSBuYW1lIGVudHJ5IGNvbXBhdCA7IGRvCj4gKwlpZiBbIC16 ICIkb2Zmc2V0IiBdOyB0aGVuCj4gKwkgICAgZWNobyAtZSAiI2RlZmluZSBfX05SXyR7cHJlZml4 fSR7bmFtZX1cdCRuciIKPiArCWVsc2UKPiArCSAgICBlY2hvIC1lICIjZGVmaW5lIF9fTlJfJHtw cmVmaXh9JHtuYW1lfVx0KCRvZmZzZXQgKyAkbnIpIgo+ICsJZmkKCmVjaG8gb3B0aW9ucyBhcmUg bm90IHBvcnRhYmxlOyBzb21ldGhpbmcgbGlrZQoKCXByaW50ZiAiI2RlZmluZSBfX05SXyVzJXNc dCglcyArICVzKSIgIiR7cHJlZml4fSIgIiR7bmFtZX0iICIke29mZnNldH0iICIke25yfSIKCj4g KwlueHQ9JG5yCj4gKwlsZXQgbnh0PW54dCsxCgoibGV0IiBpcyBhIGJhc2ggZXh0ZW5zaW9uLCBw b3NpeC1jb25mb3JtYW50IGV4cHJlc3Npb24gd291bGQgYmUKCglueHQ9JCgobnIgKyAxKSkKCihJ IHdvdWxkIGFsc28gY2hlY2sgdGhhdCBuciA+PSBueHQsIGhvd2V2ZXIpCgo+ICsgICAgZG9uZQo+ ICsKPiArICAgIGVjaG8gIiIKPiArICAgIGVjaG8gIiNpZmRlZiBfX0tFUk5FTF9fIgo+ICsgICAg ZWNobyAtZSAiI2RlZmluZSBfX05SX3N5c2NhbGxzXHQkbnh0Igo+ICsgICAgZWNobyAiI2VuZGlm Igo+ICsgICAgZWNobyAiIgo+ICsgICAgZWNobyAiI2VuZGlmIC8qICR7ZmlsZWd1YXJkfSAqLyIK CgljYXQgPDwtRU9GCgoJCSNpZmRlZiBfX0tFUk5FTF9fCgkJIyBkZWZpbmUgX19OUl9zeXNjYWxs c1x0JHtueHR9CgkJI2VuZGlmCgoJCSNlbmRpZiAvKiAke2ZpbGVndWFyZH0gKi8KCUVPRgoKPiAr KSA+ICIkb3V0Igo+IGRpZmYgLS1naXQgYS9hcmNoL3BhcmlzYy9rZXJuZWwvc3lzY2FsbHMvc3lz Y2FsbHRibC5zaCBiL2FyY2gvcGFyaXNjL2tlcm5lbC9zeXNjYWxscy9zeXNjYWxsdGJsLnNoCj4g bmV3IGZpbGUgbW9kZSAxMDA2NDQKPiBpbmRleCAwMDAwMDAwLi4wNGFiZGU3Cj4gLS0tIC9kZXYv bnVsbAo+ICsrKyBiL2FyY2gvcGFyaXNjL2tlcm5lbC9zeXNjYWxscy9zeXNjYWxsdGJsLnNoCj4g QEAgLTAsMCArMSw0NiBAQAo+ICsjIS9iaW4vc2gKPiArIyBTUERYLUxpY2Vuc2UtSWRlbnRpZmll cjogR1BMLTIuMAo+ICsKPiAraW49IiQxIgo+ICtvdXQ9IiQyIgo+ICtteV9hYmlzPWBlY2hvICIo JDMpIiB8IHRyICcsJyAnfCdgCj4gK29mZnNldD0iJDQiCj4gKwo+ICtlbWl0KCkgewo+ICsgICAg bnh0PSIkMSIKPiArICAgIGlmIFsgLXogIiRvZmZzZXQiIF07IHRoZW4KPiArCW5yPSIkMiIKPiAr ICAgIGVsc2UKPiArCW5yPSIkMiIKPiArCW5yPSQoKG5yK29mZnNldCkpCj4gKyAgICBmaQo+ICsg ICAgZW50cnk9IiQzIgo+ICsKPiArICAgIHdoaWxlIFsgJG54dCAtbHQgJG5yIF07IGRvCgpJdCB3 b3VsZCBicmVhayBuaWNlbHkgaWYgbnh0PSItbiB4IC1vIDEiIG9yIHNvbWV0aGluZyBsaWtlIHRo YXQuCgo+ICsJZWNobyAiX19TWVNDQUxMKCRueHQsIHN5c19uaV9zeXNjYWxsLCApIgo+ICsgICAg ICAgIGxldCBueHQ9bnh0KzEKPiArICAgIGRvbmUKPiArICAgIGVjaG8gIl9fU1lTQ0FMTCgkbnh0 LCAkZW50cnksICkiCj4gK30KPiArCj4gK2dyZXAgLUUgIl5bMC05QS1GYS1mWHhdK1tbOnNwYWNl Ol1dKyR7bXlfYWJpc30iICIkaW4iIHwgc29ydCAtbiB8ICgKPiArICAgIGlmIFsgLXogIiRvZmZz ZXQiIF07IHRoZW4KPiArCW54dD0wCj4gKyAgICBlbHNlCj4gKwlueHQ9JG9mZnNldAo+ICsgICAg ZmkKPiArCj4gKyAgICBteV9hYmk9IiQoY3V0IC1kJ3wnIC1mMiA8PDwgJG15X2FiaXMpIgoKCW15 X2FiaT0iJHtteV9hYmlzIyp8fSIKCkJ1dCBpdCBsb29rcyBsaWtlIHRoYXQgJG15X2FiaXMgaW5j bHVkZXMgcGFyZW50aGVzZXMgYW5kIHRoaXMgY29kZQppcyBicm9rZW4uCgo+ICsgICAgd2hpbGUg cmVhZCBuciBhYmkgbmFtZSBlbnRyeSBjb21wYXQgOyBkbwo+ICsJaWYgWyAkbXlfYWJpID0gImNv bXBhdCIgXTsgdGhlbgo+ICsJICAgIGlmIFsgLXogIiRjb21wYXQiIF07IHRoZW4KPiArCQllbWl0 ICRueHQgJG5yICRlbnRyeQo+ICsJICAgIGVsc2UKPiArCQllbWl0ICRueHQgJG5yICRjb21wYXQK PiArCSAgICBmaQo+ICsJZWxzZQo+ICsJICAgIGVtaXQgJG54dCAkbnIgJGVudHJ5Cj4gKwlmaQo+ ICsgICAgICAgIGxldCBueHQ9bnh0KzEKPiArICAgIGRvbmUKPiArKSA+ICIkb3V0Igo+IC0tIAo+ IDEuOS4xCj4gCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f ClkyMDM4IG1haWxpbmcgbGlzdApZMjAzOEBsaXN0cy5saW5hcm8ub3JnCmh0dHBzOi8vbGlzdHMu bGluYXJvLm9yZy9tYWlsbWFuL2xpc3RpbmZvL3kyMDM4Cg==