From mboxrd@z Thu Jan 1 00:00:00 1970 From: =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PATCH v5 08/12] KVM: arm64: re-factor hyp.S debug register code Date: Fri, 29 May 2015 10:30:24 +0100 Message-ID: <1432891828-4816-9-git-send-email-alex.bennee@linaro.org> References: <1432891828-4816-1-git-send-email-alex.bennee@linaro.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Cc: Catalin Marinas , Gleb Natapov , jan.kiszka@siemens.com, Will Deacon , open list , dahi@linux.vnet.ibm.com, r65777@freescale.com, bp@suse.de To: kvm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, christoffer.dall@linaro.org, marc.zyngier@arm.com, peter.maydell@linaro.org, agraf@suse.de, drjones@redhat.com, pbonzini@redhat.com, zhichao.huang@linaro.org Return-path: In-Reply-To: <1432891828-4816-1-git-send-email-alex.bennee@linaro.org> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: kvmarm-bounces@lists.cs.columbia.edu Sender: kvmarm-bounces@lists.cs.columbia.edu List-Id: kvm.vger.kernel.org VGhpcyBpcyBhIHByZS1jdXJzb3IgdG8gc2hhcmluZyB0aGUgY29kZSB3aXRoIHRoZSBndWVzdCBk ZWJ1ZyBzdXBwb3J0LgpUaGlzIHJlcGxhY2VzIHRoZSBiaWcgbWFjcm8gdGhhdCBmaXNoZXMgZGF0 YSBvdXQgb2YgYSBmaXhlZCBsb2NhdGlvbgp3aXRoIGEgbW9yZSBnZW5lcmFsIGhlbHBlciBtYWNy byB0byByZXN0b3JlIGEgc2V0IG9mIGRlYnVnIHJlZ2lzdGVycy4gSXQKdXNlcyBtYWNybyBzdWJz dGl0dXRpb24gc28gaXQgY2FuIGJlIHJlLXVzZWQgZm9yIGRlYnVnIGNvbnRyb2wgYW5kIHZhbHVl CnJlZ2lzdGVycy4gSXQgZG9lcyBob3dldmVyIHJlbHkgb24gdGhlIGRlYnVnIHJlZ2lzdGVycyBi ZWluZyA2NCBiaXQKYWxpZ25lZCAoYXMgdGhleSBoYXBwZW4gdG8gYmUgaW4gdGhlIGh5cCBBQkkp LgoKU2lnbmVkLW9mZi1ieTogQWxleCBCZW5uw6llIDxhbGV4LmJlbm5lZUBsaW5hcm8ub3JnPgoK LS0tCnYzOgogIC0gcmV0dXJuIHRvIHRoZSBwYXRjaCBzZXJpZXMKICAtIGFkZCBzYXZlIGFuZCBy ZXN0b3JlIHRhcmdldHMKICAtIGNoYW5nZSByZWdpc3RlciB1c2UgYW5kIGRvY3VtZW50CnY0Ogog IC0ga2VlcCBvcmlnaW5hbCBzZXR1cC9yZXN0b3JlIG5hbWVzCiAgLSBkb24ndCB1c2Ugc3BsaXQg dTMyL3U2NCBzdHJ1Y3R1cmUgeWV0Ci0tLQogYXJjaC9hcm02NC9rdm0vaHlwLlMgfCA1MTkgKysr KysrKysrKysrKystLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAxIGZpbGUg Y2hhbmdlZCwgMTQwIGluc2VydGlvbnMoKyksIDM3OSBkZWxldGlvbnMoLSkKCmRpZmYgLS1naXQg YS9hcmNoL2FybTY0L2t2bS9oeXAuUyBiL2FyY2gvYXJtNjQva3ZtL2h5cC5TCmluZGV4IDc0ZTYz ZDguLjljNDg5N2QgMTAwNjQ0Ci0tLSBhL2FyY2gvYXJtNjQva3ZtL2h5cC5TCisrKyBiL2FyY2gv YXJtNjQva3ZtL2h5cC5TCkBAIC0yMjgsMTk5ICsyMjgsNTIgQEAKIAlzdHAJeDI0LCB4MjUsIFt4 MywgIzE2MF0KIC5lbmRtCiAKLS5tYWNybyBzYXZlX2RlYnVnCi0JLy8geDI6IGJhc2UgYWRkcmVz cyBmb3IgY3B1IGNvbnRleHQKLQkvLyB4MzogdG1wIHJlZ2lzdGVyCi0KLQltcnMJeDI2LCBpZF9h YTY0ZGZyMF9lbDEKLQl1YmZ4CXgyNCwgeDI2LCAjMTIsICM0CS8vIEV4dHJhY3QgQlJQcwotCXVi ZngJeDI1LCB4MjYsICMyMCwgIzQJLy8gRXh0cmFjdCBXUlBzCi0JbW92CXcyNiwgIzE1Ci0Jc3Vi CXcyNCwgdzI2LCB3MjQJCS8vIEhvdyBtYW55IEJQcyB0byBza2lwCi0Jc3ViCXcyNSwgdzI2LCB3 MjUJCS8vIEhvdyBtYW55IFdQcyB0byBza2lwCi0KLQlhZGQJeDMsIHgyLCAjQ1BVX1NZU1JFR19P RkZTRVQoREJHQkNSMF9FTDEpCi0KLQlhZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI0LCBs c2wgIzIKLQlicgl4MjYKLTE6Ci0JbXJzCXgyMCwgZGJnYmNyMTVfZWwxCi0JbXJzCXgxOSwgZGJn YmNyMTRfZWwxCi0JbXJzCXgxOCwgZGJnYmNyMTNfZWwxCi0JbXJzCXgxNywgZGJnYmNyMTJfZWwx Ci0JbXJzCXgxNiwgZGJnYmNyMTFfZWwxCi0JbXJzCXgxNSwgZGJnYmNyMTBfZWwxCi0JbXJzCXgx NCwgZGJnYmNyOV9lbDEKLQltcnMJeDEzLCBkYmdiY3I4X2VsMQotCW1ycwl4MTIsIGRiZ2Jjcjdf ZWwxCi0JbXJzCXgxMSwgZGJnYmNyNl9lbDEKLQltcnMJeDEwLCBkYmdiY3I1X2VsMQotCW1ycwl4 OSwgZGJnYmNyNF9lbDEKLQltcnMJeDgsIGRiZ2JjcjNfZWwxCi0JbXJzCXg3LCBkYmdiY3IyX2Vs MQotCW1ycwl4NiwgZGJnYmNyMV9lbDEKLQltcnMJeDUsIGRiZ2JjcjBfZWwxCi0KLQlhZHIJeDI2 LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI0LCBsc2wgIzIKLQlicgl4MjYKLQotMToKLQlzdHIJeDIw LCBbeDMsICMoMTUgKiA4KV0KLQlzdHIJeDE5LCBbeDMsICMoMTQgKiA4KV0KLQlzdHIJeDE4LCBb eDMsICMoMTMgKiA4KV0KLQlzdHIJeDE3LCBbeDMsICMoMTIgKiA4KV0KLQlzdHIJeDE2LCBbeDMs ICMoMTEgKiA4KV0KLQlzdHIJeDE1LCBbeDMsICMoMTAgKiA4KV0KLQlzdHIJeDE0LCBbeDMsICMo OSAqIDgpXQotCXN0cgl4MTMsIFt4MywgIyg4ICogOCldCi0Jc3RyCXgxMiwgW3gzLCAjKDcgKiA4 KV0KLQlzdHIJeDExLCBbeDMsICMoNiAqIDgpXQotCXN0cgl4MTAsIFt4MywgIyg1ICogOCldCi0J c3RyCXg5LCBbeDMsICMoNCAqIDgpXQotCXN0cgl4OCwgW3gzLCAjKDMgKiA4KV0KLQlzdHIJeDcs IFt4MywgIygyICogOCldCi0Jc3RyCXg2LCBbeDMsICMoMSAqIDgpXQotCXN0cgl4NSwgW3gzLCAj KDAgKiA4KV0KLQotCWFkZAl4MywgeDIsICNDUFVfU1lTUkVHX09GRlNFVChEQkdCVlIwX0VMMSkK LQotCWFkcgl4MjYsIDFmCi0JYWRkCXgyNiwgeDI2LCB4MjQsIGxzbCAjMgotCWJyCXgyNgotMToK LQltcnMJeDIwLCBkYmdidnIxNV9lbDEKLQltcnMJeDE5LCBkYmdidnIxNF9lbDEKLQltcnMJeDE4 LCBkYmdidnIxM19lbDEKLQltcnMJeDE3LCBkYmdidnIxMl9lbDEKLQltcnMJeDE2LCBkYmdidnIx MV9lbDEKLQltcnMJeDE1LCBkYmdidnIxMF9lbDEKLQltcnMJeDE0LCBkYmdidnI5X2VsMQotCW1y cwl4MTMsIGRiZ2J2cjhfZWwxCi0JbXJzCXgxMiwgZGJnYnZyN19lbDEKLQltcnMJeDExLCBkYmdi dnI2X2VsMQotCW1ycwl4MTAsIGRiZ2J2cjVfZWwxCi0JbXJzCXg5LCBkYmdidnI0X2VsMQotCW1y cwl4OCwgZGJnYnZyM19lbDEKLQltcnMJeDcsIGRiZ2J2cjJfZWwxCi0JbXJzCXg2LCBkYmdidnIx X2VsMQotCW1ycwl4NSwgZGJnYnZyMF9lbDEKLQotCWFkcgl4MjYsIDFmCi0JYWRkCXgyNiwgeDI2 LCB4MjQsIGxzbCAjMgotCWJyCXgyNgotCi0xOgotCXN0cgl4MjAsIFt4MywgIygxNSAqIDgpXQot CXN0cgl4MTksIFt4MywgIygxNCAqIDgpXQotCXN0cgl4MTgsIFt4MywgIygxMyAqIDgpXQotCXN0 cgl4MTcsIFt4MywgIygxMiAqIDgpXQotCXN0cgl4MTYsIFt4MywgIygxMSAqIDgpXQotCXN0cgl4 MTUsIFt4MywgIygxMCAqIDgpXQotCXN0cgl4MTQsIFt4MywgIyg5ICogOCldCi0Jc3RyCXgxMywg W3gzLCAjKDggKiA4KV0KLQlzdHIJeDEyLCBbeDMsICMoNyAqIDgpXQotCXN0cgl4MTEsIFt4Mywg Iyg2ICogOCldCi0Jc3RyCXgxMCwgW3gzLCAjKDUgKiA4KV0KLQlzdHIJeDksIFt4MywgIyg0ICog OCldCi0Jc3RyCXg4LCBbeDMsICMoMyAqIDgpXQotCXN0cgl4NywgW3gzLCAjKDIgKiA4KV0KLQlz dHIJeDYsIFt4MywgIygxICogOCldCi0Jc3RyCXg1LCBbeDMsICMoMCAqIDgpXQotCi0JYWRkCXgz LCB4MiwgI0NQVV9TWVNSRUdfT0ZGU0VUKERCR1dDUjBfRUwxKQotCi0JYWRyCXgyNiwgMWYKLQlh ZGQJeDI2LCB4MjYsIHgyNSwgbHNsICMyCi0JYnIJeDI2CisubWFjcm8gc2F2ZV9kZWJ1ZyB0eXBl CisJLy8geDQ6IHBvaW50ZXIgdG8gcmVnaXN0ZXIgc2V0CisJLy8geDU6IG51bWJlciBvZiByZWdp c3RlcnMgdG8gc2tpcAorCS8vIHg2Li54MjIgdHJhc2hlZAorCisJYWRyCXgyMiwgMWYKKwlhZGQJ eDIyLCB4MjIsIHg1LCBsc2wgIzIKKwlicgl4MjIKIDE6Ci0JbXJzCXgyMCwgZGJnd2NyMTVfZWwx Ci0JbXJzCXgxOSwgZGJnd2NyMTRfZWwxCi0JbXJzCXgxOCwgZGJnd2NyMTNfZWwxCi0JbXJzCXgx NywgZGJnd2NyMTJfZWwxCi0JbXJzCXgxNiwgZGJnd2NyMTFfZWwxCi0JbXJzCXgxNSwgZGJnd2Ny MTBfZWwxCi0JbXJzCXgxNCwgZGJnd2NyOV9lbDEKLQltcnMJeDEzLCBkYmd3Y3I4X2VsMQotCW1y cwl4MTIsIGRiZ3djcjdfZWwxCi0JbXJzCXgxMSwgZGJnd2NyNl9lbDEKLQltcnMJeDEwLCBkYmd3 Y3I1X2VsMQotCW1ycwl4OSwgZGJnd2NyNF9lbDEKLQltcnMJeDgsIGRiZ3djcjNfZWwxCi0JbXJz CXg3LCBkYmd3Y3IyX2VsMQotCW1ycwl4NiwgZGJnd2NyMV9lbDEKLQltcnMJeDUsIGRiZ3djcjBf ZWwxCi0KLQlhZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI1LCBsc2wgIzIKLQlicgl4MjYK LQotMToKLQlzdHIJeDIwLCBbeDMsICMoMTUgKiA4KV0KLQlzdHIJeDE5LCBbeDMsICMoMTQgKiA4 KV0KLQlzdHIJeDE4LCBbeDMsICMoMTMgKiA4KV0KLQlzdHIJeDE3LCBbeDMsICMoMTIgKiA4KV0K LQlzdHIJeDE2LCBbeDMsICMoMTEgKiA4KV0KLQlzdHIJeDE1LCBbeDMsICMoMTAgKiA4KV0KLQlz dHIJeDE0LCBbeDMsICMoOSAqIDgpXQotCXN0cgl4MTMsIFt4MywgIyg4ICogOCldCi0Jc3RyCXgx MiwgW3gzLCAjKDcgKiA4KV0KLQlzdHIJeDExLCBbeDMsICMoNiAqIDgpXQotCXN0cgl4MTAsIFt4 MywgIyg1ICogOCldCi0Jc3RyCXg5LCBbeDMsICMoNCAqIDgpXQotCXN0cgl4OCwgW3gzLCAjKDMg KiA4KV0KLQlzdHIJeDcsIFt4MywgIygyICogOCldCi0Jc3RyCXg2LCBbeDMsICMoMSAqIDgpXQot CXN0cgl4NSwgW3gzLCAjKDAgKiA4KV0KLQotCWFkZAl4MywgeDIsICNDUFVfU1lTUkVHX09GRlNF VChEQkdXVlIwX0VMMSkKLQotCWFkcgl4MjYsIDFmCi0JYWRkCXgyNiwgeDI2LCB4MjUsIGxzbCAj MgotCWJyCXgyNgorCW1ycwl4MjEsIFx0eXBlXCgpMTVfZWwxCisJbXJzCXgyMCwgXHR5cGVcKCkx NF9lbDEKKwltcnMJeDE5LCBcdHlwZVwoKTEzX2VsMQorCW1ycwl4MTgsIFx0eXBlXCgpMTJfZWwx CisJbXJzCXgxNywgXHR5cGVcKCkxMV9lbDEKKwltcnMJeDE2LCBcdHlwZVwoKTEwX2VsMQorCW1y cwl4MTUsIFx0eXBlXCgpOV9lbDEKKwltcnMJeDE0LCBcdHlwZVwoKThfZWwxCisJbXJzCXgxMywg XHR5cGVcKCk3X2VsMQorCW1ycwl4MTIsIFx0eXBlXCgpNl9lbDEKKwltcnMJeDExLCBcdHlwZVwo KTVfZWwxCisJbXJzCXgxMCwgXHR5cGVcKCk0X2VsMQorCW1ycwl4OSwgXHR5cGVcKCkzX2VsMQor CW1ycwl4OCwgXHR5cGVcKCkyX2VsMQorCW1ycwl4NywgXHR5cGVcKCkxX2VsMQorCW1ycwl4Niwg XHR5cGVcKCkwX2VsMQorCisJYWRyCXgyMiwgMWYKKwlhZGQJeDIyLCB4MjIsIHg1LCBsc2wgIzIK Kwlicgl4MjIKIDE6Ci0JbXJzCXgyMCwgZGJnd3ZyMTVfZWwxCi0JbXJzCXgxOSwgZGJnd3ZyMTRf ZWwxCi0JbXJzCXgxOCwgZGJnd3ZyMTNfZWwxCi0JbXJzCXgxNywgZGJnd3ZyMTJfZWwxCi0JbXJz CXgxNiwgZGJnd3ZyMTFfZWwxCi0JbXJzCXgxNSwgZGJnd3ZyMTBfZWwxCi0JbXJzCXgxNCwgZGJn d3ZyOV9lbDEKLQltcnMJeDEzLCBkYmd3dnI4X2VsMQotCW1ycwl4MTIsIGRiZ3d2cjdfZWwxCi0J bXJzCXgxMSwgZGJnd3ZyNl9lbDEKLQltcnMJeDEwLCBkYmd3dnI1X2VsMQotCW1ycwl4OSwgZGJn d3ZyNF9lbDEKLQltcnMJeDgsIGRiZ3d2cjNfZWwxCi0JbXJzCXg3LCBkYmd3dnIyX2VsMQotCW1y cwl4NiwgZGJnd3ZyMV9lbDEKLQltcnMJeDUsIGRiZ3d2cjBfZWwxCi0KLQlhZHIJeDI2LCAxZgot CWFkZAl4MjYsIHgyNiwgeDI1LCBsc2wgIzIKLQlicgl4MjYKLQotMToKLQlzdHIJeDIwLCBbeDMs ICMoMTUgKiA4KV0KLQlzdHIJeDE5LCBbeDMsICMoMTQgKiA4KV0KLQlzdHIJeDE4LCBbeDMsICMo MTMgKiA4KV0KLQlzdHIJeDE3LCBbeDMsICMoMTIgKiA4KV0KLQlzdHIJeDE2LCBbeDMsICMoMTEg KiA4KV0KLQlzdHIJeDE1LCBbeDMsICMoMTAgKiA4KV0KLQlzdHIJeDE0LCBbeDMsICMoOSAqIDgp XQotCXN0cgl4MTMsIFt4MywgIyg4ICogOCldCi0Jc3RyCXgxMiwgW3gzLCAjKDcgKiA4KV0KLQlz dHIJeDExLCBbeDMsICMoNiAqIDgpXQotCXN0cgl4MTAsIFt4MywgIyg1ICogOCldCi0Jc3RyCXg5 LCBbeDMsICMoNCAqIDgpXQotCXN0cgl4OCwgW3gzLCAjKDMgKiA4KV0KLQlzdHIJeDcsIFt4Mywg IygyICogOCldCi0Jc3RyCXg2LCBbeDMsICMoMSAqIDgpXQotCXN0cgl4NSwgW3gzLCAjKDAgKiA4 KV0KLQotCW1ycwl4MjEsIG1kY2NpbnRfZWwxCi0Jc3RyCXgyMSwgW3gyLCAjQ1BVX1NZU1JFR19P RkZTRVQoTURDQ0lOVF9FTDEpXQorCXN0cgl4MjEsIFt4NCwgIygxNSAqIDgpXQorCXN0cgl4MjAs IFt4NCwgIygxNCAqIDgpXQorCXN0cgl4MTksIFt4NCwgIygxMyAqIDgpXQorCXN0cgl4MTgsIFt4 NCwgIygxMiAqIDgpXQorCXN0cgl4MTcsIFt4NCwgIygxMSAqIDgpXQorCXN0cgl4MTYsIFt4NCwg IygxMCAqIDgpXQorCXN0cgl4MTUsIFt4NCwgIyg5ICogOCldCisJc3RyCXgxNCwgW3g0LCAjKDgg KiA4KV0KKwlzdHIJeDEzLCBbeDQsICMoNyAqIDgpXQorCXN0cgl4MTIsIFt4NCwgIyg2ICogOCld CisJc3RyCXgxMSwgW3g0LCAjKDUgKiA4KV0KKwlzdHIJeDEwLCBbeDQsICMoNCAqIDgpXQorCXN0 cgl4OSwgW3g0LCAjKDMgKiA4KV0KKwlzdHIJeDgsIFt4NCwgIygyICogOCldCisJc3RyCXg3LCBb eDQsICMoMSAqIDgpXQorCXN0cgl4NiwgW3g0LCAjKDAgKiA4KV0KIC5lbmRtCiAKIC5tYWNybyBy ZXN0b3JlX3N5c3JlZ3MKQEAgLTQ2NSwxOTUgKzMxOCw1MiBAQAogCW1zcgltZHNjcl9lbDEsCXgy NQogLmVuZG0KIAotLm1hY3JvIHJlc3RvcmVfZGVidWcKLQkvLyB4MjogYmFzZSBhZGRyZXNzIGZv ciBjcHUgY29udGV4dAotCS8vIHgzOiB0bXAgcmVnaXN0ZXIKLQotCW1ycwl4MjYsIGlkX2FhNjRk ZnIwX2VsMQotCXViZngJeDI0LCB4MjYsICMxMiwgIzQJLy8gRXh0cmFjdCBCUlBzCi0JdWJmeAl4 MjUsIHgyNiwgIzIwLCAjNAkvLyBFeHRyYWN0IFdSUHMKLQltb3YJdzI2LCAjMTUKLQlzdWIJdzI0 LCB3MjYsIHcyNAkJLy8gSG93IG1hbnkgQlBzIHRvIHNraXAKLQlzdWIJdzI1LCB3MjYsIHcyNQkJ Ly8gSG93IG1hbnkgV1BzIHRvIHNraXAKLQotCWFkZAl4MywgeDIsICNDUFVfU1lTUkVHX09GRlNF VChEQkdCQ1IwX0VMMSkKKy5tYWNybyByZXN0b3JlX2RlYnVnIHR5cGUKKyAgICAgICAgLy8geDQ6 IHBvaW50ZXIgdG8gcmVnaXN0ZXIgc2V0CisgICAgICAgIC8vIHg1OiBudW1iZXIgb2YgcmVnaXN0 ZXJzIHRvIHNraXAKKwkvLyB4Ni4ueDIyIHRyYXNoZWQKIAotCWFkcgl4MjYsIDFmCi0JYWRkCXgy NiwgeDI2LCB4MjQsIGxzbCAjMgotCWJyCXgyNgorCWFkcgl4MjIsIDFmCisJYWRkCXgyMiwgeDIy LCB4NSwgbHNsICMyCisJYnIJeDIyCiAxOgotCWxkcgl4MjAsIFt4MywgIygxNSAqIDgpXQotCWxk cgl4MTksIFt4MywgIygxNCAqIDgpXQotCWxkcgl4MTgsIFt4MywgIygxMyAqIDgpXQotCWxkcgl4 MTcsIFt4MywgIygxMiAqIDgpXQotCWxkcgl4MTYsIFt4MywgIygxMSAqIDgpXQotCWxkcgl4MTUs IFt4MywgIygxMCAqIDgpXQotCWxkcgl4MTQsIFt4MywgIyg5ICogOCldCi0JbGRyCXgxMywgW3gz LCAjKDggKiA4KV0KLQlsZHIJeDEyLCBbeDMsICMoNyAqIDgpXQotCWxkcgl4MTEsIFt4MywgIyg2 ICogOCldCi0JbGRyCXgxMCwgW3gzLCAjKDUgKiA4KV0KLQlsZHIJeDksIFt4MywgIyg0ICogOCld Ci0JbGRyCXg4LCBbeDMsICMoMyAqIDgpXQotCWxkcgl4NywgW3gzLCAjKDIgKiA4KV0KLQlsZHIJ eDYsIFt4MywgIygxICogOCldCi0JbGRyCXg1LCBbeDMsICMoMCAqIDgpXQotCi0JYWRyCXgyNiwg MWYKLQlhZGQJeDI2LCB4MjYsIHgyNCwgbHNsICMyCi0JYnIJeDI2CisJbGRyCXgyMSwgW3g0LCAj KDE1ICogOCldCisJbGRyCXgyMCwgW3g0LCAjKDE0ICogOCldCisJbGRyCXgxOSwgW3g0LCAjKDEz ICogOCldCisJbGRyCXgxOCwgW3g0LCAjKDEyICogOCldCisJbGRyCXgxNywgW3g0LCAjKDExICog OCldCisJbGRyCXgxNiwgW3g0LCAjKDEwICogOCldCisJbGRyCXgxNSwgW3g0LCAjKDkgKiA4KV0K KwlsZHIJeDE0LCBbeDQsICMoOCAqIDgpXQorCWxkcgl4MTMsIFt4NCwgIyg3ICogOCldCisJbGRy CXgxMiwgW3g0LCAjKDYgKiA4KV0KKwlsZHIJeDExLCBbeDQsICMoNSAqIDgpXQorCWxkcgl4MTAs IFt4NCwgIyg0ICogOCldCisJbGRyCXg5LCBbeDQsICMoMyAqIDgpXQorCWxkcgl4OCwgW3g0LCAj KDIgKiA4KV0KKwlsZHIJeDcsIFt4NCwgIygxICogOCldCisJbGRyCXg2LCBbeDQsICMoMCAqIDgp XQorCisJYWRyCXgyMiwgMWYKKwlhZGQJeDIyLCB4MjIsIHg1LCBsc2wgIzIKKwlicgl4MjIKIDE6 Ci0JbXNyCWRiZ2JjcjE1X2VsMSwgeDIwCi0JbXNyCWRiZ2JjcjE0X2VsMSwgeDE5Ci0JbXNyCWRi Z2JjcjEzX2VsMSwgeDE4Ci0JbXNyCWRiZ2JjcjEyX2VsMSwgeDE3Ci0JbXNyCWRiZ2JjcjExX2Vs MSwgeDE2Ci0JbXNyCWRiZ2JjcjEwX2VsMSwgeDE1Ci0JbXNyCWRiZ2JjcjlfZWwxLCB4MTQKLQlt c3IJZGJnYmNyOF9lbDEsIHgxMwotCW1zcglkYmdiY3I3X2VsMSwgeDEyCi0JbXNyCWRiZ2JjcjZf ZWwxLCB4MTEKLQltc3IJZGJnYmNyNV9lbDEsIHgxMAotCW1zcglkYmdiY3I0X2VsMSwgeDkKLQlt c3IJZGJnYmNyM19lbDEsIHg4Ci0JbXNyCWRiZ2JjcjJfZWwxLCB4NwotCW1zcglkYmdiY3IxX2Vs MSwgeDYKLQltc3IJZGJnYmNyMF9lbDEsIHg1Ci0KLQlhZGQJeDMsIHgyLCAjQ1BVX1NZU1JFR19P RkZTRVQoREJHQlZSMF9FTDEpCi0KLQlhZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI0LCBs c2wgIzIKLQlicgl4MjYKLTE6Ci0JbGRyCXgyMCwgW3gzLCAjKDE1ICogOCldCi0JbGRyCXgxOSwg W3gzLCAjKDE0ICogOCldCi0JbGRyCXgxOCwgW3gzLCAjKDEzICogOCldCi0JbGRyCXgxNywgW3gz LCAjKDEyICogOCldCi0JbGRyCXgxNiwgW3gzLCAjKDExICogOCldCi0JbGRyCXgxNSwgW3gzLCAj KDEwICogOCldCi0JbGRyCXgxNCwgW3gzLCAjKDkgKiA4KV0KLQlsZHIJeDEzLCBbeDMsICMoOCAq IDgpXQotCWxkcgl4MTIsIFt4MywgIyg3ICogOCldCi0JbGRyCXgxMSwgW3gzLCAjKDYgKiA4KV0K LQlsZHIJeDEwLCBbeDMsICMoNSAqIDgpXQotCWxkcgl4OSwgW3gzLCAjKDQgKiA4KV0KLQlsZHIJ eDgsIFt4MywgIygzICogOCldCi0JbGRyCXg3LCBbeDMsICMoMiAqIDgpXQotCWxkcgl4NiwgW3gz LCAjKDEgKiA4KV0KLQlsZHIJeDUsIFt4MywgIygwICogOCldCi0KLQlhZHIJeDI2LCAxZgotCWFk ZAl4MjYsIHgyNiwgeDI0LCBsc2wgIzIKLQlicgl4MjYKLTE6Ci0JbXNyCWRiZ2J2cjE1X2VsMSwg eDIwCi0JbXNyCWRiZ2J2cjE0X2VsMSwgeDE5Ci0JbXNyCWRiZ2J2cjEzX2VsMSwgeDE4Ci0JbXNy CWRiZ2J2cjEyX2VsMSwgeDE3Ci0JbXNyCWRiZ2J2cjExX2VsMSwgeDE2Ci0JbXNyCWRiZ2J2cjEw X2VsMSwgeDE1Ci0JbXNyCWRiZ2J2cjlfZWwxLCB4MTQKLQltc3IJZGJnYnZyOF9lbDEsIHgxMwot CW1zcglkYmdidnI3X2VsMSwgeDEyCi0JbXNyCWRiZ2J2cjZfZWwxLCB4MTEKLQltc3IJZGJnYnZy NV9lbDEsIHgxMAotCW1zcglkYmdidnI0X2VsMSwgeDkKLQltc3IJZGJnYnZyM19lbDEsIHg4Ci0J bXNyCWRiZ2J2cjJfZWwxLCB4NwotCW1zcglkYmdidnIxX2VsMSwgeDYKLQltc3IJZGJnYnZyMF9l bDEsIHg1Ci0KLQlhZGQJeDMsIHgyLCAjQ1BVX1NZU1JFR19PRkZTRVQoREJHV0NSMF9FTDEpCi0K LQlhZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI1LCBsc2wgIzIKLQlicgl4MjYKLTE6Ci0J bGRyCXgyMCwgW3gzLCAjKDE1ICogOCldCi0JbGRyCXgxOSwgW3gzLCAjKDE0ICogOCldCi0JbGRy CXgxOCwgW3gzLCAjKDEzICogOCldCi0JbGRyCXgxNywgW3gzLCAjKDEyICogOCldCi0JbGRyCXgx NiwgW3gzLCAjKDExICogOCldCi0JbGRyCXgxNSwgW3gzLCAjKDEwICogOCldCi0JbGRyCXgxNCwg W3gzLCAjKDkgKiA4KV0KLQlsZHIJeDEzLCBbeDMsICMoOCAqIDgpXQotCWxkcgl4MTIsIFt4Mywg Iyg3ICogOCldCi0JbGRyCXgxMSwgW3gzLCAjKDYgKiA4KV0KLQlsZHIJeDEwLCBbeDMsICMoNSAq IDgpXQotCWxkcgl4OSwgW3gzLCAjKDQgKiA4KV0KLQlsZHIJeDgsIFt4MywgIygzICogOCldCi0J bGRyCXg3LCBbeDMsICMoMiAqIDgpXQotCWxkcgl4NiwgW3gzLCAjKDEgKiA4KV0KLQlsZHIJeDUs IFt4MywgIygwICogOCldCi0KLQlhZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI1LCBsc2wg IzIKLQlicgl4MjYKLTE6Ci0JbXNyCWRiZ3djcjE1X2VsMSwgeDIwCi0JbXNyCWRiZ3djcjE0X2Vs MSwgeDE5Ci0JbXNyCWRiZ3djcjEzX2VsMSwgeDE4Ci0JbXNyCWRiZ3djcjEyX2VsMSwgeDE3Ci0J bXNyCWRiZ3djcjExX2VsMSwgeDE2Ci0JbXNyCWRiZ3djcjEwX2VsMSwgeDE1Ci0JbXNyCWRiZ3dj cjlfZWwxLCB4MTQKLQltc3IJZGJnd2NyOF9lbDEsIHgxMwotCW1zcglkYmd3Y3I3X2VsMSwgeDEy Ci0JbXNyCWRiZ3djcjZfZWwxLCB4MTEKLQltc3IJZGJnd2NyNV9lbDEsIHgxMAotCW1zcglkYmd3 Y3I0X2VsMSwgeDkKLQltc3IJZGJnd2NyM19lbDEsIHg4Ci0JbXNyCWRiZ3djcjJfZWwxLCB4Nwot CW1zcglkYmd3Y3IxX2VsMSwgeDYKLQltc3IJZGJnd2NyMF9lbDEsIHg1Ci0KLQlhZGQJeDMsIHgy LCAjQ1BVX1NZU1JFR19PRkZTRVQoREJHV1ZSMF9FTDEpCi0KLQlhZHIJeDI2LCAxZgotCWFkZAl4 MjYsIHgyNiwgeDI1LCBsc2wgIzIKLQlicgl4MjYKLTE6Ci0JbGRyCXgyMCwgW3gzLCAjKDE1ICog OCldCi0JbGRyCXgxOSwgW3gzLCAjKDE0ICogOCldCi0JbGRyCXgxOCwgW3gzLCAjKDEzICogOCld Ci0JbGRyCXgxNywgW3gzLCAjKDEyICogOCldCi0JbGRyCXgxNiwgW3gzLCAjKDExICogOCldCi0J bGRyCXgxNSwgW3gzLCAjKDEwICogOCldCi0JbGRyCXgxNCwgW3gzLCAjKDkgKiA4KV0KLQlsZHIJ eDEzLCBbeDMsICMoOCAqIDgpXQotCWxkcgl4MTIsIFt4MywgIyg3ICogOCldCi0JbGRyCXgxMSwg W3gzLCAjKDYgKiA4KV0KLQlsZHIJeDEwLCBbeDMsICMoNSAqIDgpXQotCWxkcgl4OSwgW3gzLCAj KDQgKiA4KV0KLQlsZHIJeDgsIFt4MywgIygzICogOCldCi0JbGRyCXg3LCBbeDMsICMoMiAqIDgp XQotCWxkcgl4NiwgW3gzLCAjKDEgKiA4KV0KLQlsZHIJeDUsIFt4MywgIygwICogOCldCi0KLQlh ZHIJeDI2LCAxZgotCWFkZAl4MjYsIHgyNiwgeDI1LCBsc2wgIzIKLQlicgl4MjYKLTE6Ci0JbXNy CWRiZ3d2cjE1X2VsMSwgeDIwCi0JbXNyCWRiZ3d2cjE0X2VsMSwgeDE5Ci0JbXNyCWRiZ3d2cjEz X2VsMSwgeDE4Ci0JbXNyCWRiZ3d2cjEyX2VsMSwgeDE3Ci0JbXNyCWRiZ3d2cjExX2VsMSwgeDE2 Ci0JbXNyCWRiZ3d2cjEwX2VsMSwgeDE1Ci0JbXNyCWRiZ3d2cjlfZWwxLCB4MTQKLQltc3IJZGJn d3ZyOF9lbDEsIHgxMwotCW1zcglkYmd3dnI3X2VsMSwgeDEyCi0JbXNyCWRiZ3d2cjZfZWwxLCB4 MTEKLQltc3IJZGJnd3ZyNV9lbDEsIHgxMAotCW1zcglkYmd3dnI0X2VsMSwgeDkKLQltc3IJZGJn d3ZyM19lbDEsIHg4Ci0JbXNyCWRiZ3d2cjJfZWwxLCB4NwotCW1zcglkYmd3dnIxX2VsMSwgeDYK LQltc3IJZGJnd3ZyMF9lbDEsIHg1Ci0KLQlsZHIJeDIxLCBbeDIsICNDUFVfU1lTUkVHX09GRlNF VChNRENDSU5UX0VMMSldCi0JbXNyCW1kY2NpbnRfZWwxLCB4MjEKKwltc3IJXHR5cGVcKCkxNV9l bDEsIHgyMQorCW1zcglcdHlwZVwoKTE0X2VsMSwgeDIwCisJbXNyCVx0eXBlXCgpMTNfZWwxLCB4 MTkKKwltc3IJXHR5cGVcKCkxMl9lbDEsIHgxOAorCW1zcglcdHlwZVwoKTExX2VsMSwgeDE3CisJ bXNyCVx0eXBlXCgpMTBfZWwxLCB4MTYKKwltc3IJXHR5cGVcKCk5X2VsMSwgeDE1CisJbXNyCVx0 eXBlXCgpOF9lbDEsIHgxNAorCW1zcglcdHlwZVwoKTdfZWwxLCB4MTMKKwltc3IJXHR5cGVcKCk2 X2VsMSwgeDEyCisJbXNyCVx0eXBlXCgpNV9lbDEsIHgxMQorCW1zcglcdHlwZVwoKTRfZWwxLCB4 MTAKKwltc3IJXHR5cGVcKCkzX2VsMSwgeDkKKwltc3IJXHR5cGVcKCkyX2VsMSwgeDgKKwltc3IJ XHR5cGVcKCkxX2VsMSwgeDcKKwltc3IJXHR5cGVcKCkwX2VsMSwgeDYKIC5lbmRtCiAKIC5tYWNy byBza2lwXzMyYml0X3N0YXRlIHRtcCwgdGFyZ2V0CkBAIC04ODcsMTIgKzU5Nyw2MyBAQCBfX3Jl c3RvcmVfc3lzcmVnczoKIAlyZXN0b3JlX3N5c3JlZ3MKIAlyZXQKIAorLyogU2F2ZSBkZWJ1ZyBz dGF0ZSAqLwogX19zYXZlX2RlYnVnOgotCXNhdmVfZGVidWcKKwkvLyB4MDogYmFzZSBhZGRyZXNz IGZvciB2Y3B1IGNvbnRleHQKKwkvLyB4MjogcHRyIHRvIGN1cnJlbnQgQ1BVIGNvbnRleHQKKwkv LyB4NC94NTogdHJhc2hlZAorCisJbXJzCXgyNiwgaWRfYWE2NGRmcjBfZWwxCisJdWJmeAl4MjQs IHgyNiwgIzEyLCAjNAkvLyBFeHRyYWN0IEJSUHMKKwl1YmZ4CXgyNSwgeDI2LCAjMjAsICM0CS8v IEV4dHJhY3QgV1JQcworCW1vdgl3MjYsICMxNQorCXN1Ygl3MjQsIHcyNiwgdzI0CQkvLyBIb3cg bWFueSBCUHMgdG8gc2tpcAorCXN1Ygl3MjUsIHcyNiwgdzI1CQkvLyBIb3cgbWFueSBXUHMgdG8g c2tpcAorCisJbW92ICAgICB4NSwgeDI0CisJYWRkCXg0LCB4MiwgI0NQVV9TWVNSRUdfT0ZGU0VU KERCR0JDUjBfRUwxKQorCXNhdmVfZGVidWcgZGJnYmNyCisJYWRkCXg0LCB4MiwgI0NQVV9TWVNS RUdfT0ZGU0VUKERCR0JWUjBfRUwxKQorCXNhdmVfZGVidWcgZGJnYnZyCisKKwltb3YgICAgIHg1 LCB4MjUKKwlhZGQJeDQsIHgyLCAjQ1BVX1NZU1JFR19PRkZTRVQoREJHV0NSMF9FTDEpCisJc2F2 ZV9kZWJ1ZyBkYmd3Y3IKKwlhZGQJeDQsIHgyLCAjQ1BVX1NZU1JFR19PRkZTRVQoREJHV1ZSMF9F TDEpCisJc2F2ZV9kZWJ1ZyBkYmd3dnIKKworCW1ycwl4MjEsIG1kY2NpbnRfZWwxCisJc3RyCXgy MSwgW3gyLCAjQ1BVX1NZU1JFR19PRkZTRVQoTURDQ0lOVF9FTDEpXQogCXJldAogCisvKiBSZXN0 b3JlIGRlYnVnIHN0YXRlICovCiBfX3Jlc3RvcmVfZGVidWc6Ci0JcmVzdG9yZV9kZWJ1ZworCS8v IHgwOiBiYXNlIGFkZHJlc3MgZm9yIGNwdSBjb250ZXh0CisJLy8geDI6IHB0ciB0byBjdXJyZW50 IENQVSBjb250ZXh0CisJLy8geDQveDU6IHRyYXNoZWQKKworCW1ycwl4MjYsIGlkX2FhNjRkZnIw X2VsMQorCXViZngJeDI0LCB4MjYsICMxMiwgIzQJLy8gRXh0cmFjdCBCUlBzCisJdWJmeAl4MjUs IHgyNiwgIzIwLCAjNAkvLyBFeHRyYWN0IFdSUHMKKwltb3YJdzI2LCAjMTUKKwlzdWIJdzI0LCB3 MjYsIHcyNAkJLy8gSG93IG1hbnkgQlBzIHRvIHNraXAKKwlzdWIJdzI1LCB3MjYsIHcyNQkJLy8g SG93IG1hbnkgV1BzIHRvIHNraXAKKworCW1vdiAgICAgeDUsIHgyNAorCWFkZAl4NCwgeDIsICND UFVfU1lTUkVHX09GRlNFVChEQkdCQ1IwX0VMMSkKKwlyZXN0b3JlX2RlYnVnIGRiZ2JjcgorCWFk ZAl4NCwgeDIsICNDUFVfU1lTUkVHX09GRlNFVChEQkdCVlIwX0VMMSkKKwlyZXN0b3JlX2RlYnVn IGRiZ2J2cgorCisJbW92ICAgICB4NSwgeDI1CisJYWRkCXg0LCB4MiwgI0NQVV9TWVNSRUdfT0ZG U0VUKERCR1dDUjBfRUwxKQorCXJlc3RvcmVfZGVidWcgZGJnd2NyCisJYWRkCXg0LCB4MiwgI0NQ VV9TWVNSRUdfT0ZGU0VUKERCR1dWUjBfRUwxKQorCXJlc3RvcmVfZGVidWcgZGJnd3ZyCisKKwls ZHIJeDIxLCBbeDIsICNDUFVfU1lTUkVHX09GRlNFVChNRENDSU5UX0VMMSldCisJbXNyCW1kY2Np bnRfZWwxLCB4MjEKKwogCXJldAogCiBfX3NhdmVfZnBzaW1kOgotLSAKMi40LjEKCl9fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmt2bWFybSBtYWlsaW5nIGxp c3QKa3ZtYXJtQGxpc3RzLmNzLmNvbHVtYmlhLmVkdQpodHRwczovL2xpc3RzLmNzLmNvbHVtYmlh LmVkdS9tYWlsbWFuL2xpc3RpbmZvL2t2bWFybQo=