LyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgIHJwbmcgLSBzaW1wbGUgUE5HIGRpc3BsYXkgcHJvZ3JhbSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBycG5nLXguYwoKICAgVGhpcyBwcm9ncmFtIGRlY29kZXMgYW5kIGRpc3BsYXlzIFBORyBpbWFnZXMsIHdpdGggZ2FtbWEgY29ycmVjdGlvbiBhbmQKICAgb3B0aW9uYWxseSB3aXRoIGEgdXNlci1zcGVjaWZpZWQgYmFja2dyb3VuZCBjb2xvciAoaW4gY2FzZSB0aGUgaW1hZ2UgaGFzCiAgIHRyYW5zcGFyZW5jeSkuICBJdCBpcyB2ZXJ5IG5lYXJseSB0aGUgbW9zdCBiYXNpYyBQTkcgdmlld2VyIHBvc3NpYmxlLgogICBUaGlzIHZlcnNpb24gaXMgZm9yIHRoZSBYIFdpbmRvdyBTeXN0ZW0gKHRlc3RlZCBieSBhdXRob3IgdW5kZXIgVW5peCBhbmQKICAgYnkgTWFydGluIFppbnNlciB1bmRlciBPcGVuVk1TOyBtYXkgd29yayB1bmRlciBPUy8yIHdpdGggc29tZSB0d2Vha2luZykuCgogICB0byBkbzoKICAgIC0gOC1iaXQgKGNvbG9ybWFwcGVkKSBYIHN1cHBvcnQKICAgIC0gdXNlICUuMTAyM3MgdG8gc2ltcGxpZnkgdHJ1bmNhdGlvbiBvZiB0aXRsZS1iYXIgc3RyaW5nPwoKICAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgIENoYW5nZWxvZzoKICAgIC0gMS4wMTogIGluaXRpYWwgcHVibGljIHJlbGVhc2UKICAgIC0gMS4wMjogIG1vZGlmaWVkIHRvIGFsbG93IGFiYnJldmlhdGVkIG9wdGlvbnM7IGZpeGVkIGxvbmcvdWxvbmcgbWlzLQogICAgICAgICAgICAgIG1hdGNoOyBzd2l0Y2hlZCB0byBwbmdfam1wYnVmKCkgbWFjcm8KICAgIC0gMS4xMDogIGFkZGVkIHN1cHBvcnQgZm9yIG5vbi1kZWZhdWx0IHZpc3VhbHM7IGZpeGVkIFggcGl4ZWwtY29udmVyc2lvbgogICAgLSAxLjExOiAgYWRkZWQgZXh0cmEgc2V0IG9mIHBhcmVudGhlc2VzIHRvIHBuZ19qbXBidWYoKSBtYWNybzsgZml4ZWQKICAgICAgICAgICAgICBjb21tYW5kLWxpbmUgcGFyc2luZyBidWcKICAgIC0gMS4xMjogIGZpeGVkIHNvbWUgc21hbGwgWCBtZW1vcnkgbGVha3MgKHRoYW5rcyB0byBGcmFu529pcyBQZXRpdGplYW4pCiAgICAtIDEuMTM6ICBmaXhlZCBYRnJlZUdDKCkgY3Jhc2ggYnVnICh0aGFua3MgdG8gUGF0cmljayBXZWxjaGUpCiAgICAtIDEuMTQ6ICBhZGRlZCBzdXBwb3J0IGZvciBYIHJlc291cmNlcyAodGhhbmtzIHRvIEdlcmhhcmQgTmlrbGFzY2gpCiAgICAtIDIuMDA6ICBkdWFsLWxpY2Vuc2VkIChhZGRlZCBHTlUgR1BMKQoKICAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgICAgIENvcHlyaWdodCAoYykgMTk5OC0yMDA3IEdyZWcgUm9lbG9mcy4gIEFsbCByaWdodHMgcmVzZXJ2ZWQuCgogICAgICBUaGlzIHNvZnR3YXJlIGlzIHByb3ZpZGVkICJhcyBpcywiIHdpdGhvdXQgd2FycmFudHkgb2YgYW55IGtpbmQsCiAgICAgIGV4cHJlc3Mgb3IgaW1wbGllZC4gIEluIG5vIGV2ZW50IHNoYWxsIHRoZSBhdXRob3Igb3IgY29udHJpYnV0b3JzCiAgICAgIGJlIGhlbGQgbGlhYmxlIGZvciBhbnkgZGFtYWdlcyBhcmlzaW5nIGluIGFueSB3YXkgZnJvbSB0aGUgdXNlIG9mCiAgICAgIHRoaXMgc29mdHdhcmUuCgogICAgICBUaGUgY29udGVudHMgb2YgdGhpcyBmaWxlIGFyZSBEVUFMLUxJQ0VOU0VELiAgWW91IG1heSBtb2RpZnkgYW5kL29yCiAgICAgIHJlZGlzdHJpYnV0ZSB0aGlzIHNvZnR3YXJlIGFjY29yZGluZyB0byB0aGUgdGVybXMgb2Ygb25lIG9mIHRoZQogICAgICBmb2xsb3dpbmcgdHdvIGxpY2Vuc2VzIChhdCB5b3VyIG9wdGlvbik6CgoKICAgICAgTElDRU5TRSAxICgiQlNELWxpa2Ugd2l0aCBhZHZlcnRpc2luZyBjbGF1c2UiKToKCiAgICAgIFBlcm1pc3Npb24gaXMgZ3JhbnRlZCB0byBhbnlvbmUgdG8gdXNlIHRoaXMgc29mdHdhcmUgZm9yIGFueSBwdXJwb3NlLAogICAgICBpbmNsdWRpbmcgY29tbWVyY2lhbCBhcHBsaWNhdGlvbnMsIGFuZCB0byBhbHRlciBpdCBhbmQgcmVkaXN0cmlidXRlCiAgICAgIGl0IGZyZWVseSwgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIHJlc3RyaWN0aW9uczoKCiAgICAgIDEuIFJlZGlzdHJpYnV0aW9ucyBvZiBzb3VyY2UgY29kZSBtdXN0IHJldGFpbiB0aGUgYWJvdmUgY29weXJpZ2h0CiAgICAgICAgIG5vdGljZSwgZGlzY2xhaW1lciwgYW5kIHRoaXMgbGlzdCBvZiBjb25kaXRpb25zLgogICAgICAyLiBSZWRpc3RyaWJ1dGlvbnMgaW4gYmluYXJ5IGZvcm0gbXVzdCByZXByb2R1Y2UgdGhlIGFib3ZlIGNvcHlyaWdodAogICAgICAgICBub3RpY2UsIGRpc2NsYWltZXIsIGFuZCB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBpbiB0aGUgZG9jdW1lbnRhLQogICAgICAgICB0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMgcHJvdmlkZWQgd2l0aCB0aGUgZGlzdHJpYnV0aW9uLgogICAgICAzLiBBbGwgYWR2ZXJ0aXNpbmcgbWF0ZXJpYWxzIG1lbnRpb25pbmcgZmVhdHVyZXMgb3IgdXNlIG9mIHRoaXMKICAgICAgICAgc29mdHdhcmUgbXVzdCBkaXNwbGF5IHRoZSBmb2xsb3dpbmcgYWNrbm93bGVkZ21lbnQ6CgogICAgICAgICAgICBUaGlzIHByb2R1Y3QgaW5jbHVkZXMgc29mdHdhcmUgZGV2ZWxvcGVkIGJ5IEdyZWcgUm9lbG9mcwogICAgICAgICAgICBhbmQgY29udHJpYnV0b3JzIGZvciB0aGUgYm9vaywgIlBORzogVGhlIERlZmluaXRpdmUgR3VpZGUsIgogICAgICAgICAgICBwdWJsaXNoZWQgYnkgTydSZWlsbHkgYW5kIEFzc29jaWF0ZXMuCgoKICAgICAgTElDRU5TRSAyIChHTlUgR1BMIHYyIG9yIGxhdGVyKToKCiAgICAgIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5CiAgICAgIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5CiAgICAgIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YgdGhlIExpY2Vuc2UsIG9yCiAgICAgIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCgogICAgICBUaGlzIHByb2dyYW0gaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICAgICAgYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICAgICAgTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZQogICAgICBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLgoKICAgICAgWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UKICAgICAgYWxvbmcgd2l0aCB0aGlzIHByb2dyYW07IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbiwKICAgICAgSW5jLiwgNTkgVGVtcGxlIFBsYWNlLCBTdWl0ZSAzMzAsIEJvc3RvbiwgTUEgIDAyMTExLTEzMDcgIFVTQQoKICAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwoKI2RlZmluZSBQUk9HTkFNRSAgInJwbmcteCIKI2RlZmluZSBMT05HTkFNRSAgIlNpbXBsZSBQTkcgVmlld2VyIGZvciBYIgojZGVmaW5lIFZFUlNJT04gICAiMi4wMCBvZiAyIEp1bmUgMjAwNyIKI2RlZmluZSBSRVNOQU1FICAgInJwbmciCS8qIG91ciBYIHJlc291cmNlIGFwcGxpY2F0aW9uIG5hbWUgKi8KI2RlZmluZSBSRVNDTEFTUyAgIlJwbmciCS8qIG91ciBYIHJlc291cmNlIGNsYXNzIG5hbWUgKi8KCiNpbmNsdWRlIDxzdGRpby5oPgojaW5jbHVkZSA8c3RkbGliLmg+CiNpbmNsdWRlIDxzdHJpbmcuaD4KI2luY2x1ZGUgPHRpbWUuaD4KI2luY2x1ZGUgPFgxMS9YbGliLmg+CiNpbmNsdWRlIDxYMTEvWHV0aWwuaD4KI2luY2x1ZGUgPFgxMS9Yb3MuaD4KI2luY2x1ZGUgPFgxMS9rZXlzeW0uaD4KCi8qICNkZWZpbmUgREVCVUcgIDogIHRoaXMgZW5hYmxlcyB0aGUgVHJhY2UoKSBtYWNyb3MgKi8KCiNpbmNsdWRlICJyZWFkcG5nLmgiICAgLyogdHlwZWRlZnMsIGNvbW1vbiBtYWNyb3MsIHJlYWRwbmcgcHJvdG90eXBlcyAqLwoKCi8qIGNvdWxkIGp1c3QgaW5jbHVkZSBwbmcuaCwgYnV0IHRoaXMgbWFjcm8gaXMgdGhlIG9ubHkgdGhpbmcgd2UgbmVlZAogKiAobmFtZSBhbmQgdHlwZWRlZnMgY2hhbmdlZCB0byBsb2NhbCB2ZXJzaW9ucyk7IG5vdGUgdGhhdCBzaWRlIGVmZmVjdHMKICogb25seSBoYXBwZW4gd2l0aCBhbHBoYSAod2hpY2ggY291bGQgZWFzaWx5IGJlIGF2b2lkZWQgd2l0aAogKiAidXNoIGFjb3B5ID0gKGFscGhhKTsiKSAqLwoKI2RlZmluZSBhbHBoYV9jb21wb3NpdGUoY29tcG9zaXRlLCBmZywgYWxwaGEsIGJnKSB7ICAgICAgICAgICAgICAgXAogICAgdXNoIHRlbXAgPSAoKHVzaCkoZmcpKih1c2gpKGFscGhhKSArICAgICAgICAgICAgICAgICAgICAgICAgICBcCiAgICAgICAgICAgICAgICAodXNoKShiZykqKHVzaCkoMjU1IC0gKHVzaCkoYWxwaGEpKSArICh1c2gpMTI4KTsgIFwKICAgIChjb21wb3NpdGUpID0gKHVjaCkoKHRlbXAgKyAodGVtcCA+PiA4KSkgPj4gOCk7ICAgICAgICAgICAgICAgXAp9CgoKLyogbG9jYWwgcHJvdG90eXBlcyAqLwpzdGF0aWMgaW50ICBycG5nX3hfY3JlYXRlX3dpbmRvdyh2b2lkKTsKc3RhdGljIGludCAgcnBuZ194X2Rpc3BsYXlfaW1hZ2Uodm9pZCk7CnN0YXRpYyB2b2lkIHJwbmdfeF9jbGVhbnVwKHZvaWQpOwpzdGF0aWMgaW50ICBycG5nX3hfbXNiKHVsZyB1MzJ2YWwpOwoKCnN0YXRpYyBjaGFyIHRpdGxlYmFyWzEwMjRdLCAqd2luZG93X25hbWUgPSB0aXRsZWJhcjsKc3RhdGljIGNoYXIgKmFwcG5hbWUgPSBMT05HTkFNRTsKc3RhdGljIGNoYXIgKmljb25fbmFtZSA9IFBST0dOQU1FOwpzdGF0aWMgY2hhciAqcmVzX25hbWUgPSBSRVNOQU1FOwpzdGF0aWMgY2hhciAqcmVzX2NsYXNzID0gUkVTQ0xBU1M7CnN0YXRpYyBjaGFyICpmaWxlbmFtZTsKc3RhdGljIEZJTEUgKmluZmlsZTsKCnN0YXRpYyBjaGFyICpiZ3N0cjsKc3RhdGljIHVjaCBiZ19yZWQ9MCwgYmdfZ3JlZW49MCwgYmdfYmx1ZT0wOwoKc3RhdGljIGRvdWJsZSBkaXNwbGF5X2V4cG9uZW50OwoKc3RhdGljIHVsZyBpbWFnZV93aWR0aCwgaW1hZ2VfaGVpZ2h0LCBpbWFnZV9yb3dieXRlczsKc3RhdGljIGludCBpbWFnZV9jaGFubmVsczsKc3RhdGljIHVjaCAqaW1hZ2VfZGF0YTsKCi8qIFgtc3BlY2lmaWMgdmFyaWFibGVzICovCnN0YXRpYyBjaGFyICpkaXNwbGF5bmFtZTsKc3RhdGljIFhJbWFnZSAqeGltYWdlOwpzdGF0aWMgRGlzcGxheSAqZGlzcGxheTsKc3RhdGljIGludCBkZXB0aDsKc3RhdGljIFZpc3VhbCAqdmlzdWFsOwpzdGF0aWMgWFZpc3VhbEluZm8gKnZpc3VhbF9saXN0OwpzdGF0aWMgaW50IFJTaGlmdCwgR1NoaWZ0LCBCU2hpZnQ7CnN0YXRpYyB1bGcgUk1hc2ssIEdNYXNrLCBCTWFzazsKc3RhdGljIFdpbmRvdyB3aW5kb3c7CnN0YXRpYyBHQyBnYzsKc3RhdGljIENvbG9ybWFwIGNvbG9ybWFwOwoKc3RhdGljIGludCBoYXZlX25vbmRlZmF1bHRfdmlzdWFsID0gRkFMU0U7CnN0YXRpYyBpbnQgaGF2ZV9jb2xvcm1hcCA9IEZBTFNFOwpzdGF0aWMgaW50IGhhdmVfd2luZG93ID0gRkFMU0U7CnN0YXRpYyBpbnQgaGF2ZV9nYyA9IEZBTFNFOwovKgp1bGcgbnVtY29sb3JzPTAsIHBpeGVsc1syNTZdOwp1c2ggcmVkc1syNTZdLCBncmVlbnNbMjU2XSwgYmx1ZXNbMjU2XTsKICovCgoKCgppbnQgbWFpbihpbnQgYXJnYywgY2hhciAqKmFyZ3YpCnsKI2lmZGVmIHNnaQogICAgY2hhciB0bXBsaW5lWzgwXTsKI2VuZGlmCiAgICBjaGFyICpwOwogICAgaW50IHJjLCBhbGVuLCBmbGVuOwogICAgaW50IGVycm9yID0gMDsKICAgIGludCBoYXZlX2JnID0gRkFMU0U7CiAgICBkb3VibGUgTFVUX2V4cG9uZW50OyAgICAgICAgICAgICAgIC8qIGp1c3QgdGhlIGxvb2t1cCB0YWJsZSAqLwogICAgZG91YmxlIENSVF9leHBvbmVudCA9IDIuMjsgICAgICAgICAvKiBqdXN0IHRoZSBtb25pdG9yICovCiAgICBkb3VibGUgZGVmYXVsdF9kaXNwbGF5X2V4cG9uZW50OyAgIC8qIHdob2xlIGRpc3BsYXkgc3lzdGVtICovCiAgICBYRXZlbnQgZTsKICAgIEtleVN5bSBrOwoKCiAgICBkaXNwbGF5bmFtZSA9IChjaGFyICopTlVMTDsKICAgIGZpbGVuYW1lID0gKGNoYXIgKilOVUxMOwoKCiAgICAvKiBGaXJzdCBzZXQgdGhlIGRlZmF1bHQgdmFsdWUgZm9yIG91ciBkaXNwbGF5LXN5c3RlbSBleHBvbmVudCwgaS5lLiwKICAgICAqIHRoZSBwcm9kdWN0IG9mIHRoZSBDUlQgZXhwb25lbnQgYW5kIHRoZSBleHBvbmVudCBjb3JyZXNwb25kaW5nIHRvCiAgICAgKiB0aGUgZnJhbWUtYnVmZmVyJ3MgbG9va3VwIHRhYmxlIChMVVQpLCBpZiBhbnkuICBUaGlzIGlzIG5vdCBhbgogICAgICogZXhoYXVzdGl2ZSBsaXN0IG9mIExVVCB2YWx1ZXMgKGUuZy4sIE9wZW5TdGVwIGhhcyBhIGxvdCBvZiB3ZWlyZAogICAgICogb25lcyksIGJ1dCBpdCBzaG91bGQgY292ZXIgOTklIG9mIHRoZSBjdXJyZW50IHBvc3NpYmlsaXRpZXMuICovCgojaWYgZGVmaW5lZChOZVhUKQogICAgTFVUX2V4cG9uZW50ID0gMS4wIC8gMi4yOwogICAgLyoKICAgIGlmIChzb21lX25leHRfZnVuY3Rpb25fdGhhdF9yZXR1cm5zX2dhbW1hKCZuZXh0X2dhbW1hKSkKICAgICAgICBMVVRfZXhwb25lbnQgPSAxLjAgLyBuZXh0X2dhbW1hOwogICAgICovCiNlbGlmIGRlZmluZWQoc2dpKQogICAgTFVUX2V4cG9uZW50ID0gMS4wIC8gMS43OwogICAgLyogdGhlcmUgZG9lc24ndCBzZWVtIHRvIGJlIGFueSBkb2N1bWVudGVkIGZ1bmN0aW9uIHRvIGdldCB0aGUKICAgICAqICJnYW1tYSIgdmFsdWUsIHNvIHdlIGRvIGl0IHRoZSBoYXJkIHdheSAqLwogICAgaW5maWxlID0gZm9wZW4oIi9ldGMvY29uZmlnL3N5c3RlbS5nbEdhbW1hVmFsIiwgInIiKTsKICAgIGlmIChpbmZpbGUpIHsKICAgICAgICBkb3VibGUgc2dpX2dhbW1hOwoKICAgICAgICBmZ2V0cyh0bXBsaW5lLCA4MCwgaW5maWxlKTsKICAgICAgICBmY2xvc2UoaW5maWxlKTsKICAgICAgICBzZ2lfZ2FtbWEgPSBhdG9mKHRtcGxpbmUpOwogICAgICAgIGlmIChzZ2lfZ2FtbWEgPiAwLjApCiAgICAgICAgICAgIExVVF9leHBvbmVudCA9IDEuMCAvIHNnaV9nYW1tYTsKICAgIH0KI2VsaWYgZGVmaW5lZChNYWNpbnRvc2gpCiAgICBMVVRfZXhwb25lbnQgPSAxLjggLyAyLjYxOwogICAgLyoKICAgIGlmIChzb21lX21hY19mdW5jdGlvbl90aGF0X3JldHVybnNfZ2FtbWEoJm1hY19nYW1tYSkpCiAgICAgICAgTFVUX2V4cG9uZW50ID0gbWFjX2dhbW1hIC8gMi42MTsKICAgICAqLwojZWxzZQogICAgTFVUX2V4cG9uZW50ID0gMS4wOyAgIC8qIGFzc3VtZSBubyBMVVQ6ICBtb3N0IFBDcyAqLwojZW5kaWYKCiAgICAvKiB0aGUgZGVmYXVsdHMgYWJvdmUgZ2l2ZSAxLjAsIDEuMywgMS41IGFuZCAyLjIsIHJlc3BlY3RpdmVseTogKi8KICAgIGRlZmF1bHRfZGlzcGxheV9leHBvbmVudCA9IExVVF9leHBvbmVudCAqIENSVF9leHBvbmVudDsKCgogICAgLyogSWYgdGhlIHVzZXIgaGFzIHNldCB0aGUgU0NSRUVOX0dBTU1BIGVudmlyb25tZW50IHZhcmlhYmxlIGFzIHN1Z2dlc3RlZAogICAgICogKHNvbWV3aGF0IGltcHJlY2lzZWx5KSBpbiB0aGUgbGlicG5nIGRvY3VtZW50YXRpb24sIHVzZSB0aGF0OyBvdGhlcndpc2UKICAgICAqIHVzZSB0aGUgZGVmYXVsdCB2YWx1ZSB3ZSBqdXN0IGNhbGN1bGF0ZWQuICBFaXRoZXIgd2F5LCB0aGUgdXNlciBtYXkKICAgICAqIG92ZXJyaWRlIHRoaXMgdmlhIGEgY29tbWFuZC1saW5lIG9wdGlvbi4gKi8KCiAgICBpZiAoKHAgPSBnZXRlbnYoIlNDUkVFTl9HQU1NQSIpKSAhPSBOVUxMKQogICAgICAgIGRpc3BsYXlfZXhwb25lbnQgPSBhdG9mKHApOwogICAgZWxzZQogICAgICAgIGRpc3BsYXlfZXhwb25lbnQgPSBkZWZhdWx0X2Rpc3BsYXlfZXhwb25lbnQ7CgoKICAgIC8qIE5vdyBwYXJzZSB0aGUgY29tbWFuZCBsaW5lIGZvciBvcHRpb25zIGFuZCB0aGUgUE5HIGZpbGVuYW1lLiAqLwoKICAgIHdoaWxlICgqKythcmd2ICYmICFlcnJvcikgewogICAgICAgIGlmICghc3RybmNtcCgqYXJndiwgIi1kaXNwbGF5IiwgMikpIHsKICAgICAgICAgICAgaWYgKCEqKythcmd2KQogICAgICAgICAgICAgICAgKytlcnJvcjsKICAgICAgICAgICAgZWxzZQogICAgICAgICAgICAgICAgZGlzcGxheW5hbWUgPSAqYXJndjsKICAgICAgICB9IGVsc2UgaWYgKCFzdHJuY21wKCphcmd2LCAiLWdhbW1hIiwgMikpIHsKICAgICAgICAgICAgaWYgKCEqKythcmd2KQogICAgICAgICAgICAgICAgKytlcnJvcjsKICAgICAgICAgICAgZWxzZSB7CiAgICAgICAgICAgICAgICBkaXNwbGF5X2V4cG9uZW50ID0gYXRvZigqYXJndik7CiAgICAgICAgICAgICAgICBpZiAoZGlzcGxheV9leHBvbmVudCA8PSAwLjApCiAgICAgICAgICAgICAgICAgICAgKytlcnJvcjsKICAgICAgICAgICAgfQogICAgICAgIH0gZWxzZSBpZiAoIXN0cm5jbXAoKmFyZ3YsICItYmdjb2xvciIsIDIpKSB7CiAgICAgICAgICAgIGlmICghKisrYXJndikKICAgICAgICAgICAgICAgICsrZXJyb3I7CiAgICAgICAgICAgIGVsc2UgewogICAgICAgICAgICAgICAgYmdzdHIgPSAqYXJndjsKICAgICAgICAgICAgICAgIGlmIChzdHJsZW4oYmdzdHIpICE9IDcgfHwgYmdzdHJbMF0gIT0gJyMnKQogICAgICAgICAgICAgICAgICAgICsrZXJyb3I7IAogICAgICAgICAgICAgICAgZWxzZSAKICAgICAgICAgICAgICAgICAgICBoYXZlX2JnID0gVFJVRTsKICAgICAgICAgICAgfQogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIGlmICgqKmFyZ3YgIT0gJy0nKSB7CiAgICAgICAgICAgICAgICBmaWxlbmFtZSA9ICphcmd2OwogICAgICAgICAgICAgICAgaWYgKGFyZ3ZbMV0pICAgLyogc2hvdWxkbid0IGJlIGFueSBtb3JlIGFyZ3MgYWZ0ZXIgZmlsZW5hbWUgKi8KICAgICAgICAgICAgICAgICAgICArK2Vycm9yOwogICAgICAgICAgICB9IGVsc2UKICAgICAgICAgICAgICAgICsrZXJyb3I7ICAgLyogbm90IGV4cGVjdGluZyBhbnkgb3RoZXIgb3B0aW9ucyAqLwogICAgICAgIH0KICAgIH0KCiAgICBpZiAoIWZpbGVuYW1lKSB7CiAgICAgICAgKytlcnJvcjsKICAgIH0gZWxzZSBpZiAoIShpbmZpbGUgPSBmb3BlbihmaWxlbmFtZSwgInJiIikpKSB7CiAgICAgICAgZnByaW50ZihzdGRlcnIsIFBST0dOQU1FICI6ICBjYW4ndCBvcGVuIFBORyBmaWxlIFslc11cbiIsIGZpbGVuYW1lKTsKICAgICAgICArK2Vycm9yOwogICAgfSBlbHNlIHsKICAgICAgICBpZiAoKHJjID0gcmVhZHBuZ19pbml0KGluZmlsZSwgJmltYWdlX3dpZHRoLCAmaW1hZ2VfaGVpZ2h0KSkgIT0gMCkgewogICAgICAgICAgICBzd2l0Y2ggKHJjKSB7CiAgICAgICAgICAgICAgICBjYXNlIDE6CiAgICAgICAgICAgICAgICAgICAgZnByaW50ZihzdGRlcnIsIFBST0dOQU1FCiAgICAgICAgICAgICAgICAgICAgICAiOiAgWyVzXSBpcyBub3QgYSBQTkcgZmlsZTogaW5jb3JyZWN0IHNpZ25hdHVyZVxuIiwKICAgICAgICAgICAgICAgICAgICAgIGZpbGVuYW1lKTsKICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgIGNhc2UgMjoKICAgICAgICAgICAgICAgICAgICBmcHJpbnRmKHN0ZGVyciwgUFJPR05BTUUKICAgICAgICAgICAgICAgICAgICAgICI6ICBbJXNdIGhhcyBiYWQgSUhEUiAobGlicG5nIGxvbmdqbXApXG4iLAogICAgICAgICAgICAgICAgICAgICAgZmlsZW5hbWUpOwogICAgICAgICAgICAgICAgICAgIGJyZWFrOwogICAgICAgICAgICAgICAgY2FzZSA0OgogICAgICAgICAgICAgICAgICAgIGZwcmludGYoc3RkZXJyLCBQUk9HTkFNRSAiOiAgaW5zdWZmaWNpZW50IG1lbW9yeVxuIik7CiAgICAgICAgICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgICAgICAgICBkZWZhdWx0OgogICAgICAgICAgICAgICAgICAgIGZwcmludGYoc3RkZXJyLCBQUk9HTkFNRQogICAgICAgICAgICAgICAgICAgICAgIjogIHVua25vd24gcmVhZHBuZ19pbml0KCkgZXJyb3JcbiIpOwogICAgICAgICAgICAgICAgICAgIGJyZWFrOwogICAgICAgICAgICB9CiAgICAgICAgICAgICsrZXJyb3I7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgZGlzcGxheSA9IFhPcGVuRGlzcGxheShkaXNwbGF5bmFtZSk7CiAgICAgICAgICAgIGlmICghZGlzcGxheSkgewogICAgICAgICAgICAgICAgcmVhZHBuZ19jbGVhbnVwKFRSVUUpOwogICAgICAgICAgICAgICAgZnByaW50ZihzdGRlcnIsIFBST0dOQU1FICI6ICBjYW4ndCBvcGVuIFggZGlzcGxheSBbJXNdXG4iLAogICAgICAgICAgICAgICAgICBkaXNwbGF5bmFtZT8gZGlzcGxheW5hbWUgOiAiZGVmYXVsdCIpOwogICAgICAgICAgICAgICAgKytlcnJvcjsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICBpZiAoZXJyb3IpCiAgICAgICAgICAgIGZjbG9zZShpbmZpbGUpOwogICAgfQoKCiAgICAvKiB1c2FnZSBzY3JlZW4gKi8KCiAgICBpZiAoZXJyb3IpIHsKICAgICAgICBmcHJpbnRmKHN0ZGVyciwgIlxuJXMgJXM6ICAlc1xuIiwgUFJPR05BTUUsIFZFUlNJT04sIGFwcG5hbWUpOwogICAgICAgIHJlYWRwbmdfdmVyc2lvbl9pbmZvKCk7CiAgICAgICAgZnByaW50ZihzdGRlcnIsICJcbiIKICAgICAgICAgICJVc2FnZTogICVzIFstZGlzcGxheSB4ZHB5XSBbLWdhbW1hIGV4cF0gWy1iZ2NvbG9yIGJnXSBmaWxlLnBuZ1xuIgogICAgICAgICAgIiAgICB4ZHB5XHRuYW1lIG9mIHRoZSB0YXJnZXQgWCBkaXNwbGF5IChlLmcuLCBgYGhvc3RuYW1lOjAnJylcbiIKICAgICAgICAgICIgICAgZXhwIFx0dHJhbnNmZXItZnVuY3Rpb24gZXhwb25lbnQgKGBgZ2FtbWEnJykgb2YgdGhlIGRpc3BsYXlcbiIKICAgICAgICAgICJcdFx0ICBzeXN0ZW0gaW4gZmxvYXRpbmctcG9pbnQgZm9ybWF0IChlLmcuLCBgYCUuMWYnJyk7IGVxdWFsXG4iCiAgICAgICAgICAiXHRcdCAgdG8gdGhlIHByb2R1Y3Qgb2YgdGhlIGxvb2t1cC10YWJsZSBleHBvbmVudCAodmFyaWVzKVxuIgogICAgICAgICAgIlx0XHQgIGFuZCB0aGUgQ1JUIGV4cG9uZW50ICh1c3VhbGx5IDIuMik7IG11c3QgYmUgcG9zaXRpdmVcbiIKICAgICAgICAgICIgICAgYmcgIFx0ZGVzaXJlZCBiYWNrZ3JvdW5kIGNvbG9yIGluIDctY2hhcmFjdGVyIGhleCBSR0IgZm9ybWF0XG4iCiAgICAgICAgICAiXHRcdCAgKGUuZy4sIGBgI2ZmNzcwMCcnIGZvciBvcmFuZ2U6ICBzYW1lIGFzIEhUTUwgY29sb3JzKTtcbiIKICAgICAgICAgICJcdFx0ICB1c2VkIHdpdGggdHJhbnNwYXJlbnQgaW1hZ2VzXG4iCiAgICAgICAgICAiXG5QcmVzcyBRLCBFc2Mgb3IgbW91c2UgYnV0dG9uIDEgKHdpdGhpbiBpbWFnZSB3aW5kb3csIGFmdGVyIGltYWdlXG4iCiAgICAgICAgICAiaXMgZGlzcGxheWVkKSB0byBxdWl0LlxuIgogICAgICAgICAgIlxuIiwgUFJPR05BTUUsIGRlZmF1bHRfZGlzcGxheV9leHBvbmVudCk7CiAgICAgICAgZXhpdCgxKTsKICAgIH0KCgogICAgLyogc2V0IHRoZSB0aXRsZS1iYXIgc3RyaW5nLCBidXQgbWFrZSBzdXJlIGJ1ZmZlciBkb2Vzbid0IG92ZXJmbG93ICovCgogICAgYWxlbiA9IHN0cmxlbihhcHBuYW1lKTsKICAgIGZsZW4gPSBzdHJsZW4oZmlsZW5hbWUpOwogICAgaWYgKGFsZW4gKyBmbGVuICsgMyA+IDEwMjMpCiAgICAgICAgc3ByaW50Zih0aXRsZWJhciwgIiVzOiAgLi4uJXMiLCBhcHBuYW1lLCBmaWxlbmFtZSsoYWxlbitmbGVuKzYtMTAyMykpOwogICAgZWxzZQogICAgICAgIHNwcmludGYodGl0bGViYXIsICIlczogICVzIiwgYXBwbmFtZSwgZmlsZW5hbWUpOwoKCiAgICAvKiBpZiB0aGUgdXNlciBkaWRuJ3Qgc3BlY2lmeSBhIGJhY2tncm91bmQgY29sb3Igb24gdGhlIGNvbW1hbmQgbGluZSwKICAgICAqIGNoZWNrIGZvciBvbmUgaW4gdGhlIFBORyBmaWxlLS1pZiBub3QsIHRoZSBpbml0aWFsaXplZCB2YWx1ZXMgb2YgMAogICAgICogKGJsYWNrKSB3aWxsIGJlIHVzZWQgKi8KCiAgICBpZiAoaGF2ZV9iZykgewogICAgICAgIHVuc2lnbmVkIHIsIGcsIGI7ICAgLyogdGhpcyBhcHByb2FjaCBxdWlldHMgY29tcGlsZXIgd2FybmluZ3MgKi8KCiAgICAgICAgc3NjYW5mKGJnc3RyKzEsICIlMnglMnglMngiLCAmciwgJmcsICZiKTsKICAgICAgICBiZ19yZWQgICA9ICh1Y2gpcjsKICAgICAgICBiZ19ncmVlbiA9ICh1Y2gpZzsKICAgICAgICBiZ19ibHVlICA9ICh1Y2gpYjsKICAgIH0gZWxzZSBpZiAocmVhZHBuZ19nZXRfYmdjb2xvcigmYmdfcmVkLCAmYmdfZ3JlZW4sICZiZ19ibHVlKSA+IDEpIHsKICAgICAgICByZWFkcG5nX2NsZWFudXAoVFJVRSk7CiAgICAgICAgZnByaW50ZihzdGRlcnIsIFBST0dOQU1FCiAgICAgICAgICAiOiAgbGlicG5nIGVycm9yIHdoaWxlIGNoZWNraW5nIGZvciBiYWNrZ3JvdW5kIGNvbG9yXG4iKTsKICAgICAgICBleGl0KDIpOwogICAgfQoKCiAgICAvKiBkbyB0aGUgYmFzaWMgWCBpbml0aWFsaXphdGlvbiBzdHVmZiwgbWFrZSB0aGUgd2luZG93IGFuZCBmaWxsIGl0CiAgICAgKiB3aXRoIHRoZSBiYWNrZ3JvdW5kIGNvbG9yICovCgogICAgaWYgKHJwbmdfeF9jcmVhdGVfd2luZG93KCkpCiAgICAgICAgZXhpdCgyKTsKCgogICAgLyogZGVjb2RlIHRoZSBpbWFnZSwgYWxsIGF0IG9uY2UgKi8KCiAgICBUcmFjZSgoc3RkZXJyLCAiY2FsbGluZyByZWFkcG5nX2dldF9pbWFnZSgpXG4iKSkKICAgIGltYWdlX2RhdGEgPSByZWFkcG5nX2dldF9pbWFnZShkaXNwbGF5X2V4cG9uZW50LCAmaW1hZ2VfY2hhbm5lbHMsCiAgICAgICZpbWFnZV9yb3dieXRlcyk7CiAgICBUcmFjZSgoc3RkZXJyLCAiZG9uZSB3aXRoIHJlYWRwbmdfZ2V0X2ltYWdlKClcbiIpKQoKCiAgICAvKiBkb25lIHdpdGggUE5HIGZpbGUsIHNvIGNsZWFuIHVwIHRvIG1pbmltaXplIG1lbW9yeSB1c2FnZSAoYnV0IGRvIE5PVAogICAgICogbnVrZSBpbWFnZV9kYXRhISkgKi8KCiAgICByZWFkcG5nX2NsZWFudXAoRkFMU0UpOwogICAgZmNsb3NlKGluZmlsZSk7CgogICAgaWYgKCFpbWFnZV9kYXRhKSB7CiAgICAgICAgZnByaW50ZihzdGRlcnIsIFBST0dOQU1FICI6ICB1bmFibGUgdG8gZGVjb2RlIFBORyBpbWFnZVxuIik7CiAgICAgICAgZXhpdCgzKTsKICAgIH0KCgogICAgLyogZGlzcGxheSBpbWFnZSAoY29tcG9zaXRlIHdpdGggYmFja2dyb3VuZCBpZiByZXF1ZXN0ZWQpICovCgogICAgVHJhY2UoKHN0ZGVyciwgImNhbGxpbmcgcnBuZ194X2Rpc3BsYXlfaW1hZ2UoKVxuIikpCiAgICBpZiAocnBuZ194X2Rpc3BsYXlfaW1hZ2UoKSkgewogICAgICAgIGZyZWUoaW1hZ2VfZGF0YSk7CiAgICAgICAgZXhpdCg0KTsKICAgIH0KICAgIFRyYWNlKChzdGRlcnIsICJkb25lIHdpdGggcnBuZ194X2Rpc3BsYXlfaW1hZ2UoKVxuIikpCgoKICAgIC8qIHdhaXQgZm9yIHRoZSB1c2VyIHRvIHRlbGwgdXMgd2hlbiB0byBxdWl0ICovCgogICAgcHJpbnRmKAogICAgICAiRG9uZS4gIFByZXNzIFEsIEVzYyBvciBtb3VzZSBidXR0b24gMSAod2l0aGluIGltYWdlIHdpbmRvdykgdG8gcXVpdC5cbiIpOwogICAgZmZsdXNoKHN0ZG91dCk7CgogICAgZG8KICAgICAgICBYTmV4dEV2ZW50KGRpc3BsYXksICZlKTsKICAgIHdoaWxlICghKGUudHlwZSA9PSBCdXR0b25QcmVzcyAmJiBlLnhidXR0b24uYnV0dG9uID09IEJ1dHRvbjEpICYmCiAgICAgICAgICAgIShlLnR5cGUgPT0gS2V5UHJlc3MgJiYgICAgLyogIHYtLS0gb3IgMSBmb3Igc2hpZnRlZCBrZXlzICovCiAgICAgICAgICAgICAoKGsgPSBYTG9va3VwS2V5c3ltKCZlLnhrZXksIDApKSA9PSBYS19xIHx8IGsgPT0gWEtfRXNjYXBlKSApKTsKCgogICAgLyogT0ssIHdlJ3JlIGRvbmU6ICBjbGVhbiB1cCBhbGwgaW1hZ2UgYW5kIFggcmVzb3VyY2VzIGFuZCBnbyBhd2F5ICovCgogICAgcnBuZ194X2NsZWFudXAoKTsKCiAgICByZXR1cm4gMDsKfQoKCgoKCnN0YXRpYyBpbnQgcnBuZ194X2NyZWF0ZV93aW5kb3codm9pZCkKewogICAgdWNoICp4ZGF0YTsKICAgIGludCBuZWVkX2NvbG9ybWFwID0gRkFMU0U7CiAgICBpbnQgc2NyZWVuLCBwYWQ7CiAgICB1bGcgYmdfcGl4ZWwgPSAwTDsKICAgIHVsZyBhdHRybWFzazsKICAgIFdpbmRvdyByb290OwogICAgWEV2ZW50IGU7CiAgICBYR0NWYWx1ZXMgZ2N2YWx1ZXM7CiAgICBYU2V0V2luZG93QXR0cmlidXRlcyBhdHRyOwogICAgWFRleHRQcm9wZXJ0eSB3aW5kb3dOYW1lLCAqcFdpbmRvd05hbWUgPSAmd2luZG93TmFtZTsKICAgIFhUZXh0UHJvcGVydHkgaWNvbk5hbWUsICpwSWNvbk5hbWUgPSAmaWNvbk5hbWU7CiAgICBYVmlzdWFsSW5mbyB2aXN1YWxfaW5mbzsKICAgIFhTaXplSGludHMgKnNpemVfaGludHM7CiAgICBYV01IaW50cyAqd21faGludHM7CiAgICBYQ2xhc3NIaW50ICpjbGFzc19oaW50czsKCgogICAgc2NyZWVuID0gRGVmYXVsdFNjcmVlbihkaXNwbGF5KTsKICAgIGRlcHRoID0gRGlzcGxheVBsYW5lcyhkaXNwbGF5LCBzY3JlZW4pOwogICAgcm9vdCA9IFJvb3RXaW5kb3coZGlzcGxheSwgc2NyZWVuKTsKCiNpZmRlZiBERUJVRwogICAgWFN5bmNocm9uaXplKGRpc3BsYXksIFRydWUpOwojZW5kaWYKCiNpZiAwCi8qIEdSUjogIGFkZCA4LWJpdCBzdXBwb3J0ICovCiAgICBpZiAoLyogZGVwdGggIT0gOCAmJiAqLyBkZXB0aCAhPSAxNiAmJiBkZXB0aCAhPSAyNCAmJiBkZXB0aCAhPSAzMikgewogICAgICAgIGZwcmludGYoc3RkZXJyLAogICAgICAgICAgInNjcmVlbiBkZXB0aCAlZCBub3Qgc3VwcG9ydGVkIChvbmx5IDE2LSwgMjQtIG9yIDMyLWJpdCBUcnVlQ29sb3IpXG4iLAogICAgICAgICAgZGVwdGgpOwogICAgICAgIHJldHVybiAyOwogICAgfQoKICAgIFhNYXRjaFZpc3VhbEluZm8oZGlzcGxheSwgc2NyZWVuLCBkZXB0aCwKICAgICAgKGRlcHRoID09IDgpPyBQc2V1ZG9Db2xvciA6IFRydWVDb2xvciwgJnZpc3VhbF9pbmZvKTsKICAgIHZpc3VhbCA9IHZpc3VhbF9pbmZvLnZpc3VhbDsKI2Vsc2UKICAgIGlmIChkZXB0aCAhPSAxNiAmJiBkZXB0aCAhPSAyNCAmJiBkZXB0aCAhPSAzMikgewogICAgICAgIGludCB2aXN1YWxzX21hdGNoZWQgPSAwOwoKICAgICAgICBUcmFjZSgoc3RkZXJyLCAiZGVmYXVsdCBkZXB0aCBpcyAlZDogIGNoZWNraW5nIG90aGVyIHZpc3VhbHNcbiIsCiAgICAgICAgICBkZXB0aCkpCgogICAgICAgIC8qIDI0LWJpdCBmaXJzdCAqLwogICAgICAgIHZpc3VhbF9pbmZvLnNjcmVlbiA9IHNjcmVlbjsKICAgICAgICB2aXN1YWxfaW5mby5kZXB0aCA9IDI0OwogICAgICAgIHZpc3VhbF9saXN0ID0gWEdldFZpc3VhbEluZm8oZGlzcGxheSwKICAgICAgICAgIFZpc3VhbFNjcmVlbk1hc2sgfCBWaXN1YWxEZXB0aE1hc2ssICZ2aXN1YWxfaW5mbywgJnZpc3VhbHNfbWF0Y2hlZCk7CiAgICAgICAgaWYgKHZpc3VhbHNfbWF0Y2hlZCA9PSAwKSB7Ci8qIEdSUjogIGFkZCAxNS0sIDE2LSBhbmQgMzItYml0IFRydWVDb2xvciB2aXN1YWxzIChhbHNvIERpcmVjdENvbG9yPykgKi8KICAgICAgICAgICAgZnByaW50ZihzdGRlcnIsICJkZWZhdWx0IHNjcmVlbiBkZXB0aCAlZCBub3Qgc3VwcG9ydGVkLCBhbmQgbm8iCiAgICAgICAgICAgICAgIiAyNC1iaXQgdmlzdWFscyBmb3VuZFxuIiwgZGVwdGgpOwogICAgICAgICAgICByZXR1cm4gMjsKICAgICAgICB9CiAgICAgICAgVHJhY2UoKHN0ZGVyciwgIlhHZXRWaXN1YWxJbmZvKCkgcmV0dXJuZWQgJWQgMjQtYml0IHZpc3VhbHNcbiIsCiAgICAgICAgICB2aXN1YWxzX21hdGNoZWQpKQogICAgICAgIHZpc3VhbCA9IHZpc3VhbF9saXN0WzBdLnZpc3VhbDsKICAgICAgICBkZXB0aCA9IHZpc3VhbF9saXN0WzBdLmRlcHRoOwovKgogICAgICAgIGNvbG9ybWFwX3NpemUgPSB2aXN1YWxfbGlzdFswXS5jb2xvcm1hcF9zaXplOwogICAgICAgIHZpc3VhbF9jbGFzcyA9IHZpc3VhbC0+Y2xhc3M7CiAgICAgICAgdmlzdWFsSUQgPSBYVmlzdWFsSURGcm9tVmlzdWFsKHZpc3VhbCk7CiAqLwogICAgICAgIGhhdmVfbm9uZGVmYXVsdF92aXN1YWwgPSBUUlVFOwogICAgICAgIG5lZWRfY29sb3JtYXAgPSBUUlVFOwogICAgfSBlbHNlIHsKICAgICAgICBYTWF0Y2hWaXN1YWxJbmZvKGRpc3BsYXksIHNjcmVlbiwgZGVwdGgsIFRydWVDb2xvciwgJnZpc3VhbF9pbmZvKTsKICAgICAgICB2aXN1YWwgPSB2aXN1YWxfaW5mby52aXN1YWw7CiAgICB9CiNlbmRpZgoKICAgIFJNYXNrID0gdmlzdWFsLT5yZWRfbWFzazsKICAgIEdNYXNrID0gdmlzdWFsLT5ncmVlbl9tYXNrOwogICAgQk1hc2sgPSB2aXN1YWwtPmJsdWVfbWFzazsKCi8qIEdSUjogIGFkZC9jaGVjayA4LWJpdCBzdXBwb3J0ICovCiAgICBpZiAoZGVwdGggPT0gOCB8fCBuZWVkX2NvbG9ybWFwKSB7CiAgICAgICAgY29sb3JtYXAgPSBYQ3JlYXRlQ29sb3JtYXAoZGlzcGxheSwgcm9vdCwgdmlzdWFsLCBBbGxvY05vbmUpOwogICAgICAgIGlmICghY29sb3JtYXApIHsKICAgICAgICAgICAgZnByaW50ZihzdGRlcnIsICJYQ3JlYXRlQ29sb3JtYXAoKSBmYWlsZWRcbiIpOwogICAgICAgICAgICByZXR1cm4gMjsKICAgICAgICB9CiAgICAgICAgaGF2ZV9jb2xvcm1hcCA9IFRSVUU7CiAgICB9CiAgICBpZiAoZGVwdGggPT0gMTUgfHwgZGVwdGggPT0gMTYpIHsKICAgICAgICBSU2hpZnQgPSAxNSAtIHJwbmdfeF9tc2IoUk1hc2spOyAgICAvKiB0aGVzZSBhcmUgcmlnaHQtc2hpZnRzICovCiAgICAgICAgR1NoaWZ0ID0gMTUgLSBycG5nX3hfbXNiKEdNYXNrKTsKICAgICAgICBCU2hpZnQgPSAxNSAtIHJwbmdfeF9tc2IoQk1hc2spOwogICAgfSBlbHNlIGlmIChkZXB0aCA+IDE2KSB7CiNkZWZpbmUgTk9fMjRCSVRfTUFTS1MKI2lmZGVmIE5PXzI0QklUX01BU0tTCiAgICAgICAgUlNoaWZ0ID0gcnBuZ194X21zYihSTWFzaykgLSA3OyAgICAgLyogdGhlc2UgYXJlIGxlZnQtc2hpZnRzICovCiAgICAgICAgR1NoaWZ0ID0gcnBuZ194X21zYihHTWFzaykgLSA3OwogICAgICAgIEJTaGlmdCA9IHJwbmdfeF9tc2IoQk1hc2spIC0gNzsKI2Vsc2UKICAgICAgICBSU2hpZnQgPSA3IC0gcnBuZ194X21zYihSTWFzayk7ICAgICAvKiB0aGVzZSBhcmUgcmlnaHQtc2hpZnRzLCB0b28gKi8KICAgICAgICBHU2hpZnQgPSA3IC0gcnBuZ194X21zYihHTWFzayk7CiAgICAgICAgQlNoaWZ0ID0gNyAtIHJwbmdfeF9tc2IoQk1hc2spOwojZW5kaWYKICAgIH0KICAgIGlmIChkZXB0aCA+PSAxNSAmJiAoUlNoaWZ0IDwgMCB8fCBHU2hpZnQgPCAwIHx8IEJTaGlmdCA8IDApKSB7CiAgICAgICAgZnByaW50ZihzdGRlcnIsICJycG5nIGludGVybmFsIGxvZ2ljIGVycm9yOiAgbmVnYXRpdmUgWCBzaGlmdChzKSFcbiIpOwogICAgICAgIHJldHVybiAyOwogICAgfQoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIEZpbmFsbHksIGNyZWF0ZSB0aGUgd2luZG93LgogIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCgogICAgYXR0ci5iYWNraW5nX3N0b3JlID0gQWx3YXlzOwogICAgYXR0ci5ldmVudF9tYXNrID0gRXhwb3N1cmVNYXNrIHwgS2V5UHJlc3NNYXNrIHwgQnV0dG9uUHJlc3NNYXNrOwogICAgYXR0cm1hc2sgPSBDV0JhY2tpbmdTdG9yZSB8IENXRXZlbnRNYXNrOwogICAgaWYgKGhhdmVfbm9uZGVmYXVsdF92aXN1YWwpIHsKICAgICAgICBhdHRyLmNvbG9ybWFwID0gY29sb3JtYXA7CiAgICAgICAgYXR0ci5iYWNrZ3JvdW5kX3BpeGVsID0gMDsKICAgICAgICBhdHRyLmJvcmRlcl9waXhlbCA9IDE7CiAgICAgICAgYXR0cm1hc2sgfD0gQ1dDb2xvcm1hcCB8IENXQmFja1BpeGVsIHwgQ1dCb3JkZXJQaXhlbDsKICAgIH0KCiAgICB3aW5kb3cgPSBYQ3JlYXRlV2luZG93KGRpc3BsYXksIHJvb3QsIDAsIDAsIGltYWdlX3dpZHRoLCBpbWFnZV9oZWlnaHQsIDAsCiAgICAgIGRlcHRoLCBJbnB1dE91dHB1dCwgdmlzdWFsLCBhdHRybWFzaywgJmF0dHIpOwoKICAgIGlmICh3aW5kb3cgPT0gTm9uZSkgewogICAgICAgIGZwcmludGYoc3RkZXJyLCAiWENyZWF0ZVdpbmRvdygpIGZhaWxlZFxuIik7CiAgICAgICAgcmV0dXJuIDI7CiAgICB9IGVsc2UKICAgICAgICBoYXZlX3dpbmRvdyA9IFRSVUU7CgogICAgaWYgKGRlcHRoID09IDgpCiAgICAgICAgWFNldFdpbmRvd0NvbG9ybWFwKGRpc3BsYXksIHdpbmRvdywgY29sb3JtYXApOwoKICAgIGlmICghWFN0cmluZ0xpc3RUb1RleHRQcm9wZXJ0eSgmd2luZG93X25hbWUsIDEsIHBXaW5kb3dOYW1lKSkKICAgICAgICBwV2luZG93TmFtZSA9IE5VTEw7CiAgICBpZiAoIVhTdHJpbmdMaXN0VG9UZXh0UHJvcGVydHkoJmljb25fbmFtZSwgMSwgcEljb25OYW1lKSkKICAgICAgICBwSWNvbk5hbWUgPSBOVUxMOwoKICAgIC8qIE9LIGlmIGFueSBoaW50cyBhbGxvY2F0aW9uIGZhaWxzOyBYU2V0V01Qcm9wZXJ0aWVzKCkgYWxsb3dzIE5VTExzICovCgogICAgaWYgKChzaXplX2hpbnRzID0gWEFsbG9jU2l6ZUhpbnRzKCkpICE9IE5VTEwpIHsKICAgICAgICAvKiB3aW5kb3cgd2lsbCBub3QgYmUgcmVzaXphYmxlICovCiAgICAgICAgc2l6ZV9oaW50cy0+ZmxhZ3MgPSBQTWluU2l6ZSB8IFBNYXhTaXplOwogICAgICAgIHNpemVfaGludHMtPm1pbl93aWR0aCA9IHNpemVfaGludHMtPm1heF93aWR0aCA9IChpbnQpaW1hZ2Vfd2lkdGg7CiAgICAgICAgc2l6ZV9oaW50cy0+bWluX2hlaWdodCA9IHNpemVfaGludHMtPm1heF9oZWlnaHQgPSAoaW50KWltYWdlX2hlaWdodDsKICAgIH0KCiAgICBpZiAoKHdtX2hpbnRzID0gWEFsbG9jV01IaW50cygpKSAhPSBOVUxMKSB7CiAgICAgICAgd21faGludHMtPmluaXRpYWxfc3RhdGUgPSBOb3JtYWxTdGF0ZTsKICAgICAgICB3bV9oaW50cy0+aW5wdXQgPSBUcnVlOwogICAgIC8qIHdtX2hpbnRzLT5pY29uX3BpeG1hcCA9IGljb25fcGl4bWFwOyAqLwogICAgICAgIHdtX2hpbnRzLT5mbGFncyA9IFN0YXRlSGludCB8IElucHV0SGludCAgLyogfCBJY29uUGl4bWFwSGludCAqLyA7CiAgICB9CgogICAgaWYgKChjbGFzc19oaW50cyA9IFhBbGxvY0NsYXNzSGludCgpKSAhPSBOVUxMKSB7CiAgICAgICAgY2xhc3NfaGludHMtPnJlc19uYW1lID0gcmVzX25hbWU7CiAgICAgICAgY2xhc3NfaGludHMtPnJlc19jbGFzcyA9IHJlc19jbGFzczsKICAgIH0KCiAgICBYU2V0V01Qcm9wZXJ0aWVzKGRpc3BsYXksIHdpbmRvdywgcFdpbmRvd05hbWUsIHBJY29uTmFtZSwgTlVMTCwgMCwKICAgICAgc2l6ZV9oaW50cywgd21faGludHMsIGNsYXNzX2hpbnRzKTsKCiAgICAvKiB2YXJpb3VzIHByb3BlcnRpZXMgYW5kIGhpbnRzIG5vIGxvbmdlciBuZWVkZWQ7IGZyZWUgbWVtb3J5ICovCiAgICBpZiAocFdpbmRvd05hbWUpCiAgICAgICBYRnJlZShwV2luZG93TmFtZS0+dmFsdWUpOwogICAgaWYgKHBJY29uTmFtZSkKICAgICAgIFhGcmVlKHBJY29uTmFtZS0+dmFsdWUpOwogICAgaWYgKHNpemVfaGludHMpCiAgICAgICAgWEZyZWUoc2l6ZV9oaW50cyk7CiAgICBpZiAod21faGludHMpCiAgICAgICBYRnJlZSh3bV9oaW50cyk7CiAgICBpZiAoY2xhc3NfaGludHMpCiAgICAgICBYRnJlZShjbGFzc19oaW50cyk7CgogICAgWE1hcFdpbmRvdyhkaXNwbGF5LCB3aW5kb3cpOwoKICAgIGdjID0gWENyZWF0ZUdDKGRpc3BsYXksIHdpbmRvdywgMCwgJmdjdmFsdWVzKTsKICAgIGhhdmVfZ2MgPSBUUlVFOwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIEZpbGwgd2luZG93IHdpdGggdGhlIHNwZWNpZmllZCBiYWNrZ3JvdW5kIGNvbG9yLgogIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCgogICAgaWYgKGRlcHRoID09IDI0IHx8IGRlcHRoID09IDMyKSB7CiAgICAgICAgYmdfcGl4ZWwgPSAoKHVsZyliZ19yZWQgICA8PCBSU2hpZnQpIHwKICAgICAgICAgICAgICAgICAgICgodWxnKWJnX2dyZWVuIDw8IEdTaGlmdCkgfAogICAgICAgICAgICAgICAgICAgKCh1bGcpYmdfYmx1ZSAgPDwgQlNoaWZ0KTsKICAgIH0gZWxzZSBpZiAoZGVwdGggPT0gMTYpIHsKICAgICAgICBiZ19waXhlbCA9ICgoKCh1bGcpYmdfcmVkICAgPDwgOCkgPj4gUlNoaWZ0KSAmIFJNYXNrKSB8CiAgICAgICAgICAgICAgICAgICAoKCgodWxnKWJnX2dyZWVuIDw8IDgpID4+IEdTaGlmdCkgJiBHTWFzaykgfAogICAgICAgICAgICAgICAgICAgKCgoKHVsZyliZ19ibHVlICA8PCA4KSA+PiBCU2hpZnQpICYgQk1hc2spOwogICAgfSBlbHNlIC8qIGRlcHRoID09IDggKi8gewoKICAgICAgICAvKiBHUlI6ICBhZGQgOC1iaXQgc3VwcG9ydCAqLwoKICAgIH0KCiAgICBYU2V0Rm9yZWdyb3VuZChkaXNwbGF5LCBnYywgYmdfcGl4ZWwpOwogICAgWEZpbGxSZWN0YW5nbGUoZGlzcGxheSwgd2luZG93LCBnYywgMCwgMCwgaW1hZ2Vfd2lkdGgsIGltYWdlX2hlaWdodCk7CgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgV2FpdCBmb3IgZmlyc3QgRXhwb3NlIGV2ZW50IHRvIGRvIGFueSBkcmF3aW5nLCB0aGVuIGZsdXNoLgogIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCgogICAgZG8KICAgICAgICBYTmV4dEV2ZW50KGRpc3BsYXksICZlKTsKICAgIHdoaWxlIChlLnR5cGUgIT0gRXhwb3NlIHx8IGUueGV4cG9zZS5jb3VudCk7CgogICAgWEZsdXNoKGRpc3BsYXkpOwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIEFsbG9jYXRlIG1lbW9yeSBmb3IgdGhlIFgtIGFuZCBkaXNwbGF5LXNwZWNpZmljIHZlcnNpb24gb2YgdGhlIGltYWdlLgogIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCgogICAgaWYgKGRlcHRoID09IDI0IHx8IGRlcHRoID09IDMyKSB7CiAgICAgICAgeGRhdGEgPSAodWNoICopbWFsbG9jKDQqaW1hZ2Vfd2lkdGgqaW1hZ2VfaGVpZ2h0KTsKICAgICAgICBwYWQgPSAzMjsKICAgIH0gZWxzZSBpZiAoZGVwdGggPT0gMTYpIHsKICAgICAgICB4ZGF0YSA9ICh1Y2ggKiltYWxsb2MoMippbWFnZV93aWR0aCppbWFnZV9oZWlnaHQpOwogICAgICAgIHBhZCA9IDE2OwogICAgfSBlbHNlIC8qIGRlcHRoID09IDggKi8gewogICAgICAgIHhkYXRhID0gKHVjaCAqKW1hbGxvYyhpbWFnZV93aWR0aCppbWFnZV9oZWlnaHQpOwogICAgICAgIHBhZCA9IDg7CiAgICB9CgogICAgaWYgKCF4ZGF0YSkgewogICAgICAgIGZwcmludGYoc3RkZXJyLCBQUk9HTkFNRSAiOiAgdW5hYmxlIHRvIGFsbG9jYXRlIGltYWdlIG1lbW9yeVxuIik7CiAgICAgICAgcmV0dXJuIDQ7CiAgICB9CgogICAgeGltYWdlID0gWENyZWF0ZUltYWdlKGRpc3BsYXksIHZpc3VhbCwgZGVwdGgsIFpQaXhtYXAsIDAsCiAgICAgIChjaGFyICopeGRhdGEsIGltYWdlX3dpZHRoLCBpbWFnZV9oZWlnaHQsIHBhZCwgMCk7CgogICAgaWYgKCF4aW1hZ2UpIHsKICAgICAgICBmcHJpbnRmKHN0ZGVyciwgUFJPR05BTUUgIjogIFhDcmVhdGVJbWFnZSgpIGZhaWxlZFxuIik7CiAgICAgICAgZnJlZSh4ZGF0YSk7CiAgICAgICAgcmV0dXJuIDM7CiAgICB9CgogICAgLyogdG8gYXZvaWQgdGVzdGluZyB0aGUgYnl0ZSBvcmRlciBldmVyeSBwaXhlbCAob3IgZG91YmxpbmcgdGhlIHNpemUgb2YKICAgICAqIHRoZSBkcmF3aW5nIHJvdXRpbmUgd2l0aCBhIGdpYW50IGlmLXRlc3QpLCB3ZSBhcmJpdHJhcmlseSBzZXQgdGhlIGJ5dGUKICAgICAqIG9yZGVyIHRvIE1TQkZpcnN0IGFuZCBsZXQgWGxpYiB3b3JyeSBhYm91dCBpbnZlcnRpbmcgdGhpbmdzIG9uIGxpdHRsZS0KICAgICAqIGVuZGlhbiBtYWNoaW5lcyAobGlrZSBMaW51eC94ODYsIG9sZCBWQVhlbiwgZXRjLiktLXRoaXMgaXMgbm90IHRoZSBtb3N0CiAgICAgKiBlZmZpY2llbnQgYXBwcm9hY2ggKHRoZSBnaWFudCBpZi10ZXN0IHdvdWxkIGJlIGJldHRlciksIGJ1dCBpbiB0aGUKICAgICAqIGludGVyZXN0IG9mIGNsYXJpdHksIHdlIHRha2UgdGhlIGVhc3kgd2F5IG91dC4uLiAqLwoKICAgIHhpbWFnZS0+Ynl0ZV9vcmRlciA9IE1TQkZpcnN0OwoKICAgIHJldHVybiAwOwoKfSAvKiBlbmQgZnVuY3Rpb24gcnBuZ194X2NyZWF0ZV93aW5kb3coKSAqLwoKCgoKCnN0YXRpYyBpbnQgcnBuZ194X2Rpc3BsYXlfaW1hZ2Uodm9pZCkKewogICAgdWNoICpzcmM7CiAgICBjaGFyICpkZXN0OwogICAgdWNoIHIsIGcsIGIsIGE7CiAgICB1bGcgaSwgcm93LCBsYXN0cm93ID0gMDsKICAgIHVsZyBwaXhlbDsKICAgIGludCB4aW1hZ2Vfcm93Ynl0ZXMgPSB4aW1hZ2UtPmJ5dGVzX3Blcl9saW5lOwovKiAgaW50IGJwcCA9IHhpbWFnZS0+Yml0c19wZXJfcGl4ZWw7ICAqLwoKCiAgICBUcmFjZSgoc3RkZXJyLCAiYmVnaW5uaW5nIGRpc3BsYXkgbG9vcCAoaW1hZ2VfY2hhbm5lbHMgPT0gJWQpXG4iLAogICAgICBpbWFnZV9jaGFubmVscykpCiAgICBUcmFjZSgoc3RkZXJyLCAiICAgKHdpZHRoID0gJWxkLCByb3dieXRlcyA9ICVsZCwgeGltYWdlX3Jvd2J5dGVzID0gJWQpXG4iLAogICAgICBpbWFnZV93aWR0aCwgaW1hZ2Vfcm93Ynl0ZXMsIHhpbWFnZV9yb3dieXRlcykpCiAgICBUcmFjZSgoc3RkZXJyLCAiICAgKGJwcCA9ICVkKVxuIiwgeGltYWdlLT5iaXRzX3Blcl9waXhlbCkpCiAgICBUcmFjZSgoc3RkZXJyLCAiICAgKGJ5dGVfb3JkZXIgPSAlcylcbiIsIHhpbWFnZS0+Ynl0ZV9vcmRlciA9PSBNU0JGaXJzdD8KICAgICAgIk1TQkZpcnN0IiA6ICh4aW1hZ2UtPmJ5dGVfb3JkZXIgPT0gTFNCRmlyc3Q/ICJMU0JGaXJzdCIgOiAidW5rbm93biIpKSkKCiAgICBpZiAoZGVwdGggPT0gMjQgfHwgZGVwdGggPT0gMzIpIHsKICAgICAgICB1bGcgcmVkLCBncmVlbiwgYmx1ZTsKCiAgICAgICAgZm9yIChsYXN0cm93ID0gcm93ID0gMDsgIHJvdyA8IGltYWdlX2hlaWdodDsgICsrcm93KSB7CiAgICAgICAgICAgIHNyYyA9IGltYWdlX2RhdGEgKyByb3cqaW1hZ2Vfcm93Ynl0ZXM7CiAgICAgICAgICAgIGRlc3QgPSB4aW1hZ2UtPmRhdGEgKyByb3cqeGltYWdlX3Jvd2J5dGVzOwogICAgICAgICAgICBpZiAoaW1hZ2VfY2hhbm5lbHMgPT0gMykgewogICAgICAgICAgICAgICAgZm9yIChpID0gaW1hZ2Vfd2lkdGg7ICBpID4gMDsgIC0taSkgewogICAgICAgICAgICAgICAgICAgIHJlZCAgID0gKnNyYysrOwogICAgICAgICAgICAgICAgICAgIGdyZWVuID0gKnNyYysrOwogICAgICAgICAgICAgICAgICAgIGJsdWUgID0gKnNyYysrOwojaWZkZWYgTk9fMjRCSVRfTUFTS1MKICAgICAgICAgICAgICAgICAgICBwaXhlbCA9IChyZWQgICA8PCBSU2hpZnQpIHwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIChncmVlbiA8PCBHU2hpZnQpIHwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIChibHVlICA8PCBCU2hpZnQpOwogICAgICAgICAgICAgICAgICAgIC8qIHJlY2FsbCB0aGF0IHdlIHNldCB4aW1hZ2UtPmJ5dGVfb3JkZXIgPSBNU0JGaXJzdCBhYm92ZSAqLwogICAgICAgICAgICAgICAgICAgIC8qIEdSUiBCVUc6ICB0aGlzIGFzc3VtZXMgYnBwID09IDMyLCBidXQgbWF5IGJlIDI0OiAqLwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+IDI0KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+IDE2KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+ICA4KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoIHBpeGVsICAgICAgICAmIDB4ZmYpOwojZWxzZQogICAgICAgICAgICAgICAgICAgIHJlZCAgID0gKFJTaGlmdCA8IDApPyByZWQgICA8PCAoLVJTaGlmdCkgOiByZWQgICA+PiBSU2hpZnQ7CiAgICAgICAgICAgICAgICAgICAgZ3JlZW4gPSAoR1NoaWZ0IDwgMCk/IGdyZWVuIDw8ICgtR1NoaWZ0KSA6IGdyZWVuID4+IEdTaGlmdDsKICAgICAgICAgICAgICAgICAgICBibHVlICA9IChCU2hpZnQgPCAwKT8gYmx1ZSAgPDwgKC1CU2hpZnQpIDogYmx1ZSAgPj4gQlNoaWZ0OwogICAgICAgICAgICAgICAgICAgIHBpeGVsID0gKHJlZCAmIFJNYXNrKSB8IChncmVlbiAmIEdNYXNrKSB8IChibHVlICYgQk1hc2spOwogICAgICAgICAgICAgICAgICAgIC8qIHJlY2FsbCB0aGF0IHdlIHNldCB4aW1hZ2UtPmJ5dGVfb3JkZXIgPSBNU0JGaXJzdCBhYm92ZSAqLwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+IDI0KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+IDE2KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+ICA4KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoIHBpeGVsICAgICAgICAmIDB4ZmYpOwojZW5kaWYKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfSBlbHNlIC8qIGlmIChpbWFnZV9jaGFubmVscyA9PSA0KSAqLyB7CiAgICAgICAgICAgICAgICBmb3IgKGkgPSBpbWFnZV93aWR0aDsgIGkgPiAwOyAgLS1pKSB7CiAgICAgICAgICAgICAgICAgICAgciA9ICpzcmMrKzsKICAgICAgICAgICAgICAgICAgICBnID0gKnNyYysrOwogICAgICAgICAgICAgICAgICAgIGIgPSAqc3JjKys7CiAgICAgICAgICAgICAgICAgICAgYSA9ICpzcmMrKzsKICAgICAgICAgICAgICAgICAgICBpZiAoYSA9PSAyNTUpIHsKICAgICAgICAgICAgICAgICAgICAgICAgcmVkICAgPSByOwogICAgICAgICAgICAgICAgICAgICAgICBncmVlbiA9IGc7CiAgICAgICAgICAgICAgICAgICAgICAgIGJsdWUgID0gYjsKICAgICAgICAgICAgICAgICAgICB9IGVsc2UgaWYgKGEgPT0gMCkgewogICAgICAgICAgICAgICAgICAgICAgICByZWQgICA9IGJnX3JlZDsKICAgICAgICAgICAgICAgICAgICAgICAgZ3JlZW4gPSBiZ19ncmVlbjsKICAgICAgICAgICAgICAgICAgICAgICAgYmx1ZSAgPSBiZ19ibHVlOwogICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgICAgICAgICAgICAgIC8qIHRoaXMgbWFjcm8gKGZyb20gcG5nLmgpIGNvbXBvc2l0ZXMgdGhlIGZvcmVncm91bmQKICAgICAgICAgICAgICAgICAgICAgICAgICogYW5kIGJhY2tncm91bmQgdmFsdWVzIGFuZCBwdXRzIHRoZSByZXN1bHQgaW50byB0aGUKICAgICAgICAgICAgICAgICAgICAgICAgICogZmlyc3QgYXJndW1lbnQgKi8KICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGFfY29tcG9zaXRlKHJlZCwgICByLCBhLCBiZ19yZWQpOwogICAgICAgICAgICAgICAgICAgICAgICBhbHBoYV9jb21wb3NpdGUoZ3JlZW4sIGcsIGEsIGJnX2dyZWVuKTsKICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGFfY29tcG9zaXRlKGJsdWUsICBiLCBhLCBiZ19ibHVlKTsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgcGl4ZWwgPSAocmVkICAgPDwgUlNoaWZ0KSB8CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoZ3JlZW4gPDwgR1NoaWZ0KSB8CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoYmx1ZSAgPDwgQlNoaWZ0KTsKICAgICAgICAgICAgICAgICAgICAvKiByZWNhbGwgdGhhdCB3ZSBzZXQgeGltYWdlLT5ieXRlX29yZGVyID0gTVNCRmlyc3QgYWJvdmUgKi8KICAgICAgICAgICAgICAgICAgICAqZGVzdCsrID0gKGNoYXIpKChwaXhlbCA+PiAyNCkgJiAweGZmKTsKICAgICAgICAgICAgICAgICAgICAqZGVzdCsrID0gKGNoYXIpKChwaXhlbCA+PiAxNikgJiAweGZmKTsKICAgICAgICAgICAgICAgICAgICAqZGVzdCsrID0gKGNoYXIpKChwaXhlbCA+PiAgOCkgJiAweGZmKTsKICAgICAgICAgICAgICAgICAgICAqZGVzdCsrID0gKGNoYXIpKCBwaXhlbCAgICAgICAgJiAweGZmKTsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgICAgICAvKiBkaXNwbGF5IGFmdGVyIGV2ZXJ5IDE2IGxpbmVzICovCiAgICAgICAgICAgIGlmICgoKHJvdysxKSAmIDB4ZikgPT0gMCkgewogICAgICAgICAgICAgICAgWFB1dEltYWdlKGRpc3BsYXksIHdpbmRvdywgZ2MsIHhpbWFnZSwgMCwgKGludClsYXN0cm93LCAwLAogICAgICAgICAgICAgICAgICAoaW50KWxhc3Ryb3csIGltYWdlX3dpZHRoLCAxNik7CiAgICAgICAgICAgICAgICBYRmx1c2goZGlzcGxheSk7CiAgICAgICAgICAgICAgICBsYXN0cm93ID0gcm93ICsgMTsKICAgICAgICAgICAgfQogICAgICAgIH0KCiAgICB9IGVsc2UgaWYgKGRlcHRoID09IDE2KSB7CiAgICAgICAgdXNoIHJlZCwgZ3JlZW4sIGJsdWU7CgogICAgICAgIGZvciAobGFzdHJvdyA9IHJvdyA9IDA7ICByb3cgPCBpbWFnZV9oZWlnaHQ7ICArK3JvdykgewogICAgICAgICAgICBzcmMgPSBpbWFnZV9kYXRhICsgcm93KmltYWdlX3Jvd2J5dGVzOwogICAgICAgICAgICBkZXN0ID0geGltYWdlLT5kYXRhICsgcm93KnhpbWFnZV9yb3dieXRlczsKICAgICAgICAgICAgaWYgKGltYWdlX2NoYW5uZWxzID09IDMpIHsKICAgICAgICAgICAgICAgIGZvciAoaSA9IGltYWdlX3dpZHRoOyAgaSA+IDA7ICAtLWkpIHsKICAgICAgICAgICAgICAgICAgICByZWQgICA9ICgodXNoKSgqc3JjKSA8PCA4KTsKICAgICAgICAgICAgICAgICAgICArK3NyYzsKICAgICAgICAgICAgICAgICAgICBncmVlbiA9ICgodXNoKSgqc3JjKSA8PCA4KTsKICAgICAgICAgICAgICAgICAgICArK3NyYzsKICAgICAgICAgICAgICAgICAgICBibHVlICA9ICgodXNoKSgqc3JjKSA8PCA4KTsKICAgICAgICAgICAgICAgICAgICArK3NyYzsKICAgICAgICAgICAgICAgICAgICBwaXhlbCA9ICgocmVkICAgPj4gUlNoaWZ0KSAmIFJNYXNrKSB8CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoKGdyZWVuID4+IEdTaGlmdCkgJiBHTWFzaykgfAogICAgICAgICAgICAgICAgICAgICAgICAgICAgKChibHVlICA+PiBCU2hpZnQpICYgQk1hc2spOwogICAgICAgICAgICAgICAgICAgIC8qIHJlY2FsbCB0aGF0IHdlIHNldCB4aW1hZ2UtPmJ5dGVfb3JkZXIgPSBNU0JGaXJzdCBhYm92ZSAqLwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+ICA4KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoIHBpeGVsICAgICAgICAmIDB4ZmYpOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9IGVsc2UgLyogaWYgKGltYWdlX2NoYW5uZWxzID09IDQpICovIHsKICAgICAgICAgICAgICAgIGZvciAoaSA9IGltYWdlX3dpZHRoOyAgaSA+IDA7ICAtLWkpIHsKICAgICAgICAgICAgICAgICAgICByID0gKnNyYysrOwogICAgICAgICAgICAgICAgICAgIGcgPSAqc3JjKys7CiAgICAgICAgICAgICAgICAgICAgYiA9ICpzcmMrKzsKICAgICAgICAgICAgICAgICAgICBhID0gKnNyYysrOwogICAgICAgICAgICAgICAgICAgIGlmIChhID09IDI1NSkgewogICAgICAgICAgICAgICAgICAgICAgICByZWQgICA9ICgodXNoKXIgPDwgOCk7CiAgICAgICAgICAgICAgICAgICAgICAgIGdyZWVuID0gKCh1c2gpZyA8PCA4KTsKICAgICAgICAgICAgICAgICAgICAgICAgYmx1ZSAgPSAoKHVzaCliIDw8IDgpOwogICAgICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAoYSA9PSAwKSB7CiAgICAgICAgICAgICAgICAgICAgICAgIHJlZCAgID0gKCh1c2gpYmdfcmVkICAgPDwgOCk7CiAgICAgICAgICAgICAgICAgICAgICAgIGdyZWVuID0gKCh1c2gpYmdfZ3JlZW4gPDwgOCk7CiAgICAgICAgICAgICAgICAgICAgICAgIGJsdWUgID0gKCh1c2gpYmdfYmx1ZSAgPDwgOCk7CiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgICAgICAgICAgICAgLyogdGhpcyBtYWNybyAoZnJvbSBwbmcuaCkgY29tcG9zaXRlcyB0aGUgZm9yZWdyb3VuZAogICAgICAgICAgICAgICAgICAgICAgICAgKiBhbmQgYmFja2dyb3VuZCB2YWx1ZXMgYW5kIHB1dHMgdGhlIHJlc3VsdCBiYWNrIGludG8KICAgICAgICAgICAgICAgICAgICAgICAgICogdGhlIGZpcnN0IGFyZ3VtZW50ICg9PSBmZyBieXRlIGhlcmU6ICBzYWZlKSAqLwogICAgICAgICAgICAgICAgICAgICAgICBhbHBoYV9jb21wb3NpdGUociwgciwgYSwgYmdfcmVkKTsKICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGFfY29tcG9zaXRlKGcsIGcsIGEsIGJnX2dyZWVuKTsKICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGFfY29tcG9zaXRlKGIsIGIsIGEsIGJnX2JsdWUpOwogICAgICAgICAgICAgICAgICAgICAgICByZWQgICA9ICgodXNoKXIgPDwgOCk7CiAgICAgICAgICAgICAgICAgICAgICAgIGdyZWVuID0gKCh1c2gpZyA8PCA4KTsKICAgICAgICAgICAgICAgICAgICAgICAgYmx1ZSAgPSAoKHVzaCliIDw8IDgpOwogICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICBwaXhlbCA9ICgocmVkICAgPj4gUlNoaWZ0KSAmIFJNYXNrKSB8CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAoKGdyZWVuID4+IEdTaGlmdCkgJiBHTWFzaykgfAogICAgICAgICAgICAgICAgICAgICAgICAgICAgKChibHVlICA+PiBCU2hpZnQpICYgQk1hc2spOwogICAgICAgICAgICAgICAgICAgIC8qIHJlY2FsbCB0aGF0IHdlIHNldCB4aW1hZ2UtPmJ5dGVfb3JkZXIgPSBNU0JGaXJzdCBhYm92ZSAqLwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoKHBpeGVsID4+ICA4KSAmIDB4ZmYpOwogICAgICAgICAgICAgICAgICAgICpkZXN0KysgPSAoY2hhcikoIHBpeGVsICAgICAgICAmIDB4ZmYpOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgICAgIC8qIGRpc3BsYXkgYWZ0ZXIgZXZlcnkgMTYgbGluZXMgKi8KICAgICAgICAgICAgaWYgKCgocm93KzEpICYgMHhmKSA9PSAwKSB7CiAgICAgICAgICAgICAgICBYUHV0SW1hZ2UoZGlzcGxheSwgd2luZG93LCBnYywgeGltYWdlLCAwLCAoaW50KWxhc3Ryb3csIDAsCiAgICAgICAgICAgICAgICAgIChpbnQpbGFzdHJvdywgaW1hZ2Vfd2lkdGgsIDE2KTsKICAgICAgICAgICAgICAgIFhGbHVzaChkaXNwbGF5KTsKICAgICAgICAgICAgICAgIGxhc3Ryb3cgPSByb3cgKyAxOwogICAgICAgICAgICB9CiAgICAgICAgfQoKICAgIH0gZWxzZSAvKiBkZXB0aCA9PSA4ICovIHsKCiAgICAgICAgLyogR1JSOiAgYWRkIDgtYml0IHN1cHBvcnQgKi8KCiAgICB9CgogICAgVHJhY2UoKHN0ZGVyciwgImNhbGxpbmcgZmluYWwgWFB1dEltYWdlKClcbiIpKQogICAgaWYgKGxhc3Ryb3cgPCBpbWFnZV9oZWlnaHQpIHsKICAgICAgICBYUHV0SW1hZ2UoZGlzcGxheSwgd2luZG93LCBnYywgeGltYWdlLCAwLCAoaW50KWxhc3Ryb3csIDAsCiAgICAgICAgICAoaW50KWxhc3Ryb3csIGltYWdlX3dpZHRoLCBpbWFnZV9oZWlnaHQtbGFzdHJvdyk7CiAgICAgICAgWEZsdXNoKGRpc3BsYXkpOwogICAgfQoKICAgIHJldHVybiAwOwp9CgoKCgpzdGF0aWMgdm9pZCBycG5nX3hfY2xlYW51cCh2b2lkKQp7CiAgICBpZiAoaW1hZ2VfZGF0YSkgewogICAgICAgIGZyZWUoaW1hZ2VfZGF0YSk7CiAgICAgICAgaW1hZ2VfZGF0YSA9IE5VTEw7CiAgICB9CgogICAgaWYgKHhpbWFnZSkgewogICAgICAgIGlmICh4aW1hZ2UtPmRhdGEpIHsKICAgICAgICAgICAgZnJlZSh4aW1hZ2UtPmRhdGEpOyAgICAgICAgICAgLyogd2UgYWxsb2NhdGVkIGl0LCBzbyB3ZSBmcmVlIGl0ICovCiAgICAgICAgICAgIHhpbWFnZS0+ZGF0YSA9IChjaGFyICopTlVMTDsgIC8qICBpbnN0ZWFkIG9mIFhEZXN0cm95SW1hZ2UoKSAqLwogICAgICAgIH0KICAgICAgICBYRGVzdHJveUltYWdlKHhpbWFnZSk7CiAgICAgICAgeGltYWdlID0gTlVMTDsKICAgIH0KCiAgICBpZiAoaGF2ZV9nYykKICAgICAgICBYRnJlZUdDKGRpc3BsYXksIGdjKTsKCiAgICBpZiAoaGF2ZV93aW5kb3cpCiAgICAgICAgWERlc3Ryb3lXaW5kb3coZGlzcGxheSwgd2luZG93KTsKCiAgICBpZiAoaGF2ZV9jb2xvcm1hcCkKICAgICAgICBYRnJlZUNvbG9ybWFwKGRpc3BsYXksIGNvbG9ybWFwKTsKCiAgICBpZiAoaGF2ZV9ub25kZWZhdWx0X3Zpc3VhbCkKICAgICAgICBYRnJlZSh2aXN1YWxfbGlzdCk7Cn0KCgoKCgpzdGF0aWMgaW50IHJwbmdfeF9tc2IodWxnIHUzMnZhbCkKewogICAgaW50IGk7CgogICAgZm9yIChpID0gMzE7ICBpID49IDA7ICAtLWkpIHsKICAgICAgICBpZiAodTMydmFsICYgMHg4MDAwMDAwMEwpCiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIHUzMnZhbCA8PD0gMTsKICAgIH0KICAgIHJldHVybiBpOwp9Cg==