LyoKICogQ29weXJpZ2h0IDIwMDItMjAwMyBNaWNoYWVsIEf8bm5ld2lnCiAqCiAqIFRoaXMgbGlicmFyeSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieSB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uOyBlaXRoZXIKICogdmVyc2lvbiAyLjEgb2YgdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgbGlicmFyeSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBTZWUgdGhlIEdOVQogKiBMZXNzZXIgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLgogKgogKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgTGVzc2VyIEdlbmVyYWwgUHVibGljCiAqIExpY2Vuc2UgYWxvbmcgd2l0aCB0aGlzIGxpYnJhcnk7IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUKICogRm91bmRhdGlvbiwgSW5jLiwgNTkgVGVtcGxlIFBsYWNlLCBTdWl0ZSAzMzAsIEJvc3RvbiwgTUEgIDAyMTExLTEzMDcgIFVTQQogKi8KCi8qIFRPRE86CiAqICAgLSBzb21lIGltcHJvdmVtZW50cyBwb3NzaWJsZQogKiAgIC0gaW1wbGVtZW50IERlY29tcHJlc3NTZXRQYWxldHRlPyAtLSBkb2VzIHdlIG5lZWQgaXQgZm9yIGFueXRoaW5nPwogKi8KCiNpbmNsdWRlIDxhc3NlcnQuaD4KCiNpbmNsdWRlICJtc3JsZV9wcml2YXRlLmgiCgojaW5jbHVkZSAid2lubmxzLmgiCiNpbmNsdWRlICJ3aW51c2VyLmgiCiNpbmNsdWRlICJ3aW5kb3dzeC5oIgoKI2luY2x1ZGUgIndpbmUvZGVidWcuaCIKCldJTkVfREVGQVVMVF9ERUJVR19DSEFOTkVMKG1zcmxlMzIpOwoKc3RhdGljIEhJTlNUQU5DRSBNU1JMRTMyX2hNb2R1bGUgPSAwOwoKI2RlZmluZSBBQlMoYSkgICAgICAgICAgICAgICAgKChhKSA8IDAgPyAtKGEpIDogKGEpKQojZGVmaW5lIFNRUihhKSAgICAgICAgICAgICAgICAoKGEpICogKGEpKQoKI2RlZmluZSBRVUFMSVRZX3RvX0RJU1QocSkgICAgKElDUVVBTElUWV9ISUdIIC0gcSkKaW5saW5lIFdPUkQgQ29sb3JDbXAoV09SRCBjbHIxLCBXT1JEIGNscjIpCnsKICByZWdpc3RlciBVSU5UIGEgPSAoY2xyMS1jbHIyKTsKICByZXR1cm4gU1FSKGEpOwp9CmlubGluZSBXT1JEIEludGVuc2l0eShSR0JRVUFEIGNscikKewogIHJldHVybiAoMzAgKiBjbHIucmdiUmVkICsgNTkgKiBjbHIucmdiR3JlZW4gKyAxMSAqIGNsci5yZ2JCbHVlKS80Owp9CgojZGVmaW5lIEdldFJhd1BpeGVsKGxwYmksbHAseCkgXAogICgobHBiaSktPmJpQml0Q291bnQgPT0gMSA/ICgobHApWyh4KS84XSA+PiAoOCAtICh4KSU4KSkgJiAxIDogXAogICAoKGxwYmkpLT5iaUJpdENvdW50ID09IDQgPyAoKGxwKVsoeCkvMl0gPj4gKDQgKiAoMSAtICh4KSUyKSkpICYgMTUgOiBscFt4XSkpCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgovKiB1dGlsaXR5IGZ1bmN0aW9ucyAqLwpzdGF0aWMgQk9PTCAgICBpc1N1cHBvcnRlZERJQihMUENCSVRNQVBJTkZPSEVBREVSIGxwYmkpOwpzdGF0aWMgQk9PTCAgICBpc1N1cHBvcnRlZE1STEUoTFBDQklUTUFQSU5GT0hFQURFUiBscGJpKTsKc3RhdGljIEJZVEUgICAgTVNSTEUzMl9HZXROZWFyZXN0UGFsZXR0ZUluZGV4KFVJTlQgY291bnQsIGNvbnN0IFJHQlFVQUQgKmNscnMsIFJHQlFVQUQgY2xyKTsKCi8qIGNvbXByZXNzaW9uIGZ1bmN0aW9ucyAqLwpzdGF0aWMgdm9pZCAgICBjb21wdXRlSW50ZXJuYWxGcmFtZShDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwgTFBCWVRFIGxwSW4pOwpzdGF0aWMgTE9ORyAgICBNU1JMRTMyX0dldE1heENvbXByZXNzZWRTaXplKExQQ0JJVE1BUElORk9IRUFERVIgbHBiaSk7CnN0YXRpYyBMUkVTVUxUIE1TUkxFMzJfQ29tcHJlc3NSTEU0KENvZGVjSW5mbyAqcGksIExQQklUTUFQSU5GT0hFQURFUiBscGJpSW4sIExQQllURSBscEluLCBMUEJJVE1BUElORk9IRUFERVIgbHBiaU91dCwgTFBCWVRFIGxwT3V0LCBCT09MIGlzS2V5KTsKc3RhdGljIExSRVNVTFQgTVNSTEUzMl9Db21wcmVzc1JMRTgoQ29kZWNJbmZvICpwaSwgTFBCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwgTFBCWVRFIGxwSW4sIExQQklUTUFQSU5GT0hFQURFUiBscGJpT3V0LCBMUEJZVEUgbHBPdXQsIEJPT0wgaXNLZXkpOwoKLyogZGVjb21wcmVzc2lvbiBmdW5jdGlvbnMgKi8Kc3RhdGljIExSRVNVTFQgTVNSTEUzMl9EZWNvbXByZXNzUkxFNChDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmksCgkJCQkgICAgICBMUEJZVEUgbHBJbiwgTFBCWVRFIGxwT3V0KTsKc3RhdGljIExSRVNVTFQgTVNSTEUzMl9EZWNvbXByZXNzUkxFOChDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmksCgkJCQkgICAgICBMUEJZVEUgbHBJbiwgTFBCWVRFIGxwT3V0KTsKCi8qIEFQSSBmdW5jdGlvbnMgKi8Kc3RhdGljIExSRVNVTFQgQ29tcHJlc3NHZXRGb3JtYXQoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCQkgTFBCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpOwpzdGF0aWMgTFJFU1VMVCBDb21wcmVzc0dldFNpemUoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCSAgICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpOwpzdGF0aWMgTFJFU1VMVCBDb21wcmVzc1F1ZXJ5KENvZGVjSW5mbyAqcGksIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaUluLAoJCQkgICAgIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaU91dCk7CnN0YXRpYyBMUkVTVUxUIENvbXByZXNzQmVnaW4oQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCSAgICAgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpT3V0KTsKc3RhdGljIExSRVNVTFQgQ29tcHJlc3MoQ29kZWNJbmZvICpwaSwgSUNDT01QUkVTUyogbHBpYywgRFdPUkQgZHdTaXplKTsKc3RhdGljIExSRVNVTFQgQ29tcHJlc3NFbmQoQ29kZWNJbmZvICpwaSk7CgpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzR2V0Rm9ybWF0KENvZGVjSW5mbyAqcGksIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaUluLAoJCQkJICAgTFBCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpOwpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzUXVlcnkoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCSAgICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpOwpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzQmVnaW4oQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCSAgICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpOwpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzKENvZGVjSW5mbyAqcGksIElDREVDT01QUkVTUyAqcGljLCBEV09SRCBkd1NpemUpOwpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzRW5kKENvZGVjSW5mbyAqcGkpOwpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzR2V0UGFsZXR0ZShDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwKCQkJCSAgICBMUEJJVE1BUElORk9IRUFERVIgbHBiaU91dCk7CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgpzdGF0aWMgQk9PTCBpc1N1cHBvcnRlZE1STEUoTFBDQklUTUFQSU5GT0hFQURFUiBscGJpKQp7CiAgLyogcHJlLWNvbmRpdGlvbnMgKi8KICBhc3NlcnQobHBiaSAhPSBOVUxMKTsKCiAgaWYgKGxwYmktPmJpU2l6ZSA8IHNpemVvZihCSVRNQVBJTkZPSEVBREVSKSB8fCBcCiAgICAgIGxwYmktPmJpUGxhbmVzICE9IDEpCiAgICByZXR1cm4gRkFMU0U7CgogIGlmIChscGJpLT5iaUNvbXByZXNzaW9uID09IEJJX1JMRTQpIHsKICAgIGlmIChscGJpLT5iaUJpdENvdW50ICE9IDQgfHwgXAoJKGxwYmktPmJpV2lkdGggJSAyKSAhPSAwKQogICAgICByZXR1cm4gRkFMU0U7CiAgfSBlbHNlIGlmIChscGJpLT5iaUNvbXByZXNzaW9uID09IEJJX1JMRTgpIHsKICAgIGlmIChscGJpLT5iaUJpdENvdW50ICE9IDgpCiAgICAgIHJldHVybiBGQUxTRTsKICB9IGVsc2UKICAgIHJldHVybiBGQUxTRTsKCiAgcmV0dXJuIFRSVUU7Cn0KCnN0YXRpYyBCT09MICBpc1N1cHBvcnRlZERJQihMUENCSVRNQVBJTkZPSEVBREVSIGxwYmkpCnsKICAvKiBwcmUtY29uZGl0aW9ucyAqLwogIGFzc2VydChscGJpICE9IE5VTEwpOwoKICAvKiBjaGVjayBzdHJ1Y3R1cmUgdmVyc2lvbi9wbGFuZXMvY29tcHJlc3Npb24gKi8KICBpZiAobHBiaS0+YmlTaXplIDwgc2l6ZW9mKEJJVE1BUElORk9IRUFERVIpIHx8CiAgICAgIGxwYmktPmJpUGxhbmVzICE9IDEpCiAgICByZXR1cm4gRkFMU0U7CiAgaWYgKGxwYmktPmJpQ29tcHJlc3Npb24gIT0gQklfUkdCICYmCiAgICAgIGxwYmktPmJpQ29tcHJlc3Npb24gIT0gQklfQklURklFTERTKQogICAgcmV0dXJuIEZBTFNFOwoKICAvKiBjaGVjayBiaXQtZGVwdGggKi8KICBpZiAobHBiaS0+YmlCaXRDb3VudCAhPSAxICYmCiAgICAgIGxwYmktPmJpQml0Q291bnQgIT0gNCAmJgogICAgICBscGJpLT5iaUJpdENvdW50ICE9IDggJiYKICAgICAgbHBiaS0+YmlCaXRDb3VudCAhPSAxNSAmJgogICAgICBscGJpLT5iaUJpdENvdW50ICE9IDE2ICYmCiAgICAgIGxwYmktPmJpQml0Q291bnQgIT0gMjQgJiYKICAgICAgbHBiaS0+YmlCaXRDb3VudCAhPSAzMikKICAgIHJldHVybiBGQUxTRTsKCiAgLyogY2hlY2sgZm9yIHNpemUocykgKi8KICBpZiAoIWxwYmktPmJpV2lkdGggfHwgIWxwYmktPmJpSGVpZ2h0KQogICAgcmV0dXJuIEZBTFNFOyAvKiBpbWFnZSB3aXRoIHplcm8gc2l6ZSwgbWFrZXMgbm8gc2Vuc2Ugc28gZXJyb3IgISAqLwogIGlmIChESUJXSURUSEJZVEVTKCpscGJpKSAqIChEV09SRClscGJpLT5iaUhlaWdodCA+PSAoMVVMIDw8IDMxKSAtIDEpCiAgICByZXR1cm4gRkFMU0U7IC8qIGltYWdlIHRvbyBiaWcgISAqLwoKICAvKiBjaGVjayBmb3Igbm9uZXhpc3RlbnQgY29sb3J0YWJsZSBmb3IgaGktIGFuZCB0cnVlLWNvbG9yIERJQidzICovCiAgaWYgKGxwYmktPmJpQml0Q291bnQgPj0gMTUgJiYgbHBiaS0+YmlDbHJVc2VkID4gMCkKICAgIHJldHVybiBGQUxTRTsKCiAgcmV0dXJuIFRSVUU7Cn0KCnN0YXRpYyBCWVRFIE1TUkxFMzJfR2V0TmVhcmVzdFBhbGV0dGVJbmRleChVSU5UIGNvdW50LCBjb25zdCBSR0JRVUFEICpjbHJzLCBSR0JRVUFEIGNscikKewogIElOVCAgZGlmZiA9IDB4MDBGRkZGRkY7CiAgVUlOVCBpOwogIFVJTlQgaWR4ID0gMDsKCiAgLyogcHJlLWNvbmRpdGlvbnMgKi8KICBhc3NlcnQoY2xycyAhPSBOVUxMKTsKCiAgZm9yIChpID0gMDsgaSA8IGNvdW50OyBpKyspIHsKICAgIGludCByID0gKChpbnQpY2xyc1tpXS5yZ2JSZWQgICAtIChpbnQpY2xyLnJnYlJlZCk7CiAgICBpbnQgZyA9ICgoaW50KWNscnNbaV0ucmdiR3JlZW4gLSAoaW50KWNsci5yZ2JHcmVlbik7CiAgICBpbnQgYiA9ICgoaW50KWNscnNbaV0ucmdiQmx1ZSAgLSAoaW50KWNsci5yZ2JCbHVlKTsKCiAgICByID0gcipyICsgZypnICsgYipiOwoKICAgIGlmIChyIDwgZGlmZikgewogICAgICBpZHggID0gaTsKICAgICAgZGlmZiA9IHI7CiAgICAgIGlmIChkaWZmID09IDApCglicmVhazsKICAgIH0KICB9CgogIHJldHVybiBpZHg7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCnZvaWQgY29tcHV0ZUludGVybmFsRnJhbWUoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sIExQQllURSBscEluKQp7CiAgV09SRCAgIHdJbnRlbnNpdHlUYmxbMjU2XTsKICBEV09SRCAgbEluTGluZSwgbE91dExpbmU7CiAgTFBXT1JEIGxwT3V0OwogIFVJTlQgICBpOwogIExPTkcgICB5OwoKICAvKiBwcmUtY29uZGl0aW9ucyAqLwogIGFzc2VydChwaSAhPSBOVUxMICYmIGxwYmlJbiAhPSBOVUxMICYmIGxwSW4gIT0gTlVMTCk7CiAgYXNzZXJ0KHBpLT5wQ3VyRnJhbWUgIT0gTlVMTCk7CgogIGxJbkxpbmUgID0gRElCV0lEVEhCWVRFUygqbHBiaUluKTsKICBsT3V0TGluZSA9IFdJRFRIQllURVMoKFdPUkQpbHBiaUluLT5iaVdpZHRoICogOHUgKiBzaXplb2YoV09SRCkpIC8gMnU7CiAgbHBPdXQgICAgPSBwaS0+cEN1ckZyYW1lOwoKICBhc3NlcnQobHBiaUluLT5iaUNsclVzZWQgIT0gMCk7CgogIHsKICAgIGNvbnN0IFJHQlFVQUQgKmxwID0KICAgICAgKGNvbnN0IFJHQlFVQUQgKikoKGNvbnN0IEJZVEUqKWxwYmlJbiArIGxwYmlJbi0+YmlTaXplKTsKCiAgICBmb3IgKGkgPSAwOyBpIDwgbHBiaUluLT5iaUNsclVzZWQ7IGkrKykKICAgICAgd0ludGVuc2l0eVRibFtpXSA9IEludGVuc2l0eShscFtpXSk7CiAgfQoKICBmb3IgKHkgPSAwOyB5IDwgbHBiaUluLT5iaUhlaWdodDsgeSsrKSB7CiAgICBMT05HIHg7CgogICAgc3dpdGNoIChscGJpSW4tPmJpQml0Q291bnQpIHsKICAgIGNhc2UgMToKICAgICAgZm9yICh4ID0gMDsgeCA8IGxwYmlJbi0+YmlXaWR0aCAvIDg7IHgrKykgewoJZm9yIChpID0gMDsgaSA8IDc7IGkrKykKCSAgbHBPdXRbOCAqIHggKyBpXSA9IHdJbnRlbnNpdHlUYmxbKGxwSW5beF0gPj4gKDcgLSBpKSkgJiAxXTsKICAgICAgfQogICAgICBicmVhazsKICAgIGNhc2UgNDoKICAgICAgZm9yICh4ID0gMDsgeCA8IGxwYmlJbi0+YmlXaWR0aCAvIDI7IHgrKykgewoJbHBPdXRbMiAqIHggKyAwXSA9IHdJbnRlbnNpdHlUYmxbKGxwSW5beF0gPj4gNCldOwoJbHBPdXRbMiAqIHggKyAxXSA9IHdJbnRlbnNpdHlUYmxbKGxwSW5beF0gJiAweDBGKV07CiAgICAgIH0KICAgICAgYnJlYWs7CiAgICBjYXNlIDg6CiAgICAgIGZvciAoeCA9IDA7IHggPCBscGJpSW4tPmJpV2lkdGg7IHgrKykKCWxwT3V0W3hdID0gd0ludGVuc2l0eVRibFtscEluW3hdXTsKICAgICAgYnJlYWs7CiAgICB9CgogICAgbHBJbiAgKz0gbEluTGluZTsKICAgIGxwT3V0ICs9IGxPdXRMaW5lOwogIH0KfQoKc3RhdGljIExPTkcgTVNSTEUzMl9HZXRNYXhDb21wcmVzc2VkU2l6ZShMUENCSVRNQVBJTkZPSEVBREVSIGxwYmkpCnsKICBMT05HIGEsIGIsIHNpemU7CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQobHBiaSAhPSBOVUxMKTsKCiAgYSA9IGxwYmktPmJpV2lkdGggLyAyNTU7CiAgYiA9IGxwYmktPmJpV2lkdGggJSAyNTU7CiAgaWYgKGxwYmktPmJpQml0Q291bnQgPD0gNCkgewogICAgYSAvPSAyOwogICAgYiAvPSAyOwogIH0KCiAgc2l6ZSA9ICgyICsgYSAqICgyICsgKChhICsgMikgJiB+MikpICsgYiAqICgyICsgKChiICsgMikgJiB+MikpKTsKICByZXR1cm4gc2l6ZSAqIGxwYmktPmJpSGVpZ2h0Owp9CgovKiBscFAgPT4gY3VycmVudCAgcG9zIGluIHByZXZpb3VzIGZyYW1lCiAqIGxwQSA9PiBwcmV2aW91cyBwb3MgaW4gY3VycmVudCAgZnJhbWUKICogbHBCID0+IGN1cnJlbnQgIHBvcyBpbiBjdXJyZW50ICBmcmFtZQogKi8Kc3RhdGljIElOVCBjb3VudERpZmZSTEU0KExQV09SRCBscFAsIExQV09SRCBscEEsIExQV09SRCBscEIsIElOVCBwb3MsIExPTkcgbERpc3QsIExPTkcgd2lkdGgpCnsKICBJTlQgIGNvdW50OwogIFdPUkQgY2xyMSwgY2xyMjsKCiAgLyogcHJlLWNvbmRpdGlvbnMgKi8KICBhc3NlcnQobHBBICYmIGxwQiAmJiBsRGlzdCA+PSAwICYmIHdpZHRoID4gMCk7CgogIGlmIChwb3MgPj0gd2lkdGgpCiAgICByZXR1cm4gMDsKICBpZiAocG9zKzEgPT0gd2lkdGgpCiAgICByZXR1cm4gMTsKCiAgY2xyMSA9IGxwQltwb3MrK107CiAgY2xyMiA9IGxwQltwb3NdOwoKICBjb3VudCA9IDI7CiAgd2hpbGUgKHBvcyArIDEgPCB3aWR0aCkgewogICAgV09SRCBjbHIzLCBjbHI0OwoKICAgIGNscjMgPSBscEJbKytwb3NdOwogICAgaWYgKHBvcyArIDEgPj0gd2lkdGgpCiAgICAgIHJldHVybiBjb3VudCArIDE7CgogICAgY2xyNCA9IGxwQlsrK3Bvc107CiAgICBpZiAoQ29sb3JDbXAoY2xyMSwgY2xyMykgPD0gbERpc3QgJiYKCUNvbG9yQ21wKGNscjIsIGNscjQpIDw9IGxEaXN0KSB7CiAgICAgIC8qIGRpZmYgYXQgZW5kPyAtLSBsb29rLWFoZWFkIGZvciBhdCBsZWFzdCA/PyBtb3JlIGVuY29kYWJsZSBwaXhlbHMgKi8KICAgICAgaWYgKHBvcyArIDIgPCB3aWR0aCAmJiBDb2xvckNtcChjbHIxLGxwQltwb3MrMV0pIDw9IGxEaXN0ICYmCgkgIENvbG9yQ21wKGNscjIsbHBCW3BvcysyXSkgPD0gbERpc3QpIHsKCWlmIChwb3MgKyA0IDwgd2lkdGggJiYgQ29sb3JDbXAobHBCW3BvcysxXSxscEJbcG9zKzNdKSA8PSBsRGlzdCAmJgoJICAgIENvbG9yQ21wKGxwQltwb3MrMl0sbHBCW3Bvcys0XSkgPD0gbERpc3QpCgkgIHJldHVybiBjb3VudCAtIDM7IC8qIGZvbGxvd2VkIGJ5IGF0IGxlYXN0IDQgZW5jb2RhYmxlIHBpeGVscyAqLwoJcmV0dXJuIGNvdW50IC0gMjsKICAgICAgfQogICAgfSBlbHNlIGlmIChscFAgIT0gTlVMTCAmJiBDb2xvckNtcChscFBbcG9zXSwgbHBCW3Bvc10pIDw9IGxEaXN0KSB7CiAgICAgIC8qICdjb21wYXJlJyB3aXRoIHByZXZpb3VzIGZyYW1lIGZvciBlbmQgb2YgZGlmZiAqLwogICAgICBJTlQgY291bnQyID0gMDsKCiAgICAgIC8qIEZJWE1FICovCgogICAgICBpZiAoY291bnQyID49IDgpCglyZXR1cm4gY291bnQ7CgogICAgICBwb3MgLT0gY291bnQyOwogICAgfQoKICAgIGNvdW50ICs9IDI7CiAgICBjbHIxID0gY2xyMzsKICAgIGNscjIgPSBjbHI0OwogIH0KCiAgcmV0dXJuIGNvdW50Owp9CgovKiBscFAgPT4gY3VycmVudCAgcG9zIGluIHByZXZpb3VzIGZyYW1lCiAqIGxwQSA9PiBwcmV2aW91cyBwb3MgaW4gY3VycmVudCAgZnJhbWUKICogbHBCID0+IGN1cnJlbnQgIHBvcyBpbiBjdXJyZW50ICBmcmFtZQogKi8Kc3RhdGljIElOVCBjb3VudERpZmZSTEU4KExQV09SRCBscFAsIExQV09SRCBscEEsIExQV09SRCBscEIsIElOVCBwb3MsIExPTkcgbERpc3QsIExPTkcgd2lkdGgpCnsKICBJTlQgY291bnQ7CgogIGZvciAoY291bnQgPSAwOyBwb3MgPCB3aWR0aDsgcG9zKyssIGNvdW50KyspIHsKICAgIGlmIChDb2xvckNtcChscEFbcG9zXSwgbHBCW3Bvc10pIDw9IGxEaXN0KSB7CiAgICAgIC8qIGRpZmYgYXQgZW5kPyAtLSBsb29rLWFoZWFkIGZvciBzb21lIG1vcmUgZW5jb2RhYmxlIHBpeGVsICovCiAgICAgIGlmIChwb3MgKyAxIDwgd2lkdGggJiYgQ29sb3JDbXAobHBCW3Bvc10sIGxwQltwb3MrMV0pIDw9IGxEaXN0KQoJcmV0dXJuIGNvdW50IC0gMTsKICAgICAgaWYgKHBvcyArIDIgPCB3aWR0aCAmJiBDb2xvckNtcChscEJbcG9zKzFdLCBscEJbcG9zKzJdKSA8PSBsRGlzdCkKCXJldHVybiBjb3VudCAtIDE7CiAgICB9IGVsc2UgaWYgKGxwUCAhPSBOVUxMICYmIENvbG9yQ21wKGxwUFtwb3NdLCBscEJbcG9zXSkgPD0gbERpc3QpIHsKICAgICAgLyogJ2NvbXBhcmUnIHdpdGggcHJldmlvdXMgZnJhbWUgZm9yIGVuZCBvZiBkaWZmICovCiAgICAgIElOVCBjb3VudDIgPSAwOwoKICAgICAgZm9yIChjb3VudDIgPSAwLCBwb3MrKzsgcG9zIDwgd2lkdGggJiYgY291bnQyIDw9IDU7IHBvcysrLCBjb3VudDIrKykgewoJaWYgKENvbG9yQ21wKGxwUFtwb3NdLCBscEJbcG9zXSkgPiBsRGlzdCkKCSAgYnJlYWs7CiAgICAgIH0KICAgICAgaWYgKGNvdW50MiA+IDQpCglyZXR1cm4gY291bnQ7CgogICAgICBwb3MgLT0gY291bnQyOwogICAgfQogIH0KCiAgcmV0dXJuIGNvdW50Owp9CgpzdGF0aWMgSU5UIE1TUkxFMzJfQ29tcHJlc3NSTEU0TGluZShDb2RlY0luZm8gKnBpLCBMUFdPUkQgbHBQLCBMUFdPUkQgbHBDLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmksIEJZVEUgKmxwSW4sIExPTkcgbERpc3QsIElOVCB4LCBMUEJZVEUgKnBwT3V0LCBEV09SRCAqbHBTaXplSW1hZ2UpCnsKICBMUEJZVEUgbHBPdXQgPSAqcHBPdXQ7CiAgSU5UICAgIGNvdW50LCBwb3M7CiAgV09SRCAgIGNscjEsIGNscjI7CgogIC8qIHRyeSB0byBlbmNvZGUgYXMgbWFueSBwaXhlbCBhcyBwb3NzaWJsZSAqLwogIGNvdW50ID0gMTsKICBwb3MgICA9IHg7CiAgY2xyMSAgPSBscENbcG9zKytdOwogIGlmIChwb3MgPCBscGJpLT5iaVdpZHRoKSB7CiAgICBjbHIyID0gbHBDW3Bvc107CiAgICBmb3IgKCsrY291bnQ7IHBvcyArIDEgPCBscGJpLT5iaVdpZHRoOyApIHsKICAgICAgKytwb3M7CiAgICAgIGlmIChDb2xvckNtcChjbHIxLCBscENbcG9zXSkgPiBsRGlzdCkKCWJyZWFrOwogICAgICBjb3VudCsrOwogICAgICBpZiAocG9zICsgMSA+PSBscGJpLT5iaVdpZHRoKQoJYnJlYWs7CiAgICAgICsrcG9zOwogICAgICBpZiAoQ29sb3JDbXAoY2xyMiwgbHBDW3Bvc10pID4gbERpc3QpCglicmVhazsKICAgICAgY291bnQrKzsKICAgIH0KICB9CgogIGlmIChjb3VudCA8IDQpIHsKICAgIC8qIGFkZCBzb21lIHBpeGVsIGZvciBhYnNvbHV0aW5nIGlmIHBvc3NpYmxlICovCiAgICBjb3VudCArPSBjb3VudERpZmZSTEU0KGxwUCwgbHBDIC0gMSwgbHBDLCBwb3MtMSwgbERpc3QsIGxwYmktPmJpV2lkdGgpOwoKICAgIGFzc2VydChjb3VudCA+IDApOwoKICAgIC8qIGNoZWNrIGZvciBuZWFyIGVuZCBvZiBsaW5lICovCiAgICBpZiAoeCArIGNvdW50ID4gbHBiaS0+YmlXaWR0aCkKICAgICAgY291bnQgPSBscGJpLT5iaVdpZHRoIC0geDsKCiAgICAvKiBhYnNvbHV0ZSBwaXhlbChzKSBpbiBncm91cHMgb2YgYXQgbGVhc3QgMyBhbmQgYXQgbW9zdCAyNTQgcGl4ZWxzICovCiAgICB3aGlsZSAoY291bnQgPiAyKSB7CiAgICAgIElOVCAgaTsKICAgICAgSU5UICBzaXplICAgICAgID0gbWluKGNvdW50LCAyNTQpOwogICAgICBpbnQgIGJ5dGVzICAgICAgPSAoKHNpemUgKyAxKSAmICh+MSkpIC8gMjsKICAgICAgQk9PTCBleHRyYV9ieXRlID0gYnl0ZXMgJiAweDAxOwoKICAgICAgKmxwU2l6ZUltYWdlICs9IDIgKyBieXRlcyArIGV4dHJhX2J5dGU7CiAgICAgIGFzc2VydCgoKCpscFNpemVJbWFnZSkgJSAyKSA9PSAwKTsKICAgICAgY291bnQgLT0gc2l6ZTsKICAgICAgKmxwT3V0KysgPSAwOwogICAgICAqbHBPdXQrKyA9IHNpemU7CiAgICAgIGZvciAoaSA9IDA7IGkgPCBzaXplOyBpICs9IDIpIHsKCWNscjEgPSBwaS0+cGFsZXR0ZV9tYXBbR2V0UmF3UGl4ZWwobHBiaSxscEluLHgpXTsKCXgrKzsKCWlmIChpICsgMSA8IHNpemUpIHsKCSAgY2xyMiA9IHBpLT5wYWxldHRlX21hcFtHZXRSYXdQaXhlbChscGJpLGxwSW4seCldOwoJICB4Kys7Cgl9IGVsc2UKCSAgY2xyMiA9IDA7CgoJKmxwT3V0KysgPSAoY2xyMSA8PCA0KSB8IGNscjI7CiAgICAgIH0KICAgICAgaWYgKGV4dHJhX2J5dGUpCgkqbHBPdXQrKyA9IDA7CiAgICB9CgogICAgaWYgKGNvdW50ID4gMCkgewogICAgICAvKiB0b28gbGl0dGxlIGZvciBhYnNvbHV0aW5nIHNvIHdlIG11c3QgZW5jb2RlIHRoZW0gKi8KICAgICAgYXNzZXJ0KGNvdW50IDw9IDIpOwoKICAgICAgKmxwU2l6ZUltYWdlICs9IDI7CiAgICAgIGNscjEgPSBwaS0+cGFsZXR0ZV9tYXBbR2V0UmF3UGl4ZWwobHBiaSxscEluLHgpXTsKICAgICAgeCsrOwogICAgICBpZiAoY291bnQgPT0gMikgewoJY2xyMiA9IHBpLT5wYWxldHRlX21hcFtHZXRSYXdQaXhlbChscGJpLGxwSW4seCldOwoJeCsrOwogICAgICB9IGVsc2UKCWNscjIgPSAwOwogICAgICAqbHBPdXQrKyA9IGNvdW50OwogICAgICAqbHBPdXQrKyA9IChjbHIxIDw8IDQpIHwgY2xyMjsKICAgIH0KICB9IGVsc2UgewogICAgLyogZW5jb2RlIGNvdW50IHBpeGVsKHMpICovCiAgICBjbHIxID0gKChwaS0+cGFsZXR0ZV9tYXBbR2V0UmF3UGl4ZWwobHBiaSxscEluLHgpXSA8PCA0KSB8CgkgICAgcGktPnBhbGV0dGVfbWFwW0dldFJhd1BpeGVsKGxwYmksbHBJbix4ICsgMSldKTsKCiAgICB4ICs9IGNvdW50OwogICAgd2hpbGUgKGNvdW50ID4gMCkgewogICAgICBJTlQgc2l6ZSA9IG1pbihjb3VudCwgMjU0KTsKCiAgICAgICpscFNpemVJbWFnZSArPSAyOwogICAgICBjb3VudCAgICAtPSBzaXplOwogICAgICAqbHBPdXQrKyAgPSBzaXplOwogICAgICAqbHBPdXQrKyAgPSBjbHIxOwogICAgfQogIH0KCiAgKnBwT3V0ID0gbHBPdXQ7CgogIHJldHVybiB4Owp9CgpzdGF0aWMgSU5UIE1TUkxFMzJfQ29tcHJlc3NSTEU4TGluZShDb2RlY0luZm8gKnBpLCBMUFdPUkQgbHBQLCBMUFdPUkQgbHBDLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmksIEJZVEUgKmxwSW4sIExPTkcgbERpc3QsIElOVCB4LCBMUEJZVEUgKnBwT3V0LCBEV09SRCAqbHBTaXplSW1hZ2UpCnsKICBMUEJZVEUgbHBPdXQgPSAqcHBPdXQ7CiAgSU5UICAgIGNvdW50LCBwb3M7CiAgV09SRCAgIGNscjsKCiAgYXNzZXJ0KGxwYmktPmJpQml0Q291bnQgPD0gOCk7CiAgYXNzZXJ0KGxwYmktPmJpQ29tcHJlc3Npb24gPT0gQklfUkdCKTsKCiAgLyogdHJ5IHRvIGVuY29kZSBhcyBtdWNoIGFzIHBvc3NpYmxlICovCiAgcG9zID0geDsKICBjbHIgPSBscENbcG9zKytdOwogIGZvciAoY291bnQgPSAxOyBwb3MgPCBscGJpLT5iaVdpZHRoOyBjb3VudCsrKSB7CiAgICBpZiAoQ29sb3JDbXAoY2xyLCBscENbcG9zKytdKSA+IGxEaXN0KQogICAgICBicmVhazsKICB9CgogIGlmIChjb3VudCA8IDIpIHsKICAgIC8qIGFkZCBzb21lIG1vcmUgcGl4ZWxzIGZvciBhYnNvbHV0aW5nIGlmIHBvc3NpYmxlICovCiAgICBjb3VudCArPSBjb3VudERpZmZSTEU4KGxwUCwgbHBDIC0gMSwgbHBDLCBwb3MtMSwgbERpc3QsIGxwYmktPmJpV2lkdGgpOwoKICAgIGFzc2VydChjb3VudCA+IDApOwoKICAgIC8qIGNoZWNrIGZvciBvdmVyIGVuZCBvZiBsaW5lICovCiAgICBpZiAoeCArIGNvdW50ID4gbHBiaS0+YmlXaWR0aCkKICAgICAgY291bnQgPSBscGJpLT5iaVdpZHRoIC0geDsKCiAgICAvKiBhYnNvbHV0ZSBwaXhlbChzKSBpbiBncm91cHMgb2YgYXQgbGVhc3QgMyBhbmQgYXQgbW9zdCAyNTUgcGl4ZWxzICovCiAgICB3aGlsZSAoY291bnQgPiAyKSB7CiAgICAgIElOVCAgaTsKICAgICAgSU5UICBzaXplICAgICAgID0gbWluKGNvdW50LCAyNTUpOwogICAgICBCT09MIGV4dHJhX2J5dGUgPSBzaXplICUgMjsKCiAgICAgICpscFNpemVJbWFnZSArPSAyICsgc2l6ZSArIGV4dHJhX2J5dGU7CiAgICAgIGNvdW50IC09IHNpemU7CiAgICAgICpscE91dCsrID0gMDsKICAgICAgKmxwT3V0KysgPSBzaXplOwogICAgICBmb3IgKGkgPSAwOyBpIDwgc2l6ZTsgaSsrKSB7CgkqbHBPdXQrKyA9IHBpLT5wYWxldHRlX21hcFtHZXRSYXdQaXhlbChscGJpLGxwSW4seCldOwoJeCsrOwogICAgICB9CiAgICAgIGlmIChleHRyYV9ieXRlKQoJKmxwT3V0KysgPSAwOwogICAgfQogICAgaWYgKGNvdW50ID4gMCkgewogICAgICAvKiB0b28gbGl0dGxlIGZvciBhYnNvbHV0aW5nIHNvIHdlIG11c3QgZW5jb2RlIHRoZW0gZXZlbiBpZiBpdCdzIGV4cGVuc2l2ZSEgKi8KICAgICAgYXNzZXJ0KGNvdW50IDw9IDIpOwoKICAgICAgKmxwU2l6ZUltYWdlICs9IDIgKiBjb3VudDsKICAgICAgKmxwT3V0KysgPSAxOwogICAgICAqbHBPdXQrKyA9IHBpLT5wYWxldHRlX21hcFtHZXRSYXdQaXhlbChscGJpLGxwSW4seCldOwogICAgICB4Kys7CgogICAgICBpZiAoY291bnQgPT0gMikgewoJKmxwT3V0KysgPSAxOwoJKmxwT3V0KysgPSBwaS0+cGFsZXR0ZV9tYXBbR2V0UmF3UGl4ZWwobHBiaSxscEluLHgpXTsKCXgrKzsKICAgICAgfQogICAgfQogIH0gZWxzZSB7CiAgICAvKiBlbmNvZGUgY291bnQgcGl4ZWwocykgKi8KICAgIGNsciA9IHBpLT5wYWxldHRlX21hcFtHZXRSYXdQaXhlbChscGJpLGxwSW4seCldOwoKICAgIC8qIG9wdGltaXplIGVuZCBvZiBsaW5lICovCiAgICBpZiAoeCArIGNvdW50ICsgMSA9PSBscGJpLT5iaVdpZHRoKQogICAgICBjb3VudCsrOwoKICAgIHggKz0gY291bnQ7CiAgICB3aGlsZSAoY291bnQgPiAwKSB7CiAgICAgIElOVCBzaXplID0gbWluKGNvdW50LCAyNTUpOwoKICAgICAgKmxwU2l6ZUltYWdlICs9IDI7CiAgICAgIGNvdW50ICAgIC09IHNpemU7CiAgICAgICpscE91dCsrICA9IHNpemU7CiAgICAgICpscE91dCsrICA9IGNscjsKICAgIH0KICB9CgogICpwcE91dCA9IGxwT3V0OwoKICByZXR1cm4geDsKfQoKTFJFU1VMVCBNU1JMRTMyX0NvbXByZXNzUkxFNChDb2RlY0luZm8gKnBpLCBMUEJJVE1BUElORk9IRUFERVIgbHBiaUluLCBMUEJZVEUgbHBJbiwgTFBCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQsIExQQllURSBscE91dCwgQk9PTCBpc0tleSkKewogIExQV09SRCBscEM7CiAgTE9ORyAgIGxMaW5lLCBsSW5MaW5lLCBsRGlzdDsKICBMUEJZVEUgbHBPdXRTdGFydCA9IGxwT3V0OwoKICAvKiBwcmUtY29uZGl0aW9ucyAqLwogIGFzc2VydChwaSAhPSBOVUxMICYmIGxwYmlPdXQgIT0gTlVMTCk7CiAgYXNzZXJ0KGxwSW4gIT0gTlVMTCAmJiBscE91dCAhPSBOVUxMKTsKICBhc3NlcnQocGktPnBDdXJGcmFtZSAhPSBOVUxMKTsKCiAgbHBDICAgICAgPSBwaS0+cEN1ckZyYW1lOwogIGxEaXN0ICAgID0gUVVBTElUWV90b19ESVNUKHBpLT5kd1F1YWxpdHkpOwogIGxJbkxpbmUgID0gRElCV0lEVEhCWVRFUygqbHBiaUluKTsKICBsTGluZSAgICA9IFdJRFRIQllURVMobHBiaU91dC0+YmlXaWR0aCAqIDE2KSAvIDI7CgogIGxwYmlPdXQtPmJpU2l6ZUltYWdlID0gMDsKICBpZiAoaXNLZXkpIHsKICAgIC8qIGtleWZyYW1lIC0tIGNvbnZlcnQgaW50ZXJuYWwgZnJhbWUgdG8gb3V0cHV0IGZvcm1hdCAqLwogICAgSU5UIHgsIHk7CgogICAgZm9yICh5ID0gMDsgeSA8IGxwYmlPdXQtPmJpSGVpZ2h0OyB5KyspIHsKICAgICAgeCA9IDA7CgogICAgICBkbyB7Cgl4ID0gTVNSTEUzMl9Db21wcmVzc1JMRTRMaW5lKHBpLCBOVUxMLCBscEMsIGxwYmlJbiwgbHBJbiwgbERpc3QsIHgsCgkJCQkgICAgICZscE91dCwgJmxwYmlPdXQtPmJpU2l6ZUltYWdlKTsKICAgICAgfSB3aGlsZSAoeCA8IGxwYmlPdXQtPmJpV2lkdGgpOwoKICAgICAgbHBDICAgKz0gbExpbmU7CiAgICAgIGxwSW4gICs9IGxJbkxpbmU7CgogICAgICAvKiBhZGQgRU9MIC0tIGVuZCBvZiBsaW5lICovCiAgICAgIGxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDI7CiAgICAgICooTFBXT1JEKWxwT3V0ID0gMDsKICAgICAgbHBPdXQgKz0gc2l6ZW9mKFdPUkQpOwogICAgICBhc3NlcnQobHBPdXQgPT0gKGxwT3V0U3RhcnQgKyBscGJpT3V0LT5iaVNpemVJbWFnZSkpOwogICAgfQogIH0gZWxzZSB7CiAgICAvKiBkZWx0YS1mcmFtZSAtLSBjb21wdXRlIGRlbHRhIGJldHdlZW4gbGFzdCBhbmQgdGhpcyBpbnRlcm5hbCBmcmFtZSAqLwogICAgTFBXT1JEIGxwUDsKICAgIElOVCAgICB4LCB5OwogICAgSU5UICAgIGp1bXB4LCBqdW1weTsKCiAgICBhc3NlcnQocGktPnBQcmV2RnJhbWUgIT0gTlVMTCk7CgogICAgbHBQICAgPSBwaS0+cFByZXZGcmFtZTsKICAgIGp1bXB5ID0gMDsKICAgIGp1bXB4ID0gLTE7CgogICAgZm9yICh5ID0gMDsgeSA8IGxwYmlPdXQtPmJpSGVpZ2h0OyB5KyspIHsKICAgICAgeCA9IDA7CgogICAgICBkbyB7CglJTlQgY291bnQsIHBvczsKCglpZiAoanVtcHggPT0gLTEpCgkgIGp1bXB4ID0geDsKCWZvciAoY291bnQgPSAwLCBwb3MgPSB4OyBwb3MgPCBscGJpT3V0LT5iaVdpZHRoOyBwb3MrKywgY291bnQrKykgewoJICBpZiAoQ29sb3JDbXAobHBQW3Bvc10sIGxwQ1twb3NdKSA+IGxEaXN0KQoJICAgIGJyZWFrOwoJfQoKCWlmIChwb3MgPT0gbHBiaU91dC0+YmlXaWR0aCAmJiBjb3VudCA+IDgpIHsKCSAgLyogKGNvdW50ID4gOCkgc2VjdXJlcyB0aGF0IHdlIHdpbGwgc2F2ZSBzcGFjZSAqLwoJICBqdW1weSsrOwoJICBicmVhazsKCX0gZWxzZSBpZiAoanVtcHkgfHwganVtcHggIT0gcG9zKSB7CgkgIC8qIHRpbWUgdG8ganVtcCAqLwoJICBhc3NlcnQoanVtcHggIT0gLTEpOwoKCSAgaWYgKHBvcyA8IGp1bXB4KSB7CgkgICAgLyogY2FuIG9ubHkganVtcCBpbiBwb3NpdGl2ZSBkaXJlY3Rpb24gLS0ganVtcCB1bnRpbCBFT0wsIEVPTCAqLwoJICAgIElOVCB3ID0gbHBiaU91dC0+YmlXaWR0aCAtIGp1bXB4OwoKCSAgICBhc3NlcnQoanVtcHkgPiAwKTsKCSAgICBhc3NlcnQodyA+PSA0KTsKCgkgICAganVtcHggPSAwOwoJICAgIGp1bXB5LS07CgkgICAgLyogaWYgKHcgJSAyNTUgPT0gMikgdGhlbiBlcXVhbCBjb3N0cwoJICAgICAqIGVsc2UgaWYgKHcgJSAyNTUgPCA0ICYmIHdlIGNvdWxkIGVuY29kZSBhbGwpIHRoZW4gMiBieXRlcyB0b28gZXhwZW5zaXZlCgkgICAgICogZWxzZSBpdCB3aWxsIGJlIGNoZWFwZXIKCSAgICAgKi8KCSAgICB3aGlsZSAodyA+IDApIHsKCSAgICAgIGxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDQ7CgkgICAgICAqbHBPdXQrKyA9IDA7CgkgICAgICAqbHBPdXQrKyA9IDI7CgkgICAgICAqbHBPdXQgICA9IG1pbih3LCAyNTUpOwoJICAgICAgdyAgICAgICAtPSAqbHBPdXQrKzsKCSAgICAgICpscE91dCsrID0gMDsKCSAgICB9CgkgICAgLyogYWRkIEVPTCAtLSBlbmQgb2YgbGluZSAqLwoJICAgIGxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDI7CgkgICAgKigoTFBXT1JEKWxwT3V0KSA9IDA7CgkgICAgbHBPdXQgKz0gc2l6ZW9mKFdPUkQpOwoJICB9CgoJICAvKiBGSVhNRTogaWYgKGp1bXB5ID09IDAgJiYgY291bGQgZW5jb2RlIGFsbCkgdGhlbiBqdW1wIHRvbyBleHBlbnNpdmUgKi8KCgkgIC8qIHdyaXRlIG91dCByZWFsIGp1bXAocykgKi8KCSAgd2hpbGUgKGp1bXB5IHx8IHBvcyAhPSBqdW1weCkgewoJICAgIGxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDQ7CgkgICAgKmxwT3V0KysgPSAwOwoJICAgICpscE91dCsrID0gMjsKCSAgICAqbHBPdXQgICA9IG1pbihwb3MgLSBqdW1weCwgMjU1KTsKCSAgICB4ICAgICAgICs9ICpscE91dDsKCSAgICBqdW1weCAgICs9ICpscE91dCsrOwoJICAgICpscE91dCAgID0gbWluKGp1bXB5LCAyNTUpOwoJICAgIGp1bXB5ICAgLT0gKmxwT3V0Kys7CgkgIH0KCgkgIGp1bXB5ID0gMDsKCX0KCglqdW1weCA9IC0xOwoKCWlmICh4IDwgbHBiaU91dC0+YmlXaWR0aCkgewoJICAvKiBza2lwcGVkIHRoZSAnc2FtZScgdGhpbmdzIGNvcnJlc3BvbmRpbmcgdG8gcHJldmlvdXMgZnJhbWUgKi8KCSAgeCA9IE1TUkxFMzJfQ29tcHJlc3NSTEU0TGluZShwaSwgbHBQLCBscEMsIGxwYmlJbiwgbHBJbiwgbERpc3QsIHgsCgkJCSAgICAgICAmbHBPdXQsICZscGJpT3V0LT5iaVNpemVJbWFnZSk7Cgl9CiAgICAgIH0gd2hpbGUgKHggPCBscGJpT3V0LT5iaVdpZHRoKTsKCiAgICAgIGxwUCAgICs9IGxMaW5lOwogICAgICBscEMgICArPSBsTGluZTsKICAgICAgbHBJbiAgKz0gbEluTGluZTsKCiAgICAgIGlmIChqdW1weSA9PSAwKSB7Cglhc3NlcnQoanVtcHggPT0gLTEpOwoKCS8qIGFkZCBFT0wgLS0gZW5kIG9mIGxpbmUgKi8KCWxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDI7CgkqKChMUFdPUkQpbHBPdXQpID0gMDsKICAgICAgICBscE91dCArPSBzaXplb2YoV09SRCk7Cglhc3NlcnQobHBPdXQgPT0gbHBPdXRTdGFydCArIGxwYmlPdXQtPmJpU2l6ZUltYWdlKTsKICAgICAgfQogICAgfQoKICAgIC8qIGFkZCBFT0wgLS0gd2lsbCBiZSBjaGFuZ2VkIHRvIEVPSSAqLwogICAgbHBiaU91dC0+YmlTaXplSW1hZ2UgKz0gMjsKICAgICooKExQV09SRClscE91dCkgPSAwOwogICAgbHBPdXQgKz0gc2l6ZW9mKFdPUkQpOwogIH0KCiAgLyogY2hhbmdlIEVPTCB0byBFT0kgLS0gZW5kIG9mIGltYWdlICovCiAgbHBPdXRbLTFdID0gMTsKICBhc3NlcnQobHBPdXQgPT0gKGxwT3V0U3RhcnQgKyBscGJpT3V0LT5iaVNpemVJbWFnZSkpOwoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCkxSRVNVTFQgTVNSTEUzMl9Db21wcmVzc1JMRTgoQ29kZWNJbmZvICpwaSwgTFBCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwgTFBCWVRFIGxwSW4sIExQQklUTUFQSU5GT0hFQURFUiBscGJpT3V0LCBMUEJZVEUgbHBPdXQsIEJPT0wgaXNLZXkpCnsKICBMUFdPUkQgbHBDOwogIExPTkcgICBsRGlzdCwgbEluTGluZSwgbExpbmU7CiAgTFBCWVRFIGxwT3V0U3RhcnQgPSBscE91dDsKCiAgYXNzZXJ0KHBpICE9IE5VTEwgJiYgbHBiaU91dCAhPSBOVUxMKTsKICBhc3NlcnQobHBJbiAhPSBOVUxMICYmIGxwT3V0ICE9IE5VTEwpOwogIGFzc2VydChwaS0+cEN1ckZyYW1lICE9IE5VTEwpOwoKICBscEMgICAgID0gcGktPnBDdXJGcmFtZTsKICBsRGlzdCAgID0gUVVBTElUWV90b19ESVNUKHBpLT5kd1F1YWxpdHkpOwogIGxJbkxpbmUgPSBESUJXSURUSEJZVEVTKCpscGJpSW4pOwogIGxMaW5lICAgPSBXSURUSEJZVEVTKGxwYmlPdXQtPmJpV2lkdGggKiAxNikgLyAyOwoKICBscGJpT3V0LT5iaVNpemVJbWFnZSA9IDA7CiAgaWYgKGlzS2V5KSB7CiAgICAvKiBrZXlmcmFtZSAtLSBjb252ZXJ0IGludGVybmFsIGZyYW1lIHRvIG91dHB1dCBmb3JtYXQgKi8KICAgIElOVCB4LCB5OwoKICAgIGZvciAoeSA9IDA7IHkgPCBscGJpT3V0LT5iaUhlaWdodDsgeSsrKSB7CiAgICAgIHggPSAwOwoKICAgICAgZG8gewoJeCA9IE1TUkxFMzJfQ29tcHJlc3NSTEU4TGluZShwaSwgTlVMTCwgbHBDLCBscGJpSW4sIGxwSW4sIGxEaXN0LCB4LAoJCQkgICAgICZscE91dCwgJmxwYmlPdXQtPmJpU2l6ZUltYWdlKTsKCWFzc2VydChscE91dCA9PSAobHBPdXRTdGFydCArIGxwYmlPdXQtPmJpU2l6ZUltYWdlKSk7CiAgICAgIH0gd2hpbGUgKHggPCBscGJpT3V0LT5iaVdpZHRoKTsKCiAgICAgIGxwQyAgKz0gbExpbmU7CiAgICAgIGxwSW4gKz0gbEluTGluZTsKCiAgICAgIC8qIGFkZCBFT0wgLS0gZW5kIG9mIGxpbmUgKi8KICAgICAgbHBiaU91dC0+YmlTaXplSW1hZ2UgKz0gMjsKICAgICAgKigoTFBXT1JEKWxwT3V0KSA9IDA7CiAgICAgIGxwT3V0ICs9IHNpemVvZihXT1JEKTsKICAgICAgYXNzZXJ0KGxwT3V0ID09IChscE91dFN0YXJ0ICsgbHBiaU91dC0+YmlTaXplSW1hZ2UpKTsKICAgIH0KICB9IGVsc2UgewogICAgLyogZGVsdGEtZnJhbWUgLS0gY29tcHV0ZSBkZWx0YSBiZXR3ZWVuIGxhc3QgYW5kIHRoaXMgaW50ZXJuYWwgZnJhbWUgKi8KICAgIExQV09SRCBscFA7CiAgICBJTlQgICAgeCwgeTsKICAgIElOVCAgICBqdW1weCwganVtcHk7CgogICAgYXNzZXJ0KHBpLT5wUHJldkZyYW1lICE9IE5VTEwpOwoKICAgIGxwUCAgID0gcGktPnBQcmV2RnJhbWU7CiAgICBqdW1weCA9IC0xOwogICAganVtcHkgPSAwOwoKICAgIGZvciAoeSA9IDA7IHkgPCBscGJpT3V0LT5iaUhlaWdodDsgeSsrKSB7CiAgICAgIHggPSAwOwoKICAgICAgZG8gewoJSU5UIGNvdW50LCBwb3M7CgoJaWYgKGp1bXB4ID09IC0xKQoJICBqdW1weCA9IHg7Cglmb3IgKGNvdW50ID0gMCwgcG9zID0geDsgcG9zIDwgbHBiaU91dC0+YmlXaWR0aDsgcG9zKyssIGNvdW50KyspIHsKCSAgaWYgKENvbG9yQ21wKGxwUFtwb3NdLCBscENbcG9zXSkgPiBsRGlzdCkKCSAgICBicmVhazsKCX0KCglpZiAocG9zID09IGxwYmlPdXQtPmJpV2lkdGggJiYgY291bnQgPiA0KSB7CgkgIC8qIChjb3VudCA+IDQpIHNlY3VyZXMgdGhhdCB3ZSB3aWxsIHNhdmUgc3BhY2UgKi8KCSAganVtcHkrKzsKCSAgYnJlYWs7Cgl9IGVsc2UgaWYgKGp1bXB5IHx8IGp1bXB4ICE9IHBvcykgewoJICAvKiB0aW1lIHRvIGp1bXAgKi8KCSAgYXNzZXJ0KGp1bXB4ICE9IC0xKTsKCgkgIGlmIChwb3MgPCBqdW1weCkgewoJICAgIC8qIGNhbiBvbmx5IGp1bXAgaW4gcG9zaXRpdmUgZGlyZWN0aW9uIC0tIGRvIGFuIEVPTCB0aGVuIGp1bXAgKi8KCSAgICBhc3NlcnQoanVtcHkgPiAwKTsKCgkgICAganVtcHggPSAwOwoJICAgIGp1bXB5LS07CgoJICAgIC8qIGFkZCBFT0wgLS0gZW5kIG9mIGxpbmUgKi8KCSAgICBscGJpT3V0LT5iaVNpemVJbWFnZSArPSAyOwoJICAgICooKExQV09SRClscE91dCkgPSAwOwoJICAgIGxwT3V0ICs9IHNpemVvZihXT1JEKTsKCSAgICBhc3NlcnQobHBPdXQgPT0gKGxwT3V0U3RhcnQgKyBscGJpT3V0LT5iaVNpemVJbWFnZSkpOwoJICB9CgoJICAvKiBGSVhNRTogaWYgKGp1bXB5ID09IDAgJiYgY291bGQgZW5jb2RlIGFsbCkgdGhlbiBqdW1wIHRvbyBleHBlbnNpdmUgKi8KCgkgIC8qIHdyaXRlIG91dCByZWFsIGp1bXAocykgKi8KCSAgd2hpbGUgKGp1bXB5IHx8IHBvcyAhPSBqdW1weCkgewoJICAgIGxwYmlPdXQtPmJpU2l6ZUltYWdlICs9IDQ7CgkgICAgKmxwT3V0KysgPSAwOwoJICAgICpscE91dCsrID0gMjsKCSAgICAqbHBPdXQgICA9IG1pbihwb3MgLSBqdW1weCwgMjU1KTsKCSAgICBqdW1weCAgICs9ICpscE91dCsrOwoJICAgICpscE91dCAgID0gbWluKGp1bXB5LCAyNTUpOwoJICAgIGp1bXB5ICAgLT0gKmxwT3V0Kys7CgkgIH0KCSAgeCA9IHBvczsKCgkgIGp1bXB5ID0gMDsKCX0KCglqdW1weCA9IC0xOwoKCWlmICh4IDwgbHBiaU91dC0+YmlXaWR0aCkgewoJICAvKiBza2lwIHRoZSAnc2FtZScgdGhpbmdzIGNvcnJlc3BvbmRpbmcgdG8gcHJldmlvdXMgZnJhbWUgKi8KCSAgeCA9IE1TUkxFMzJfQ29tcHJlc3NSTEU4TGluZShwaSwgbHBQLCBscEMsIGxwYmlJbiwgbHBJbiwgbERpc3QsIHgsCgkJCSAgICAgICAmbHBPdXQsICZscGJpT3V0LT5iaVNpemVJbWFnZSk7CgkgIGFzc2VydChscE91dCA9PSAobHBPdXRTdGFydCArIGxwYmlPdXQtPmJpU2l6ZUltYWdlKSk7Cgl9CiAgICAgIH0gd2hpbGUgKHggPCBscGJpT3V0LT5iaVdpZHRoKTsKCiAgICAgIGxwUCAgKz0gbExpbmU7CiAgICAgIGxwQyAgKz0gbExpbmU7CiAgICAgIGxwSW4gKz0gbEluTGluZTsKCiAgICAgIGlmIChqdW1weSA9PSAwKSB7CgkvKiBhZGQgRU9MIC0tIGVuZCBvZiBsaW5lICovCglscGJpT3V0LT5iaVNpemVJbWFnZSArPSAyOwoJKigoTFBXT1JEKWxwT3V0KSA9IDA7CglscE91dCArPSBzaXplb2YoV09SRCk7Cglhc3NlcnQobHBPdXQgPT0gKGxwT3V0U3RhcnQgKyBscGJpT3V0LT5iaVNpemVJbWFnZSkpOwogICAgICB9CiAgICB9CgogICAgLyogYWRkIEVPTCAtLSB3aWxsIGJlIGNoYW5nZWQgdG8gRU9JICovCiAgICBscGJpT3V0LT5iaVNpemVJbWFnZSArPSAyOwogICAgKigoTFBXT1JEKWxwT3V0KSA9IDA7CiAgICBscE91dCArPSBzaXplb2YoV09SRCk7CiAgfQoKICAvKiBjaGFuZ2UgRU9MIHRvIEVPSSAtLSBlbmQgb2YgaW1hZ2UgKi8KICBscE91dFstMV0gPSAxOwogIGFzc2VydChscE91dCA9PSAobHBPdXRTdGFydCArIGxwYmlPdXQtPmJpU2l6ZUltYWdlKSk7CgogIHJldHVybiBJQ0VSUl9PSzsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKc3RhdGljIExSRVNVTFQgTVNSTEUzMl9EZWNvbXByZXNzUkxFNChDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmksCgkJCQkgICAgICBMUEJZVEUgbHBJbiwgTFBCWVRFIGxwT3V0KQp7CiAgaW50ICBieXRlc19wZXJfcGl4ZWw7CiAgaW50ICBsaW5lX3NpemU7CiAgaW50ICBwaXhlbF9wdHIgID0gMDsKICBpbnQgIGk7CiAgQk9PTCBiRW5kRmxhZyAgID0gRkFMU0U7CgogIGFzc2VydChwaSAhPSBOVUxMKTsKICBhc3NlcnQobHBiaSAhPSBOVUxMICYmIGxwYmktPmJpQ29tcHJlc3Npb24gPT0gQklfUkdCKTsKICBhc3NlcnQobHBJbiAhPSBOVUxMICYmIGxwT3V0ICE9IE5VTEwpOwoKICBieXRlc19wZXJfcGl4ZWwgPSAobHBiaS0+YmlCaXRDb3VudCArIDEpIC8gODsKICBsaW5lX3NpemUgICAgICAgPSBESUJXSURUSEJZVEVTKCpscGJpKTsKCiAgZG8gewogICAgQllURSBjb2RlMCwgY29kZTE7CgogICAgY29kZTAgPSAqbHBJbisrOwogICAgY29kZTEgPSAqbHBJbisrOwoKICAgIGlmIChjb2RlMCA9PSAwKSB7CiAgICAgIGludCAgZXh0cmFfYnl0ZTsKCiAgICAgIHN3aXRjaCAoY29kZTEpIHsKICAgICAgY2FzZSAgMDogLyogRU9MIC0gZW5kIG9mIGxpbmUgICovCglwaXhlbF9wdHIgPSAwOwoJbHBPdXQgKz0gbGluZV9zaXplOwoJYnJlYWs7CiAgICAgIGNhc2UgIDE6IC8qIEVPSSAtIGVuZCBvZiBpbWFnZSAqLwoJYkVuZEZsYWcgPSBUUlVFOwoJYnJlYWs7CiAgICAgIGNhc2UgIDI6IC8qIHNraXAgKi8KCXBpeGVsX3B0ciArPSAqbHBJbisrICogYnl0ZXNfcGVyX3BpeGVsOwoJbHBPdXQgICAgICs9ICpscEluKysgKiBsaW5lX3NpemU7CglpZiAocGl4ZWxfcHRyID49IGxwYmktPmJpV2lkdGggKiBieXRlc19wZXJfcGl4ZWwpIHsKCSAgcGl4ZWxfcHRyID0gMDsKCSAgbHBPdXQgICAgKz0gbGluZV9zaXplOwoJfQoJYnJlYWs7CiAgICAgIGRlZmF1bHQ6IC8qIGFic29sdXRlIG1vZGUgKi8KCWV4dHJhX2J5dGUgPSAoKChjb2RlMSArIDEpICYgKH4xKSkgLyAyKSAmIDB4MDE7CgoJaWYgKHBpeGVsX3B0ci9ieXRlc19wZXJfcGl4ZWwgKyBjb2RlMSA+IGxwYmktPmJpV2lkdGgpCgkgIHJldHVybiBJQ0VSUl9FUlJPUjsKCgljb2RlMCA9IGNvZGUxOwoJZm9yIChpID0gMDsgaSA8IGNvZGUwIC8gMjsgaSsrKSB7CgkgIGlmIChieXRlc19wZXJfcGl4ZWwgPT0gMSkgewoJICAgIGNvZGUxID0gbHBJbltpXTsKCSAgICBscE91dFtwaXhlbF9wdHIrK10gPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxID4+IDQpXTsKCSAgICBpZiAoMiAqIGkgKyAxIDw9IGNvZGUwKQoJICAgICAgbHBPdXRbcGl4ZWxfcHRyKytdID0gcGktPnBhbGV0dGVfbWFwWyhjb2RlMSAmIDB4MEYpXTsKCSAgfSBlbHNlIGlmIChieXRlc19wZXJfcGl4ZWwgPT0gMikgewoJICAgIGNvZGUxID0gbHBJbltpXSA+PiA0OwoJICAgIGxwT3V0W3BpeGVsX3B0cisrXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDIgKyAwXTsKCSAgICBscE91dFtwaXhlbF9wdHIrK10gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiAyICsgMV07CgoJICAgIGlmICgyICogaSArIDEgPD0gY29kZTApIHsKCSAgICAgIGNvZGUxID0gbHBJbltpXSAmIDB4MEY7CgkgICAgICBscE91dFtwaXhlbF9wdHIrK10gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiAyICsgMF07CgkgICAgICBscE91dFtwaXhlbF9wdHIrK10gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiAyICsgMV07CgkgICAgfQoJICB9IGVsc2UgewoJICAgIGNvZGUxID0gbHBJbltpXSA+PiA0OwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDBdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDBdOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDFdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDFdOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDJdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDJdOwoJICAgIHBpeGVsX3B0ciArPSBieXRlc19wZXJfcGl4ZWw7CgoJICAgIGlmICgyICogaSArIDEgPD0gY29kZTApIHsKCSAgICAgIGNvZGUxID0gbHBJbltpXSAmIDB4MEY7CgkgICAgICBscE91dFtwaXhlbF9wdHIgKyAwXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAwXTsKCSAgICAgIGxwT3V0W3BpeGVsX3B0ciArIDFdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDFdOwoJICAgICAgbHBPdXRbcGl4ZWxfcHRyICsgMl0gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiA0ICsgMl07CgkgICAgICBwaXhlbF9wdHIgKz0gYnl0ZXNfcGVyX3BpeGVsOwoJICAgIH0KCSAgfQoJfQoJaWYgKGNvZGUwICYgMHgwMSkgewoJICBpZiAoYnl0ZXNfcGVyX3BpeGVsID09IDEpIHsKCSAgICBjb2RlMSA9IGxwSW5baV07CgkgICAgbHBPdXRbcGl4ZWxfcHRyKytdID0gcGktPnBhbGV0dGVfbWFwWyhjb2RlMSA+PiA0KV07CgkgIH0gZWxzZSBpZiAoYnl0ZXNfcGVyX3BpeGVsID09IDIpIHsKCSAgICBjb2RlMSA9IGxwSW5baV0gPj4gNDsKCSAgICBscE91dFtwaXhlbF9wdHIrK10gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiAyICsgMF07CgkgICAgbHBPdXRbcGl4ZWxfcHRyKytdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogMiArIDFdOwoJICB9IGVsc2UgewoJICAgIGNvZGUxID0gbHBJbltpXSA+PiA0OwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDBdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDBdOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDFdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDFdOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDJdID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxICogNCArIDJdOwoJICAgIHBpeGVsX3B0ciArPSBieXRlc19wZXJfcGl4ZWw7CgkgIH0KCSAgbHBJbisrOwoJfQoJbHBJbiArPSBjb2RlMCAvIDI7CgoJLyogaWYgdGhlIFJMRSBjb2RlIGlzIG9kZCwgc2tpcCBhIGJ5dGUgaW4gdGhlIHN0cmVhbSAqLwoJaWYgKGV4dHJhX2J5dGUpCgkgIGxwSW4rKzsKICAgICAgfTsKICAgIH0gZWxzZSB7CiAgICAgIC8qIGNvZGVkIG1vZGUgKi8KICAgICAgaWYgKHBpeGVsX3B0ci9ieXRlc19wZXJfcGl4ZWwgKyBjb2RlMCA+IGxwYmktPmJpV2lkdGgpCglyZXR1cm4gSUNFUlJfRVJST1I7CgogICAgICBpZiAoYnl0ZXNfcGVyX3BpeGVsID09IDEpIHsKCUJZVEUgYzEgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxID4+IDQpXTsKCUJZVEUgYzIgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxICYgMHgwRildOwoKCWZvciAoaSA9IDA7IGkgPCBjb2RlMDsgaSsrKSB7CgkgIGlmICgoaSAmIDEpID09IDApCgkgICAgbHBPdXRbcGl4ZWxfcHRyKytdID0gYzE7CgkgIGVsc2UKCSAgICBscE91dFtwaXhlbF9wdHIrK10gPSBjMjsKCX0KICAgICAgfSBlbHNlIGlmIChieXRlc19wZXJfcGl4ZWwgPT0gMikgewoJQllURSBoaTEgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxID4+IDQpICogMiArIDBdOwoJQllURSBsbzEgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxID4+IDQpICogMiArIDFdOwoKCUJZVEUgaGkyID0gcGktPnBhbGV0dGVfbWFwWyhjb2RlMSAmIDB4MEYpICogMiArIDBdOwoJQllURSBsbzIgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxICYgMHgwRikgKiAyICsgMV07CgoJZm9yIChpID0gMDsgaSA8IGNvZGUwOyBpKyspIHsKCSAgaWYgKChpICYgMSkgPT0gMCkgewoJICAgIGxwT3V0W3BpeGVsX3B0cisrXSA9IGhpMTsKCSAgICBscE91dFtwaXhlbF9wdHIrK10gPSBsbzE7CgkgIH0gZWxzZSB7CgkgICAgbHBPdXRbcGl4ZWxfcHRyKytdID0gaGkyOwoJICAgIGxwT3V0W3BpeGVsX3B0cisrXSA9IGxvMjsKCSAgfQoJfQogICAgICB9IGVsc2UgewoJQllURSBiMSA9IHBpLT5wYWxldHRlX21hcFsoY29kZTEgPj4gNCkgKiA0ICsgMF07CglCWVRFIGcxID0gcGktPnBhbGV0dGVfbWFwWyhjb2RlMSA+PiA0KSAqIDQgKyAxXTsKCUJZVEUgcjEgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxID4+IDQpICogNCArIDJdOwoKCUJZVEUgYjIgPSBwaS0+cGFsZXR0ZV9tYXBbKGNvZGUxICYgMHgwRikgKiA0ICsgMF07CglCWVRFIGcyID0gcGktPnBhbGV0dGVfbWFwWyhjb2RlMSAmIDB4MEYpICogNCArIDFdOwoJQllURSByMiA9IHBpLT5wYWxldHRlX21hcFsoY29kZTEgJiAweDBGKSAqIDQgKyAyXTsKCglmb3IgKGkgPSAwOyBpIDwgY29kZTA7IGkrKykgewoJICBpZiAoKGkgJiAxKSA9PSAwKSB7CgkgICAgbHBPdXRbcGl4ZWxfcHRyICsgMF0gPSBiMTsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAxXSA9IGcxOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDJdID0gcjE7CgkgIH0gZWxzZSB7CgkgICAgbHBPdXRbcGl4ZWxfcHRyICsgMF0gPSBiMjsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAxXSA9IGcyOwoJICAgIGxwT3V0W3BpeGVsX3B0ciArIDJdID0gcjI7CgkgIH0KCSAgcGl4ZWxfcHRyICs9IGJ5dGVzX3Blcl9waXhlbDsKCX0KICAgICAgfQogICAgfQogIH0gd2hpbGUgKCEgYkVuZEZsYWcpOwoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIE1TUkxFMzJfRGVjb21wcmVzc1JMRTgoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpLAoJCQkJICAgICAgTFBCWVRFIGxwSW4sIExQQllURSBscE91dCkKewogIGludCAgYnl0ZXNfcGVyX3BpeGVsOwogIGludCAgbGluZV9zaXplOwogIGludCAgcGl4ZWxfcHRyICA9IDA7CiAgQk9PTCBiRW5kRmxhZyAgID0gRkFMU0U7CgogIGFzc2VydChwaSAhPSBOVUxMKTsKICBhc3NlcnQobHBiaSAhPSBOVUxMICYmIGxwYmktPmJpQ29tcHJlc3Npb24gPT0gQklfUkdCKTsKICBhc3NlcnQobHBJbiAhPSBOVUxMICYmIGxwT3V0ICE9IE5VTEwpOwoKICBieXRlc19wZXJfcGl4ZWwgPSAobHBiaS0+YmlCaXRDb3VudCArIDEpIC8gODsKICBsaW5lX3NpemUgICAgICAgPSBESUJXSURUSEJZVEVTKCpscGJpKTsKCiAgZG8gewogICAgQllURSBjb2RlMCwgY29kZTE7CgogICAgY29kZTAgPSAqbHBJbisrOwogICAgY29kZTEgPSAqbHBJbisrOwoKICAgIGlmIChjb2RlMCA9PSAwKSB7CiAgICAgIGludCAgZXh0cmFfYnl0ZTsKCiAgICAgIHN3aXRjaCAoY29kZTEpIHsKICAgICAgY2FzZSAgMDogLyogRU9MIC0gZW5kIG9mIGxpbmUgICovCglwaXhlbF9wdHIgPSAwOwoJbHBPdXQgKz0gbGluZV9zaXplOwoJYnJlYWs7CiAgICAgIGNhc2UgIDE6IC8qIEVPSSAtIGVuZCBvZiBpbWFnZSAqLwoJYkVuZEZsYWcgPSBUUlVFOwoJYnJlYWs7CiAgICAgIGNhc2UgIDI6IC8qIHNraXAgKi8KCXBpeGVsX3B0ciArPSAqbHBJbisrICogYnl0ZXNfcGVyX3BpeGVsOwoJbHBPdXQgICAgICs9ICpscEluKysgKiBsaW5lX3NpemU7CglpZiAocGl4ZWxfcHRyID49IGxwYmktPmJpV2lkdGggKiBieXRlc19wZXJfcGl4ZWwpIHsKCSAgcGl4ZWxfcHRyID0gMDsKCSAgbHBPdXQgICAgKz0gbGluZV9zaXplOwoJfQoJYnJlYWs7CiAgICAgIGRlZmF1bHQ6IC8qIGFic29sdXRlIG1vZGUgKi8KCWlmIChwaXhlbF9wdHIvYnl0ZXNfcGVyX3BpeGVsICsgY29kZTEgPiBscGJpLT5iaVdpZHRoKSB7CgkgIFdBUk4oImFib3J0ZWQgYWJzb2x1dGU6ICglZD0lZC8lZCslZCkgPiAlbGRcbiIscGl4ZWxfcHRyL2J5dGVzX3Blcl9waXhlbCArIGNvZGUxLHBpeGVsX3B0cixieXRlc19wZXJfcGl4ZWwsY29kZTEsbHBiaS0+YmlXaWR0aCk7CgkgIHJldHVybiBJQ0VSUl9FUlJPUjsKCX0KCWV4dHJhX2J5dGUgPSBjb2RlMSAmIDB4MDE7CgoJY29kZTAgPSBjb2RlMTsKCXdoaWxlIChjb2RlMC0tKSB7CgkgIGNvZGUxID0gKmxwSW4rKzsKCSAgaWYgKGJ5dGVzX3Blcl9waXhlbCA9PSAxKSB7CgkgICAgbHBPdXRbcGl4ZWxfcHRyXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMV07CgkgIH0gZWxzZSBpZiAoYnl0ZXNfcGVyX3BpeGVsID09IDIpIHsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAwXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDIgKyAwXTsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAxXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDIgKyAxXTsKCSAgfSBlbHNlIHsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAwXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAwXTsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAxXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAxXTsKCSAgICBscE91dFtwaXhlbF9wdHIgKyAyXSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAyXTsKCSAgfQoJICBwaXhlbF9wdHIgKz0gYnl0ZXNfcGVyX3BpeGVsOwoJfQoKCS8qIGlmIHRoZSBSTEUgY29kZSBpcyBvZGQsIHNraXAgYSBieXRlIGluIHRoZSBzdHJlYW0gKi8KCWlmIChleHRyYV9ieXRlKQoJICBscEluKys7CiAgICAgIH07CiAgICB9IGVsc2UgewogICAgICAvKiBjb2RlZCBtb2RlICovCiAgICAgIGlmIChwaXhlbF9wdHIvYnl0ZXNfcGVyX3BpeGVsICsgY29kZTAgPiBscGJpLT5iaVdpZHRoKSB7CglXQVJOKCJhYm9ydGVkIGNvZGVkOiAoJWQ9JWQvJWQrJWQpID4gJWxkXG4iLHBpeGVsX3B0ci9ieXRlc19wZXJfcGl4ZWwgKyBjb2RlMSxwaXhlbF9wdHIsYnl0ZXNfcGVyX3BpeGVsLGNvZGUxLGxwYmktPmJpV2lkdGgpOwoJcmV0dXJuIElDRVJSX0VSUk9SOwogICAgICB9CgogICAgICBpZiAoYnl0ZXNfcGVyX3BpeGVsID09IDEpIHsKCWNvZGUxID0gcGktPnBhbGV0dGVfbWFwW2NvZGUxXTsKCXdoaWxlIChjb2RlMC0tKQoJICBscE91dFtwaXhlbF9wdHIrK10gPSBjb2RlMTsKICAgICAgfSBlbHNlIGlmIChieXRlc19wZXJfcGl4ZWwgPT0gMikgewoJQllURSBoaSA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDIgKyAwXTsKCUJZVEUgbG8gPSBwaS0+cGFsZXR0ZV9tYXBbY29kZTEgKiAyICsgMV07CgoJd2hpbGUgKGNvZGUwLS0pIHsKCSAgbHBPdXRbcGl4ZWxfcHRyICsgMF0gPSBoaTsKCSAgbHBPdXRbcGl4ZWxfcHRyICsgMV0gPSBsbzsKCSAgcGl4ZWxfcHRyICs9IGJ5dGVzX3Blcl9waXhlbDsKCX0KICAgICAgfSBlbHNlIHsKCUJZVEUgciA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAyXTsKCUJZVEUgZyA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAxXTsKCUJZVEUgYiA9IHBpLT5wYWxldHRlX21hcFtjb2RlMSAqIDQgKyAwXTsKCgl3aGlsZSAoY29kZTAtLSkgewoJICBscE91dFtwaXhlbF9wdHIgKyAwXSA9IGI7CgkgIGxwT3V0W3BpeGVsX3B0ciArIDFdID0gZzsKCSAgbHBPdXRbcGl4ZWxfcHRyICsgMl0gPSByOwoJICBwaXhlbF9wdHIgKz0gYnl0ZXNfcGVyX3BpeGVsOwoJfQogICAgICB9CiAgICB9CiAgfSB3aGlsZSAoISBiRW5kRmxhZyk7CgogIHJldHVybiBJQ0VSUl9PSzsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKc3RhdGljIENvZGVjSW5mbyogT3BlbihMUElDT1BFTiBpY2luZm8pCnsKICBDb2RlY0luZm8qIHBpID0gTlVMTDsKCiAgaWYgKGljaW5mbyA9PSBOVUxMKSB7CiAgICBUUkFDRSgiKE5VTEwpXG4iKTsKICAgIHJldHVybiAoTFBWT0lEKTB4RkZGRjAwMDA7CiAgfQoKICBUUkFDRSgiKCVwID0geyVsdSwweCUwOGxYKCU0LjRzKSwweCUwOGxYKCU0LjRzKSwweCVsWCwweCVsWCwuLi59KVxuIiwgaWNpbmZvLAoJaWNpbmZvLT5kd1NpemUsCWljaW5mby0+ZmNjVHlwZSwgKGNoYXIqKSZpY2luZm8tPmZjY1R5cGUsCglpY2luZm8tPmZjY0hhbmRsZXIsIChjaGFyKikmaWNpbmZvLT5mY2NIYW5kbGVyLAoJaWNpbmZvLT5kd1ZlcnNpb24saWNpbmZvLT5kd0ZsYWdzKTsKCiAgc3dpdGNoIChpY2luZm8tPmZjY0hhbmRsZXIpIHsKICBjYXNlIEZPVVJDQ19STEU6CiAgY2FzZSBGT1VSQ0NfUkxFNDoKICBjYXNlIEZPVVJDQ19STEU4OgogIGNhc2UgRk9VUkNDX01STEU6CiAgICBicmVhazsKICBjYXNlIG1taW9GT1VSQ0MoJ20nLCdyJywnbCcsJ2UnKToKICAgIGljaW5mby0+ZmNjSGFuZGxlciA9IEZPVVJDQ19NUkxFOwogICAgYnJlYWs7CiAgZGVmYXVsdDoKICAgIFdBUk4oInVua25vd24gRk9VUkNDID0gMHglMDhsWCglNC40cykgIVxuIiwKCSBpY2luZm8tPmZjY0hhbmRsZXIsKGNoYXIqKSZpY2luZm8tPmZjY0hhbmRsZXIpOwogICAgcmV0dXJuIE5VTEw7CiAgfQoKICBwaSA9IChDb2RlY0luZm8qKUxvY2FsQWxsb2MoTFBUUiwgc2l6ZW9mKENvZGVjSW5mbykpOwoKICBpZiAocGkgIT0gTlVMTCkgewogICAgcGktPmZjY0hhbmRsZXIgID0gaWNpbmZvLT5mY2NIYW5kbGVyOwoKICAgIHBpLT5iQ29tcHJlc3MgICA9IEZBTFNFOwogICAgcGktPmR3UXVhbGl0eSAgID0gTVNSTEUzMl9ERUZBVUxUUVVBTElUWTsKICAgIHBpLT5uUHJldkZyYW1lICA9IC0xOwogICAgcGktPnBQcmV2RnJhbWUgID0gcGktPnBDdXJGcmFtZSA9IE5VTEw7CgogICAgcGktPmJEZWNvbXByZXNzID0gRkFMU0U7CiAgICBwaS0+cGFsZXR0ZV9tYXAgPSBOVUxMOwogIH0KCiAgaWNpbmZvLT5kd0Vycm9yID0gKHBpICE9IE5VTEwgPyBJQ0VSUl9PSyA6IElDRVJSX01FTU9SWSk7CgogIHJldHVybiBwaTsKfQoKc3RhdGljIExSRVNVTFQgQ2xvc2UoQ29kZWNJbmZvICpwaSkKewogIFRSQUNFKCIoJXApXG4iLCBwaSk7CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIGlmIChwaS0+cFByZXZGcmFtZSAhPSBOVUxMIHx8IHBpLT5wQ3VyRnJhbWUgIT0gTlVMTCkKICAgIENvbXByZXNzRW5kKHBpKTsKCiAgTG9jYWxGcmVlKChITE9DQUwpcGkpOwogIHJldHVybiAxOwp9CgpzdGF0aWMgTFJFU1VMVCBHZXRJbmZvKENvZGVjSW5mbyAqcGksIElDSU5GTyAqaWNpbmZvLCBEV09SRCBkd1NpemUpCnsKICAvKiBwcmUtY29uZGl0aW9uICovCiAgYXNzZXJ0KHBpICE9IE5VTEwpOwoKICAvKiBjaGVjayBwYXJhbWV0ZXJzICovCiAgaWYgKGljaW5mbyA9PSBOVUxMKQogICAgcmV0dXJuIHNpemVvZihJQ0lORk8pOwogIGlmIChkd1NpemUgPCBzaXplb2YoSUNJTkZPKSkKICAgIHJldHVybiAwOwoKICBpY2luZm8tPmR3U2l6ZSAgICAgICA9IHNpemVvZihJQ0lORk8pOwogIGljaW5mby0+ZmNjVHlwZSAgICAgID0gSUNUWVBFX1ZJREVPOwogIGljaW5mby0+ZmNjSGFuZGxlciAgID0gKHBpICE9IE5VTEwgPyBwaS0+ZmNjSGFuZGxlciA6IEZPVVJDQ19NUkxFKTsKICBpY2luZm8tPmR3RmxhZ3MgICAgICA9IFZJRENGX1FVQUxJVFkgfCBWSURDRl9URU1QT1JBTCB8IFZJRENGX0NSVU5DSCB8IFZJRENGX0ZBU1RURU1QT1JBTEM7CiAgaWNpbmZvLT5kd1ZlcnNpb24gICAgPSBJQ1ZFUlNJT047CiAgaWNpbmZvLT5kd1ZlcnNpb25JQ00gPSBJQ1ZFUlNJT047CgogIExvYWRTdHJpbmdXKE1TUkxFMzJfaE1vZHVsZSwgSURTX05BTUUsIGljaW5mby0+c3pOYW1lLCBzaXplb2YoaWNpbmZvLT5zek5hbWUpL3NpemVvZihXQ0hBUikpOwogIExvYWRTdHJpbmdXKE1TUkxFMzJfaE1vZHVsZSwgSURTX0RFU0NSSVBUSU9OLCBpY2luZm8tPnN6RGVzY3JpcHRpb24sIHNpemVvZihpY2luZm8tPnN6RGVzY3JpcHRpb24pL3NpemVvZihXQ0hBUikpOwoKICByZXR1cm4gc2l6ZW9mKElDSU5GTyk7Cn0KCnN0YXRpYyBMUkVTVUxUIFNldFF1YWxpdHkoQ29kZWNJbmZvICpwaSwgTE9ORyBsUXVhbGl0eSkKewogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIGlmIChsUXVhbGl0eSA9PSAtMSkKICAgIGxRdWFsaXR5ID0gTVNSTEUzMl9ERUZBVUxUUVVBTElUWTsKICBlbHNlIGlmIChJQ1FVQUxJVFlfTE9XID4gbFF1YWxpdHkgfHwgbFF1YWxpdHkgPiBJQ1FVQUxJVFlfSElHSCkKICAgIHJldHVybiBJQ0VSUl9CQURQQVJBTTsKCiAgcGktPmR3UXVhbGl0eSA9IChEV09SRClsUXVhbGl0eTsKCiAgcmV0dXJuIElDRVJSX09LOwp9CgpzdGF0aWMgTFJFU1VMVCBDb25maWd1cmUoQ29kZWNJbmZvICpwaSwgSFdORCBoV25kKQp7CiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgLyogRklYTUUgKi8KICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIEFib3V0KENvZGVjSW5mbyAqcGksIEhXTkQgaFduZCkKewogIENIQVIgc3pUaXRsZVsyMF07CiAgQ0hBUiBzekFib3V0WzEyOF07CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQoTVNSTEUzMl9oTW9kdWxlICE9IDApOwoKICBMb2FkU3RyaW5nQShNU1JMRTMyX2hNb2R1bGUsIElEU19OQU1FLCBzelRpdGxlLCBzaXplb2Yoc3pUaXRsZSkpOwogIExvYWRTdHJpbmdBKE1TUkxFMzJfaE1vZHVsZSwgSURTX0FCT1VULCBzekFib3V0LCBzaXplb2Yoc3pBYm91dCkpOwoKICBNZXNzYWdlQm94QShoV25kLCBzekFib3V0LCBzelRpdGxlLCBNQl9PS3xNQl9JQ09OSU5GT1JNQVRJT04pOwoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIENvbXByZXNzR2V0Rm9ybWF0KENvZGVjSW5mbyAqcGksIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaUluLAoJCQkJIExQQklUTUFQSU5GT0hFQURFUiBscGJpT3V0KQp7CiAgTFJFU1VMVCBzaXplOwoKICBUUkFDRSgiKCVwLCVwLCVwKVxuIixwaSxscGJpSW4sbHBiaU91dCk7CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIC8qIGNoZWNrIHBhcmFtZXRlcnMgLS0gbmVlZCBhdCBsZWFzdCBpbnB1dCBmb3JtYXQgKi8KICBpZiAobHBiaUluID09IE5VTEwpIHsKICAgIGlmIChscGJpT3V0ICE9IE5VTEwpCiAgICAgIHJldHVybiBJQ0VSUl9CQURQQVJBTTsKICAgIHJldHVybiAwOwogIH0KCiAgLyogaGFuZGxlIHVuc3VwcG9ydGVkIGlucHV0IGZvcm1hdCAqLwogIGlmIChDb21wcmVzc1F1ZXJ5KHBpLCBscGJpSW4sIE5VTEwpICE9IElDRVJSX09LKQogICAgcmV0dXJuIChscGJpT3V0ID09IE5VTEwgPyBJQ0VSUl9CQURGT1JNQVQgOiAwKTsKCiAgYXNzZXJ0KDAgPCBscGJpSW4tPmJpQml0Q291bnQgJiYgbHBiaUluLT5iaUJpdENvdW50IDw9IDgpOwoKICBzd2l0Y2ggKHBpLT5mY2NIYW5kbGVyKSB7CiAgY2FzZSBGT1VSQ0NfUkxFNDoKICAgIHNpemUgPSAxIDw8IDQ7CiAgICBicmVhazsKICBjYXNlIEZPVVJDQ19STEU4OgogICAgc2l6ZSA9IDEgPDwgODsKICAgIGJyZWFrOwogIGNhc2UgRk9VUkNDX1JMRToKICBjYXNlIEZPVVJDQ19NUkxFOgogICAgc2l6ZSA9IChscGJpSW4tPmJpQml0Q291bnQgPD0gNCA/IDEgPDwgNCA6IDEgPDwgOCk7CiAgICBicmVhazsKICBkZWZhdWx0OgogICAgcmV0dXJuIElDRVJSX0VSUk9SOwogIH0KCiAgaWYgKGxwYmlJbi0+YmlDbHJVc2VkICE9IDApCiAgICBzaXplID0gbHBiaUluLT5iaUNsclVzZWQ7CgogIHNpemUgPSBzaXplb2YoQklUTUFQSU5GT0hFQURFUikgKyBzaXplICogc2l6ZW9mKFJHQlFVQUQpOwoKICBpZiAobHBiaU91dCAhPSBOVUxMKSB7CiAgICBscGJpT3V0LT5iaVNpemUgICAgICAgICAgPSBzaXplb2YoQklUTUFQSU5GT0hFQURFUik7CiAgICBscGJpT3V0LT5iaVdpZHRoICAgICAgICAgPSBscGJpSW4tPmJpV2lkdGg7CiAgICBscGJpT3V0LT5iaUhlaWdodCAgICAgICAgPSBscGJpSW4tPmJpSGVpZ2h0OwogICAgbHBiaU91dC0+YmlQbGFuZXMgICAgICAgID0gMTsKICAgIGlmIChwaS0+ZmNjSGFuZGxlciA9PSBGT1VSQ0NfUkxFNCB8fAoJbHBiaUluLT5iaUJpdENvdW50IDw9IDQpIHsKICAgICAgbHBiaU91dC0+YmlDb21wcmVzc2lvbiA9IEJJX1JMRTQ7CiAgICAgIGxwYmlPdXQtPmJpQml0Q291bnQgICAgPSA0OwogICAgfSBlbHNlIHsKICAgICAgbHBiaU91dC0+YmlDb21wcmVzc2lvbiA9IEJJX1JMRTg7CiAgICAgIGxwYmlPdXQtPmJpQml0Q291bnQgICAgPSA4OwogICAgfQogICAgbHBiaU91dC0+YmlTaXplSW1hZ2UgICAgID0gTVNSTEUzMl9HZXRNYXhDb21wcmVzc2VkU2l6ZShscGJpT3V0KTsKICAgIGxwYmlPdXQtPmJpWFBlbHNQZXJNZXRlciA9IGxwYmlJbi0+YmlYUGVsc1Blck1ldGVyOwogICAgbHBiaU91dC0+YmlZUGVsc1Blck1ldGVyID0gbHBiaUluLT5iaVlQZWxzUGVyTWV0ZXI7CiAgICBpZiAobHBiaUluLT5iaUNsclVzZWQgPT0gMCkKICAgICAgc2l6ZSA9IDE8PGxwYmlJbi0+YmlCaXRDb3VudDsKICAgIGVsc2UKICAgICAgc2l6ZSA9IGxwYmlJbi0+YmlDbHJVc2VkOwogICAgbHBiaU91dC0+YmlDbHJVc2VkICAgICAgID0gbWluKHNpemUsIDEgPDwgbHBiaU91dC0+YmlCaXRDb3VudCk7CiAgICBscGJpT3V0LT5iaUNsckltcG9ydGFudCAgPSAwOwoKICAgIG1lbWNweSgoTFBCWVRFKWxwYmlPdXQgKyBscGJpT3V0LT5iaVNpemUsCgkgICAoY29uc3QgQllURSopbHBiaUluICsgbHBiaUluLT5iaVNpemUsIGxwYmlPdXQtPmJpQ2xyVXNlZCAqIHNpemVvZihSR0JRVUFEKSk7CgogICAgcmV0dXJuIElDRVJSX09LOwogIH0gZWxzZQogICAgcmV0dXJuIHNpemU7Cn0KCnN0YXRpYyBMUkVTVUxUIENvbXByZXNzR2V0U2l6ZShDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwKCQkJICAgICAgIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaU91dCkKewogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIFRSQUNFKCIoJXAsJXAsJXApXG4iLHBpLGxwYmlJbixscGJpT3V0KTsKCiAgLyogY2hlY2sgcGFyYW1ldGVyIC0tIG5lZWQgYXQgbGVhc3Qgb25lIGZvcm1hdCAqLwogIGlmIChscGJpSW4gPT0gTlVMTCAmJiBscGJpT3V0ID09IE5VTEwpCiAgICByZXR1cm4gMDsKICAvKiBjaGVjayBpZiB0aGUgZ2l2ZW4gZm9ybWF0IGlzIHN1cHBvcnRlZCAqLwogIGlmIChDb21wcmVzc1F1ZXJ5KHBpLCBscGJpSW4sIGxwYmlPdXQpICE9IElDRVJSX09LKQogICAgcmV0dXJuIDA7CgogIC8qIHRoZSB3b3JzdCBjYXNlIGlzIGNvZGluZyB0aGUgY29tcGxldGUgaW1hZ2UgaW4gYWJzb2x1dGUgbW9kZS4gKi8KICBpZiAobHBiaUluKQogICAgcmV0dXJuIE1TUkxFMzJfR2V0TWF4Q29tcHJlc3NlZFNpemUobHBiaUluKTsKICBlbHNlCiAgICByZXR1cm4gTVNSTEUzMl9HZXRNYXhDb21wcmVzc2VkU2l6ZShscGJpT3V0KTsKfQoKc3RhdGljIExSRVNVTFQgQ29tcHJlc3NRdWVyeShDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwKCQkJICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpCnsKICAvKiBwcmUtY29uZGl0aW9uICovCiAgYXNzZXJ0KHBpICE9IE5VTEwpOwoKICAvKiBuZWVkIGF0IGxlYXN0IG9uZSBmb3JtYXQgKi8KICBpZiAobHBiaUluID09IE5VTEwgJiYgbHBiaU91dCA9PSBOVUxMKQogICAgcmV0dXJuIElDRVJSX0JBRFBBUkFNOwoKICAvKiBjaGVjayBpbnB1dCBmb3JtYXQgaWYgZ2l2ZW4gKi8KICBpZiAobHBiaUluICE9IE5VTEwpIHsKICAgIGlmICghaXNTdXBwb3J0ZWRESUIobHBiaUluKSkKICAgICAgcmV0dXJuIElDRVJSX0JBREZPUk1BVDsKCiAgICAvKiBmb3IgNC1iaXQgbmVlZCBhbiBldmVuIHdpZHRoICovCiAgICBpZiAobHBiaUluLT5iaUJpdENvdW50IDw9IDQgJiYgKGxwYmlJbi0+YmlXaWR0aCAlIDIpKQogICAgICByZXR1cm4gSUNFUlJfQkFERk9STUFUOwoKICAgIGlmIChwaS0+ZmNjSGFuZGxlciA9PSBGT1VSQ0NfUkxFNCAmJiBscGJpSW4tPmJpQml0Q291bnQgPiA0KQogICAgICByZXR1cm4gSUNFUlJfVU5TVVBQT1JURUQ7CiAgICBlbHNlIGlmIChscGJpSW4tPmJpQml0Q291bnQgPiA4KQogICAgICByZXR1cm4gSUNFUlJfVU5TVVBQT1JURUQ7CiAgfQoKICAvKiBjaGVjayBvdXRwdXQgZm9ybWF0IGlmIGdpdmVuICovCiAgaWYgKGxwYmlPdXQgIT0gTlVMTCkgewogICAgaWYgKCFpc1N1cHBvcnRlZE1STEUobHBiaU91dCkpCiAgICAgIHJldHVybiBJQ0VSUl9CQURGT1JNQVQ7CgogICAgaWYgKGxwYmlJbiAhPSBOVUxMKSB7CiAgICAgIGlmIChscGJpSW4tPmJpV2lkdGggICE9IGxwYmlPdXQtPmJpV2lkdGgpCglyZXR1cm4gSUNFUlJfVU5TVVBQT1JURUQ7CiAgICAgIGlmIChscGJpSW4tPmJpSGVpZ2h0ICE9IGxwYmlPdXQtPmJpSGVpZ2h0KQoJcmV0dXJuIElDRVJSX1VOU1VQUE9SVEVEOwogICAgICBpZiAobHBiaUluLT5iaUJpdENvdW50ID4gbHBiaU91dC0+YmlCaXRDb3VudCkKCXJldHVybiBJQ0VSUl9VTlNVUFBPUlRFRDsKICAgIH0KICB9CgogIHJldHVybiBJQ0VSUl9PSzsKfQoKc3RhdGljIExSRVNVTFQgQ29tcHJlc3NCZWdpbihDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwKCQkJICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpCnsKICBjb25zdCBSR0JRVUFEICpyZ2JJbjsKICBjb25zdCBSR0JRVUFEICpyZ2JPdXQ7CiAgVUlOVCAgIGk7CiAgc2l6ZV90IHNpemU7CgogIFRSQUNFKCIoJXAsJXAsJXApXG4iLHBpLGxwYmlJbixscGJpT3V0KTsKCiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgLyogY2hlY2sgcGFyYW1ldGVycyAtLSBuZWVkIGJvdGggZm9ybWF0cyAqLwogIGlmIChscGJpSW4gPT0gTlVMTCB8fCBscGJpT3V0ID09IE5VTEwpCiAgICByZXR1cm4gSUNFUlJfQkFEUEFSQU07CiAgLyogQW5kIGJvdGggbXVzdCBiZSBzdXBwb3J0ZWQgKi8KICBpZiAoQ29tcHJlc3NRdWVyeShwaSwgbHBiaUluLCBscGJpT3V0KSAhPSBJQ0VSUl9PSykKICAgIHJldHVybiBJQ0VSUl9CQURGT1JNQVQ7CgogIC8qIEZJWE1FOiBjYW5ub3QgY29tcHJlc3MgYW5kIGRlY29tcHJlc3MgYXQgc2FtZSB0aW1lISAqLwogIGlmIChwaS0+YkRlY29tcHJlc3MpIHsKICAgIEZJWE1FKCJjYW5ub3QgY29tcHJlc3MgYW5kIGRlY29tcHJlc3MgYXQgc2FtZSB0aW1lIVxuIik7CiAgICByZXR1cm4gSUNFUlJfRVJST1I7CiAgfQoKICBpZiAocGktPmJDb21wcmVzcykKICAgIENvbXByZXNzRW5kKHBpKTsKCiAgc2l6ZSA9IFdJRFRIQllURVMobHBiaU91dC0+YmlXaWR0aCAqIDE2KSAvIDIgKiBscGJpT3V0LT5iaUhlaWdodDsKICBwaS0+cFByZXZGcmFtZSA9IChMUFdPUkQpR2xvYmFsQWxsb2NQdHIoR1BUUiwgc2l6ZSAqIHNpemVvZihXT1JEKSk7CiAgaWYgKHBpLT5wUHJldkZyYW1lID09IE5VTEwpCiAgICByZXR1cm4gSUNFUlJfTUVNT1JZOwogIHBpLT5wQ3VyRnJhbWUgPSAoTFBXT1JEKUdsb2JhbEFsbG9jUHRyKEdQVFIsIHNpemUgKiBzaXplb2YoV09SRCkpOwogIGlmIChwaS0+cEN1ckZyYW1lID09IE5VTEwpIHsKICAgIENvbXByZXNzRW5kKHBpKTsKICAgIHJldHVybiBJQ0VSUl9NRU1PUlk7CiAgfQogIHBpLT5uUHJldkZyYW1lID0gLTE7CiAgcGktPmJDb21wcmVzcyAgPSBUUlVFOwoKICByZ2JJbiAgPSAoY29uc3QgUkdCUVVBRCopKChjb25zdCBCWVRFKilscGJpSW4gICsgbHBiaUluLT5iaVNpemUpOwogIHJnYk91dCA9IChjb25zdCBSR0JRVUFEKikoKGNvbnN0IEJZVEUqKWxwYmlPdXQgKyBscGJpT3V0LT5iaVNpemUpOwoKICBzd2l0Y2ggKGxwYmlPdXQtPmJpQml0Q291bnQpIHsKICBjYXNlIDQ6CiAgY2FzZSA4OgogICAgcGktPnBhbGV0dGVfbWFwID0gKExQQllURSlMb2NhbEFsbG9jKExQVFIsIGxwYmlJbi0+YmlDbHJVc2VkKTsKICAgIGlmIChwaS0+cGFsZXR0ZV9tYXAgPT0gTlVMTCkgewogICAgICBDb21wcmVzc0VuZChwaSk7CiAgICAgIHJldHVybiBJQ0VSUl9NRU1PUlk7CiAgICB9CgogICAgZm9yIChpID0gMDsgaSA8IGxwYmlJbi0+YmlDbHJVc2VkOyBpKyspIHsKICAgICAgcGktPnBhbGV0dGVfbWFwW2ldID0gTVNSTEUzMl9HZXROZWFyZXN0UGFsZXR0ZUluZGV4KGxwYmlPdXQtPmJpQ2xyVXNlZCwgcmdiT3V0LCByZ2JJbltpXSk7CiAgICB9CiAgICBicmVhazsKICB9OwoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIENvbXByZXNzKENvZGVjSW5mbyAqcGksIElDQ09NUFJFU1MqIGxwaWMsIERXT1JEIGR3U2l6ZSkKewogIGludCBpOwoKICBUUkFDRSgiKCVwLCVwLCVsdSlcbiIscGksbHBpYyxkd1NpemUpOwoKICAvKiBwcmUtY29uZGl0aW9uICovCiAgYXNzZXJ0KHBpICE9IE5VTEwpOwoKICAvKiBjaGVjayBwYXJhbWV0ZXJzICovCiAgaWYgKGxwaWMgPT0gTlVMTCB8fCBkd1NpemUgPCBzaXplb2YoSUNDT01QUkVTUykpCiAgICByZXR1cm4gSUNFUlJfQkFEUEFSQU07CiAgaWYgKCFscGljLT5scGJpT3V0cHV0IHx8ICFscGljLT5scE91dHB1dCB8fAogICAgICAhbHBpYy0+bHBiaUlucHV0ICB8fCAhbHBpYy0+bHBJbnB1dCkKICAgIHJldHVybiBJQ0VSUl9CQURQQVJBTTsKCiAgVFJBQ0UoImxwaWM9ezB4JWxYLCVwLCVwLCVwLCVwLCVwLCVwLCVsZCwlbHUsJWx1LCVwLCVwfVxuIixscGljLT5kd0ZsYWdzLGxwaWMtPmxwYmlPdXRwdXQsbHBpYy0+bHBPdXRwdXQsbHBpYy0+bHBiaUlucHV0LGxwaWMtPmxwSW5wdXQsbHBpYy0+bHBja2lkLGxwaWMtPmxwZHdGbGFncyxscGljLT5sRnJhbWVOdW0sbHBpYy0+ZHdGcmFtZVNpemUsbHBpYy0+ZHdRdWFsaXR5LGxwaWMtPmxwYmlQcmV2LGxwaWMtPmxwUHJldik7CgogIGlmICghIHBpLT5iQ29tcHJlc3MpIHsKICAgIExSRVNVTFQgaHIgPSBDb21wcmVzc0JlZ2luKHBpLCBscGljLT5scGJpSW5wdXQsIGxwaWMtPmxwYmlPdXRwdXQpOwogICAgaWYgKGhyICE9IElDRVJSX09LKQogICAgICByZXR1cm4gaHI7CiAgfSBlbHNlIGlmIChDb21wcmVzc1F1ZXJ5KHBpLCBscGljLT5scGJpSW5wdXQsIGxwaWMtPmxwYmlPdXRwdXQpICE9IElDRVJSX09LKQogICAgcmV0dXJuIElDRVJSX0JBREZPUk1BVDsKCiAgaWYgKGxwaWMtPmxGcmFtZU51bSA+PSBwaS0+blByZXZGcmFtZSArIDEpIHsKICAgIC8qIHdlIGNvbnRpbnVlIGluIHRoZSBzZXF1ZW5jZSBzbyB3ZSBuZWVkIHRvIGluaXRpYWxpemUgCiAgICAgKiBvdXIgaW50ZXJuYWwgZnJhbWVkYXRhICovCgogICAgY29tcHV0ZUludGVybmFsRnJhbWUocGksIGxwaWMtPmxwYmlJbnB1dCwgbHBpYy0+bHBJbnB1dCk7CiAgfSBlbHNlIGlmIChscGljLT5sRnJhbWVOdW0gPT0gcGktPm5QcmV2RnJhbWUpIHsKICAgIC8qIE9vcHMsIGNvbXByZXNzIHNhbWUgZnJhbWUgYWdhaW4gPyBPa2F5LCBhcyB5b3Ugd2lzaC4KICAgICAqIE5vIG5lZWQgdG8gcmVjb21wdXRlIGludGVybmFsIGZyYW1lZGF0YSwgYmVjYXVzZSB3ZSBvbmx5IHN3YXBwZWQgYnVmZmVycyAqLwogICAgTFBXT1JEIHBUbXAgPSBwaS0+cFByZXZGcmFtZTsKCiAgICBwaS0+cFByZXZGcmFtZSA9IHBpLT5wQ3VyRnJhbWU7CiAgICBwaS0+cEN1ckZyYW1lICA9IHBUbXA7CiAgfSBlbHNlIGlmICgobHBpYy0+ZHdGbGFncyAmIElDQ09NUFJFU1NfS0VZRlJBTUUpID09IDApIHsKICAgIExQV09SRCBwVG1wOwoKICAgIFdBUk4oIjogcHJldj0lbGQgY3VyPSVsZCBnb25lIGJhY2s/IC0tIHVudGVzdGVkXG4iLHBpLT5uUHJldkZyYW1lLGxwaWMtPmxGcmFtZU51bSk7CiAgICBpZiAobHBpYy0+bHBiaVByZXYgPT0gTlVMTCB8fCBscGljLT5scFByZXYgPT0gTlVMTCkKICAgICAgcmV0dXJuIElDRVJSX0dPVE9LRVlGUkFNRTsgLyogTmVlZCBhIGtleWZyYW1lIGlmIHlvdSBnbyBiYWNrICovCiAgICBpZiAoQ29tcHJlc3NRdWVyeShwaSwgbHBpYy0+bHBiaVByZXYsIGxwaWMtPmxwYmlPdXRwdXQpICE9IElDRVJSX09LKQogICAgICByZXR1cm4gSUNFUlJfQkFERk9STUFUOwoKICAgIFdBUk4oIjogcHJldj0lbGQgY3VyPSVsZCBjb21wdXRlIHN3YXBwZWQgLS0gdW50ZXN0ZWRcbiIscGktPm5QcmV2RnJhbWUsbHBpYy0+bEZyYW1lTnVtKTsKICAgIGNvbXB1dGVJbnRlcm5hbEZyYW1lKHBpLCBscGljLT5scGJpUHJldiwgbHBpYy0+bHBQcmV2KTsKCiAgICAvKiBzd2FwIGJ1ZmZlcnMgZm9yIGN1cnJlbnQgYW5kIHByZXZpb3VzIGZyYW1lICovCiAgICAvKiBEb24ndCBmcmVlIGFuZCBhbGxvYyBuZXcgLS0gY29zdHMgdG8gbXVjaCB0aW1lIGFuZCB0aGV5IGFyZSBvZiBlcXVhbCBzaXplICEgKi8KICAgIHBUbXAgPSBwaS0+cFByZXZGcmFtZTsKICAgIHBpLT5wUHJldkZyYW1lID0gcGktPnBDdXJGcmFtZTsKICAgIHBpLT5wQ3VyRnJhbWUgID0gcFRtcDsKICAgIHBpLT5uUHJldkZyYW1lID0gbHBpYy0+bEZyYW1lTnVtOwogIH0KCiAgZm9yIChpID0gMDsgaSA8IDM7IGkrKykgewogICAgU2V0UXVhbGl0eShwaSwgbHBpYy0+ZHdRdWFsaXR5KTsKCiAgICBscGljLT5scGJpT3V0cHV0LT5iaVNpemVJbWFnZSA9IDA7CgogICAgaWYgKGxwaWMtPmxwYmlPdXRwdXQtPmJpQml0Q291bnQgPT0gNCkKICAgICAgTVNSTEUzMl9Db21wcmVzc1JMRTQocGksIGxwaWMtPmxwYmlJbnB1dCwgKExQQllURSlscGljLT5scElucHV0LAoJCSAgIGxwaWMtPmxwYmlPdXRwdXQsIChMUEJZVEUpbHBpYy0+bHBPdXRwdXQsIChscGljLT5kd0ZsYWdzICYgSUNDT01QUkVTU19LRVlGUkFNRSkgIT0gMCk7CiAgICBlbHNlCiAgICAgIE1TUkxFMzJfQ29tcHJlc3NSTEU4KHBpLCBscGljLT5scGJpSW5wdXQsIChMUEJZVEUpbHBpYy0+bHBJbnB1dCwKCQkgICBscGljLT5scGJpT3V0cHV0LCAoTFBCWVRFKWxwaWMtPmxwT3V0cHV0LCAobHBpYy0+ZHdGbGFncyAmIElDQ09NUFJFU1NfS0VZRlJBTUUpICE9IDApOwoKICAgIGlmIChscGljLT5kd0ZyYW1lU2l6ZSA9PSAwIHx8CglscGljLT5scGJpT3V0cHV0LT5iaVNpemVJbWFnZSA8IGxwaWMtPmR3RnJhbWVTaXplKQogICAgICBicmVhazsKCiAgICBpZiAoKCpscGljLT5scGR3RmxhZ3MgJiBJQ0NPTVBSRVNTX0tFWUZSQU1FKSA9PSAwKSB7CiAgICAgIGlmIChscGljLT5scGJpT3V0cHV0LT5iaUJpdENvdW50ID09IDQpCglNU1JMRTMyX0NvbXByZXNzUkxFNChwaSwgbHBpYy0+bHBiaUlucHV0LCAoTFBCWVRFKWxwaWMtPmxwSW5wdXQsCgkJCSAgICAgbHBpYy0+bHBiaU91dHB1dCwgKExQQllURSlscGljLT5scE91dHB1dCwgVFJVRSk7CiAgICAgIGVsc2UKCU1TUkxFMzJfQ29tcHJlc3NSTEU4KHBpLCBscGljLT5scGJpSW5wdXQsIChMUEJZVEUpbHBpYy0+bHBJbnB1dCwKCQkJICAgICBscGljLT5scGJpT3V0cHV0LCAoTFBCWVRFKWxwaWMtPmxwT3V0cHV0LCBUUlVFKTsKCiAgICAgIGlmIChscGljLT5kd0ZyYW1lU2l6ZSA9PSAwIHx8CgkgIGxwaWMtPmxwYmlPdXRwdXQtPmJpU2l6ZUltYWdlIDwgbHBpYy0+ZHdGcmFtZVNpemUpIHsKCVdBUk4oInN3aXRjaGVkIHRvIGtleWZyYW1lLCB3YXMgc21hbGwgZW5vdWdoIVxuIik7CgkqbHBpYy0+bHBkd0ZsYWdzIHw9IElDQ09NUFJFU1NfS0VZRlJBTUU7CgkqbHBpYy0+bHBja2lkICAgID0gTUFLRUFWSUNLSUQoY2t0eXBlRElCYml0cywKCQkJCSAgICAgICBTdHJlYW1Gcm9tRk9VUkNDKCpscGljLT5scGNraWQpKTsKCWJyZWFrOwogICAgICB9CiAgICB9CgogICAgaWYgKGxwaWMtPmR3UXVhbGl0eSA8IDEwMDApCiAgICAgIGJyZWFrOwoKICAgIGxwaWMtPmR3UXVhbGl0eSAtPSAxMDAwOyAvKiByZWR1Y2UgcXVhbGl0eSBieSAxMCUgKi8KICB9CgogIHsgLyogc3dhcCBidWZmZXIgZm9yIGN1cnJlbnQgYW5kIHByZXZpb3VzIGZyYW1lICovCiAgICAvKiBEb24ndCBmcmVlIGFuZCBhbGxvYyBuZXcgLS0gY29zdHMgdG8gbXVjaCB0aW1lIGFuZCB0aGV5IGFyZSBvZiBlcXVhbCBzaXplICEgKi8KICAgIHJlZ2lzdGVyIExQV09SRCBwVG1wID0gcGktPnBQcmV2RnJhbWU7CgogICAgcGktPnBQcmV2RnJhbWUgPSBwaS0+cEN1ckZyYW1lOwogICAgcGktPnBDdXJGcmFtZSAgPSBwVG1wOwogICAgcGktPm5QcmV2RnJhbWUgPSBscGljLT5sRnJhbWVOdW07CiAgfQoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIENvbXByZXNzRW5kKENvZGVjSW5mbyAqcGkpCnsKICBUUkFDRSgiKCVwKVxuIixwaSk7CgogIGlmIChwaSAhPSBOVUxMKSB7CiAgICBpZiAocGktPnBQcmV2RnJhbWUgIT0gTlVMTCkKICAgICAgR2xvYmFsRnJlZVB0cihwaS0+cFByZXZGcmFtZSk7CiAgICBpZiAocGktPnBDdXJGcmFtZSAhPSBOVUxMKQogICAgICBHbG9iYWxGcmVlUHRyKHBpLT5wQ3VyRnJhbWUpOwogICAgcGktPnBQcmV2RnJhbWUgPSBOVUxMOwogICAgcGktPnBDdXJGcmFtZSAgPSBOVUxMOwogICAgcGktPm5QcmV2RnJhbWUgPSAtMTsKICAgIHBpLT5iQ29tcHJlc3MgID0gRkFMU0U7CiAgfQoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIERlY29tcHJlc3NHZXRGb3JtYXQoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCQkgICBMUEJJVE1BUElORk9IRUFERVIgbHBiaU91dCkKewogIERXT1JEIHNpemU7CgogIFRSQUNFKCIoJXAsJXAsJXApXG4iLHBpLGxwYmlJbixscGJpT3V0KTsKCiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgaWYgKGxwYmlJbiA9PSBOVUxMKQogICAgcmV0dXJuIChscGJpT3V0ICE9IE5VTEwgPyBJQ0VSUl9CQURQQVJBTSA6IDApOwoKICBpZiAoRGVjb21wcmVzc1F1ZXJ5KHBpLCBscGJpSW4sIE5VTEwpICE9IElDRVJSX09LKQogICAgcmV0dXJuIChscGJpT3V0ICE9IE5VTEwgPyBJQ0VSUl9CQURGT1JNQVQgOiAwKTsKCiAgc2l6ZSA9IGxwYmlJbi0+YmlTaXplOwoKICBpZiAobHBiaUluLT5iaUJpdENvdW50IDw9IDgpCiAgICBzaXplICs9IGxwYmlJbi0+YmlDbHJVc2VkICogc2l6ZW9mKFJHQlFVQUQpOwoKICBpZiAobHBiaU91dCAhPSBOVUxMKSB7CiAgICBtZW1jcHkobHBiaU91dCwgbHBiaUluLCBzaXplKTsKICAgIGxwYmlPdXQtPmJpQ29tcHJlc3Npb24gID0gQklfUkdCOwogICAgbHBiaU91dC0+YmlTaXplSW1hZ2UgICAgPSBESUJXSURUSEJZVEVTKCpscGJpT3V0KSAqIGxwYmlPdXQtPmJpSGVpZ2h0OwoKICAgIHJldHVybiBJQ0VSUl9PSzsKICB9IGVsc2UKICAgIHJldHVybiBzaXplOwp9CgpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzUXVlcnkoQ29kZWNJbmZvICpwaSwgTFBDQklUTUFQSU5GT0hFQURFUiBscGJpSW4sCgkJCSAgICAgICBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlPdXQpCnsKICBMUkVTVUxUIGhyID0gSUNFUlJfT0s7CgogIFRSQUNFKCIoJXAsJXAsJXApXG4iLHBpLGxwYmlJbixscGJpT3V0KTsKCiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgLyogbmVlZCBhdCBsZWFzdCBvbmUgZm9ybWF0ICovCiAgaWYgKGxwYmlJbiA9PSBOVUxMICYmIGxwYmlPdXQgPT0gTlVMTCkKICAgIHJldHVybiBJQ0VSUl9CQURQQVJBTTsKCiAgLyogY2hlY2sgaW5wdXQgZm9ybWF0IGlmIGdpdmVuICovCiAgaWYgKGxwYmlJbiAhPSBOVUxMKSB7CiAgICBpZiAoIWlzU3VwcG9ydGVkTVJMRShscGJpSW4pKQogICAgICByZXR1cm4gSUNFUlJfQkFERk9STUFUOwogIH0KCiAgLyogY2hlY2sgb3V0cHV0IGZvcm1hdCBpZiBnaXZlbiAqLwogIGlmIChscGJpT3V0ICE9IE5VTEwpIHsKICAgIGlmICghaXNTdXBwb3J0ZWRESUIobHBiaU91dCkpCiAgICAgIGhyID0gSUNFUlJfQkFERk9STUFUOwoKICAgIGlmIChscGJpSW4gIT0gTlVMTCkgewogICAgICBpZiAobHBiaUluLT5iaVdpZHRoICAhPSBscGJpT3V0LT5iaVdpZHRoKQoJaHIgPSBJQ0VSUl9VTlNVUFBPUlRFRDsKICAgICAgaWYgKGxwYmlJbi0+YmlIZWlnaHQgIT0gbHBiaU91dC0+YmlIZWlnaHQpCglociA9IElDRVJSX1VOU1VQUE9SVEVEOwogICAgICBpZiAobHBiaUluLT5iaUJpdENvdW50ID4gbHBiaU91dC0+YmlCaXRDb3VudCkKCWhyID0gSUNFUlJfVU5TVVBQT1JURUQ7CiAgICB9CiAgfQoKICByZXR1cm4gaHI7Cn0KCnN0YXRpYyBMUkVTVUxUIERlY29tcHJlc3NCZWdpbihDb2RlY0luZm8gKnBpLCBMUENCSVRNQVBJTkZPSEVBREVSIGxwYmlJbiwKCQkJICAgICAgIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaU91dCkKewogIGNvbnN0IFJHQlFVQUQgKnJnYkluOwogIGNvbnN0IFJHQlFVQUQgKnJnYk91dDsKICBVSU5UICBpOwoKICBUUkFDRSgiKCVwLCVwLCVwKVxuIixwaSxscGJpSW4sbHBiaU91dCk7CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIC8qIGNoZWNrIHBhcmFtZXRlcnMgKi8KICBpZiAobHBiaUluID09IE5VTEwgfHwgbHBiaU91dCA9PSBOVUxMKQogICAgcmV0dXJuIElDRVJSX0JBRFBBUkFNOwogIGlmIChEZWNvbXByZXNzUXVlcnkocGksIGxwYmlJbiwgbHBiaU91dCkgIT0gSUNFUlJfT0spCiAgICByZXR1cm4gSUNFUlJfQkFERk9STUFUOwoKICAvKiBGSVhNRTogY2Fubm90IGNvbXByZXNzIGFuZCBkZWNvbXByZXNzIGF0IGEgdGltZSEgKi8KICBpZiAocGktPmJDb21wcmVzcykgewogICAgRklYTUUoImNhbm5vdCBjb21wcmVzcyBhbmQgZGVjb21wcmVzcyBhdCBzYW1lIHRpbWUhXG4iKTsKICAgIHJldHVybiBJQ0VSUl9FUlJPUjsKICB9CgogIGlmIChwaS0+YkRlY29tcHJlc3MpCiAgICBEZWNvbXByZXNzRW5kKHBpKTsKCiAgcmdiSW4gID0gKGNvbnN0IFJHQlFVQUQqKSgoY29uc3QgQllURSopbHBiaUluICArIGxwYmlJbi0+YmlTaXplKTsKICByZ2JPdXQgPSAoY29uc3QgUkdCUVVBRCopKChjb25zdCBCWVRFKilscGJpT3V0ICsgbHBiaU91dC0+YmlTaXplKTsKCiAgc3dpdGNoIChscGJpT3V0LT5iaUJpdENvdW50KSB7CiAgY2FzZSA0OgogIGNhc2UgODoKICAgIHBpLT5wYWxldHRlX21hcCA9IChMUEJZVEUpTG9jYWxBbGxvYyhMUFRSLCBscGJpSW4tPmJpQ2xyVXNlZCk7CiAgICBpZiAocGktPnBhbGV0dGVfbWFwID09IE5VTEwpCiAgICAgIHJldHVybiBJQ0VSUl9NRU1PUlk7CgogICAgZm9yIChpID0gMDsgaSA8IGxwYmlJbi0+YmlDbHJVc2VkOyBpKyspIHsKICAgICAgcGktPnBhbGV0dGVfbWFwW2ldID0gTVNSTEUzMl9HZXROZWFyZXN0UGFsZXR0ZUluZGV4KGxwYmlPdXQtPmJpQ2xyVXNlZCwgcmdiT3V0LCByZ2JJbltpXSk7CiAgICB9CiAgICBicmVhazsKICBjYXNlIDE1OgogIGNhc2UgMTY6CiAgICBwaS0+cGFsZXR0ZV9tYXAgPSAoTFBCWVRFKUxvY2FsQWxsb2MoTFBUUiwgbHBiaUluLT5iaUNsclVzZWQgKiAyKTsKICAgIGlmIChwaS0+cGFsZXR0ZV9tYXAgPT0gTlVMTCkKICAgICAgcmV0dXJuIElDRVJSX01FTU9SWTsKCiAgICBmb3IgKGkgPSAwOyBpIDwgbHBiaUluLT5iaUNsclVzZWQ7IGkrKykgewogICAgICBXT1JEIGNvbG9yOwoKICAgICAgaWYgKGxwYmlPdXQtPmJpQml0Q291bnQgPT0gMTUpCgljb2xvciA9ICgocmdiSW5baV0ucmdiUmVkID4+IDMpIDw8IDEwKQoJICB8ICgocmdiSW5baV0ucmdiR3JlZW4gPj4gMykgPDwgNSkgfCAocmdiSW5baV0ucmdiQmx1ZSA+PiAzKTsKICAgICAgZWxzZQoJY29sb3IgPSAoKHJnYkluW2ldLnJnYlJlZCA+PiAzKSA8PCAxMSkKCSAgfCAoKHJnYkluW2ldLnJnYkdyZWVuID4+IDMpIDw8IDUpIHwgKHJnYkluW2ldLnJnYkJsdWUgPj4gMyk7CgogICAgICBwaS0+cGFsZXR0ZV9tYXBbaSAqIDIgKyAxXSA9IGNvbG9yID4+IDg7CiAgICAgIHBpLT5wYWxldHRlX21hcFtpICogMiArIDBdID0gY29sb3IgJiAweEZGOwogICAgfTsKICAgIGJyZWFrOwogIGNhc2UgMjQ6CiAgY2FzZSAzMjoKICAgIHBpLT5wYWxldHRlX21hcCA9IChMUEJZVEUpTG9jYWxBbGxvYyhMUFRSLCBscGJpSW4tPmJpQ2xyVXNlZCAqIHNpemVvZihSR0JRVUFEKSk7CiAgICBpZiAocGktPnBhbGV0dGVfbWFwID09IE5VTEwpCiAgICAgIHJldHVybiBJQ0VSUl9NRU1PUlk7CiAgICBtZW1jcHkocGktPnBhbGV0dGVfbWFwLCByZ2JJbiwgbHBiaUluLT5iaUNsclVzZWQgKiBzaXplb2YoUkdCUVVBRCkpOwogICAgYnJlYWs7CiAgfTsKCiAgcGktPmJEZWNvbXByZXNzID0gVFJVRTsKCiAgcmV0dXJuIElDRVJSX09LOwp9CgpzdGF0aWMgTFJFU1VMVCBEZWNvbXByZXNzKENvZGVjSW5mbyAqcGksIElDREVDT01QUkVTUyAqcGljLCBEV09SRCBkd1NpemUpCnsKICBUUkFDRSgiKCVwLCVwLCVsdSlcbiIscGkscGljLGR3U2l6ZSk7CgogIC8qIHByZS1jb25kaXRpb24gKi8KICBhc3NlcnQocGkgIT0gTlVMTCk7CgogIC8qIGNoZWNrIHBhcmFtZXRlcnMgKi8KICBpZiAocGljID09IE5VTEwpCiAgICByZXR1cm4gSUNFUlJfQkFEUEFSQU07CiAgaWYgKHBpYy0+bHBiaUlucHV0ID09IE5VTEwgfHwgcGljLT5scElucHV0ID09IE5VTEwgfHwKICAgICAgcGljLT5scGJpT3V0cHV0ID09IE5VTEwgfHwgcGljLT5scE91dHB1dCA9PSBOVUxMKQogICAgcmV0dXJuIElDRVJSX0JBRFBBUkFNOwoKICAvKiBjaGVjayBmb3JtYXRzICovCiAgaWYgKCEgcGktPmJEZWNvbXByZXNzKSB7CiAgICBMUkVTVUxUIGhyID0gRGVjb21wcmVzc0JlZ2luKHBpLCBwaWMtPmxwYmlJbnB1dCwgcGljLT5scGJpT3V0cHV0KTsKICAgIGlmIChociAhPSBJQ0VSUl9PSykKICAgICAgcmV0dXJuIGhyOwogIH0gZWxzZSBpZiAoRGVjb21wcmVzc1F1ZXJ5KHBpLCBwaWMtPmxwYmlJbnB1dCwgcGljLT5scGJpT3V0cHV0KSAhPSBJQ0VSUl9PSykKICAgIHJldHVybiBJQ0VSUl9CQURGT1JNQVQ7CgogIGFzc2VydChwaWMtPmxwYmlJbnB1dC0+YmlXaWR0aCAgPT0gcGljLT5scGJpT3V0cHV0LT5iaVdpZHRoKTsKICBhc3NlcnQocGljLT5scGJpSW5wdXQtPmJpSGVpZ2h0ID09IHBpYy0+bHBiaU91dHB1dC0+YmlIZWlnaHQpOwoKICBwaWMtPmxwYmlPdXRwdXQtPmJpU2l6ZUltYWdlID0gRElCV0lEVEhCWVRFUygqcGljLT5scGJpT3V0cHV0KSAqIHBpYy0+bHBiaU91dHB1dC0+YmlIZWlnaHQ7CiAgaWYgKHBpYy0+bHBiaUlucHV0LT5iaUJpdENvdW50ID09IDQpCiAgICByZXR1cm4gTVNSTEUzMl9EZWNvbXByZXNzUkxFNChwaSwgcGljLT5scGJpT3V0cHV0LCBwaWMtPmxwSW5wdXQsIHBpYy0+bHBPdXRwdXQpOwogIGVsc2UKICAgIHJldHVybiBNU1JMRTMyX0RlY29tcHJlc3NSTEU4KHBpLCBwaWMtPmxwYmlPdXRwdXQsIHBpYy0+bHBJbnB1dCwgcGljLT5scE91dHB1dCk7Cn0KCnN0YXRpYyBMUkVTVUxUIERlY29tcHJlc3NFbmQoQ29kZWNJbmZvICpwaSkKewogIFRSQUNFKCIoJXApXG4iLHBpKTsKCiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgcGktPmJEZWNvbXByZXNzID0gRkFMU0U7CgogIGlmIChwaS0+cGFsZXR0ZV9tYXAgIT0gTlVMTCkgewogICAgTG9jYWxGcmVlKChITE9DQUwpcGktPnBhbGV0dGVfbWFwKTsKICAgIHBpLT5wYWxldHRlX21hcCA9IE5VTEw7CiAgfQoKICByZXR1cm4gSUNFUlJfT0s7Cn0KCnN0YXRpYyBMUkVTVUxUIERlY29tcHJlc3NHZXRQYWxldHRlKENvZGVjSW5mbyAqcGksIExQQ0JJVE1BUElORk9IRUFERVIgbHBiaUluLAoJCQkJICAgIExQQklUTUFQSU5GT0hFQURFUiBscGJpT3V0KQp7CiAgaW50IHNpemU7CgogIFRSQUNFKCIoJXAsJXAsJXApXG4iLHBpLGxwYmlJbixscGJpT3V0KTsKCiAgLyogcHJlLWNvbmRpdGlvbiAqLwogIGFzc2VydChwaSAhPSBOVUxMKTsKCiAgLyogY2hlY2sgcGFyYW1ldGVycyAqLwogIGlmIChscGJpSW4gPT0gTlVMTCB8fCBscGJpT3V0ID09IE5VTEwpCiAgICByZXR1cm4gSUNFUlJfQkFEUEFSQU07CgogIGlmIChEZWNvbXByZXNzUXVlcnkocGksIGxwYmlJbiwgbHBiaU91dCkgIT0gSUNFUlJfT0spCiAgICByZXR1cm4gSUNFUlJfQkFERk9STUFUOwoKICBpZiAobHBiaU91dC0+YmlCaXRDb3VudCA+IDgpCiAgICByZXR1cm4gSUNFUlJfRVJST1I7CgogIGlmIChscGJpSW4tPmJpQml0Q291bnQgPD0gOCkgewogICAgaWYgKGxwYmlJbi0+YmlDbHJVc2VkID4gMCkKICAgICAgc2l6ZSA9IGxwYmlJbi0+YmlDbHJVc2VkOwogICAgZWxzZQogICAgICBzaXplID0gKDEgPDwgbHBiaUluLT5iaUJpdENvdW50KTsKCiAgICBscGJpT3V0LT5iaUNsclVzZWQgPSBzaXplOwoKICAgIG1lbWNweSgoTFBCWVRFKWxwYmlPdXQgKyBscGJpT3V0LT5iaVNpemUsIChjb25zdCBCWVRFKilscGJpSW4gKyBscGJpSW4tPmJpU2l6ZSwgc2l6ZSAqIHNpemVvZihSR0JRVUFEKSk7CiAgfSAvKiBlbHNlIGNvdWxkIG5ldmVyIG9jY3VyICEgKi8KCiAgcmV0dXJuIElDRVJSX09LOwp9CgovKiBEcml2ZXJQcm9jIC0gZW50cnkgcG9pbnQgZm9yIGFuIGluc3RhbGxhYmxlIGRyaXZlciAqLwpMUkVTVUxUIENBTExCQUNLIE1TUkxFMzJfRHJpdmVyUHJvYyhEV09SRF9QVFIgZHdEcnZJRCwgSERSVlIgaERydiwgVUlOVCB1TXNnLAoJCQkJICAgIExQQVJBTSBsUGFyYW0xLCBMUEFSQU0gbFBhcmFtMikKewogIENvZGVjSW5mbyAqcGkgPSAoQ29kZWNJbmZvKilkd0RydklEOwoKICBUUkFDRSgiKCVseCwlcCwweCUwNFgsMHglMDhsWCwweCUwOGxYKVxuIiwgZHdEcnZJRCwgaERydiwgdU1zZywgbFBhcmFtMSwgbFBhcmFtMik7CgogIHN3aXRjaCAodU1zZykgewogICAgLyogc3RhbmRhcmQgZHJpdmVyIG1lc3NhZ2VzICovCiAgY2FzZSBEUlZfTE9BRDoKICAgIHJldHVybiBEUlZDTkZfT0s7CiAgY2FzZSBEUlZfT1BFTjoKICAgICAgcmV0dXJuIChMUkVTVUxUKU9wZW4oKElDT1BFTiopbFBhcmFtMik7CiAgY2FzZSBEUlZfQ0xPU0U6CiAgICBpZiAoZHdEcnZJRCAhPSAweEZGRkYwMDAwICYmIChMUFZPSUQpZHdEcnZJRCAhPSBOVUxMKQogICAgICBDbG9zZShwaSk7CiAgICByZXR1cm4gRFJWQ05GX09LOwogIGNhc2UgRFJWX0VOQUJMRToKICBjYXNlIERSVl9ESVNBQkxFOgogICAgcmV0dXJuIERSVkNORl9PSzsKICBjYXNlIERSVl9GUkVFOgogICAgcmV0dXJuIERSVkNORl9PSzsKICBjYXNlIERSVl9RVUVSWUNPTkZJR1VSRToKICAgIHJldHVybiBEUlZDTkZfQ0FOQ0VMOyAvKiBGSVhNRSAqLwogIGNhc2UgRFJWX0NPTkZJR1VSRToKICAgIHJldHVybiBEUlZDTkZfT0s7ICAgICAvKiBGSVhNRSAqLwogIGNhc2UgRFJWX0lOU1RBTEw6CiAgY2FzZSBEUlZfUkVNT1ZFOgogICAgcmV0dXJuIERSVkNORl9PSzsKCiAgICAvKiBpbnN0YWxsYWJsZSBjb21wcmVzc2lvbiBtYW5hZ2VyIG1lc3NhZ2VzICovCiAgY2FzZSBJQ01fQ09ORklHVVJFOgogICAgRklYTUUoIklDTV9DT05GSUdVUkUgKCVsZClcbiIsbFBhcmFtMSk7CiAgICBpZiAobFBhcmFtMSA9PSAtMSkKICAgICAgcmV0dXJuIElDRVJSX1VOU1VQUE9SVEVEOyAvKiBGSVhNRSAqLwogICAgZWxzZQogICAgICByZXR1cm4gQ29uZmlndXJlKHBpLCAoSFdORClsUGFyYW0xKTsKICBjYXNlIElDTV9BQk9VVDoKICAgIGlmIChsUGFyYW0xID09IC0xKQogICAgICByZXR1cm4gSUNFUlJfT0s7CiAgICBlbHNlCiAgICAgIHJldHVybiBBYm91dChwaSwgKEhXTkQpbFBhcmFtMSk7CiAgY2FzZSBJQ01fR0VUU1RBVEU6CiAgY2FzZSBJQ01fU0VUU1RBVEU6CiAgICByZXR1cm4gMDsgLyogbm8gc3RhdGUgKi8KICBjYXNlIElDTV9HRVRJTkZPOgogICAgcmV0dXJuIEdldEluZm8ocGksIChJQ0lORk8qKWxQYXJhbTEsIChEV09SRClsUGFyYW0yKTsKICBjYXNlIElDTV9HRVRERUZBVUxUUVVBTElUWToKICAgIGlmICgoTFBWT0lEKWxQYXJhbTEgIT0gTlVMTCkgewogICAgICAqKChMUERXT1JEKWxQYXJhbTEpID0gTVNSTEUzMl9ERUZBVUxUUVVBTElUWTsKICAgICAgcmV0dXJuIElDRVJSX09LOwogICAgfQogICAgYnJlYWs7CiAgY2FzZSBJQ01fR0VUUVVBTElUWToKICAgIGlmICgoTFBWT0lEKWxQYXJhbTEgIT0gTlVMTCkgewogICAgICAqKChMUERXT1JEKWxQYXJhbTEpID0gcGktPmR3UXVhbGl0eTsKICAgICAgcmV0dXJuIElDRVJSX09LOwogICAgfQogICAgYnJlYWs7CiAgY2FzZSBJQ01fU0VUUVVBTElUWToKICAgIHJldHVybiBTZXRRdWFsaXR5KHBpLCAqKExQTE9ORylsUGFyYW0xKTsKICBjYXNlIElDTV9DT01QUkVTU19HRVRfRk9STUFUOgogICAgcmV0dXJuIENvbXByZXNzR2V0Rm9ybWF0KHBpLCAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0xLAoJCQkgICAgIChMUEJJVE1BUElORk9IRUFERVIpbFBhcmFtMik7CiAgY2FzZSBJQ01fQ09NUFJFU1NfR0VUX1NJWkU6CiAgICByZXR1cm4gQ29tcHJlc3NHZXRTaXplKHBpLCAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0xLAoJCQkgICAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0yKTsKICBjYXNlIElDTV9DT01QUkVTU19RVUVSWToKICAgIHJldHVybiBDb21wcmVzc1F1ZXJ5KHBpLCAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0xLAoJCQkgKExQQ0JJVE1BUElORk9IRUFERVIpbFBhcmFtMik7CiAgY2FzZSBJQ01fQ09NUFJFU1NfQkVHSU46CiAgICByZXR1cm4gQ29tcHJlc3NCZWdpbihwaSwgKExQQ0JJVE1BUElORk9IRUFERVIpbFBhcmFtMSwKCQkJIChMUENCSVRNQVBJTkZPSEVBREVSKWxQYXJhbTIpOwogIGNhc2UgSUNNX0NPTVBSRVNTOgogICAgcmV0dXJuIENvbXByZXNzKHBpLCAoSUNDT01QUkVTUyopbFBhcmFtMSwgKERXT1JEKWxQYXJhbTIpOwogIGNhc2UgSUNNX0NPTVBSRVNTX0VORDoKICAgIHJldHVybiBDb21wcmVzc0VuZChwaSk7CiAgY2FzZSBJQ01fREVDT01QUkVTU19HRVRfRk9STUFUOgogICAgcmV0dXJuIERlY29tcHJlc3NHZXRGb3JtYXQocGksIChMUENCSVRNQVBJTkZPSEVBREVSKWxQYXJhbTEsCgkJCSAgICAgICAoTFBCSVRNQVBJTkZPSEVBREVSKWxQYXJhbTIpOwogIGNhc2UgSUNNX0RFQ09NUFJFU1NfUVVFUlk6CiAgICByZXR1cm4gRGVjb21wcmVzc1F1ZXJ5KHBpLCAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0xLAoJCQkgICAoTFBDQklUTUFQSU5GT0hFQURFUilsUGFyYW0yKTsKICBjYXNlIElDTV9ERUNPTVBSRVNTX0JFR0lOOgogICAgcmV0dXJuIERlY29tcHJlc3NCZWdpbihwaSwgKExQQ0JJVE1BUElORk9IRUFERVIpbFBhcmFtMSwKCQkJICAgKExQQ0JJVE1BUElORk9IRUFERVIpbFBhcmFtMik7CiAgY2FzZSBJQ01fREVDT01QUkVTUzoKICAgIHJldHVybiBEZWNvbXByZXNzKHBpLCAoSUNERUNPTVBSRVNTKilsUGFyYW0xLCAoRFdPUkQpbFBhcmFtMik7CiAgY2FzZSBJQ01fREVDT01QUkVTU19FTkQ6CiAgICByZXR1cm4gRGVjb21wcmVzc0VuZChwaSk7CiAgY2FzZSBJQ01fREVDT01QUkVTU19TRVRfUEFMRVRURToKICAgIEZJWE1FKCIoLi4uKSAtPiBTZXRQYWxldHRlKCVwLCVwLCVwKTogc3R1YiFcbiIsIHBpLCAoTFBWT0lEKWxQYXJhbTEsIChMUFZPSUQpbFBhcmFtMik7CiAgICByZXR1cm4gSUNFUlJfVU5TVVBQT1JURUQ7CiAgY2FzZSBJQ01fREVDT01QUkVTU19HRVRfUEFMRVRURToKICAgIHJldHVybiBEZWNvbXByZXNzR2V0UGFsZXR0ZShwaSwgKExQQklUTUFQSU5GT0hFQURFUilsUGFyYW0xLAoJCQkJKExQQklUTUFQSU5GT0hFQURFUilsUGFyYW0yKTsKICBjYXNlIElDTV9HRVRERUZBVUxUS0VZRlJBTUVSQVRFOgogICAgaWYgKChMUFZPSUQpbFBhcmFtMSAhPSBOVUxMKQogICAgICAqKExQRFdPUkQpbFBhcmFtMSA9IDE1OwogICAgcmV0dXJuIElDRVJSX09LOwogIGRlZmF1bHQ6CiAgICBpZiAodU1zZyA8IERSVl9VU0VSKQogICAgICByZXR1cm4gRGVmRHJpdmVyUHJvYyhkd0RydklELCBoRHJ2LCB1TXNnLCBsUGFyYW0xLCBsUGFyYW0yKTsKICAgIGVsc2UKICAgICAgRklYTUUoIlVua25vd24gbWVzc2FnZSB1TXNnPTB4JTA4WCBsUGFyYW0xPTB4JTA4bFggbFBhcmFtMj0weCUwOGxYXG4iLHVNc2csbFBhcmFtMSxsUGFyYW0yKTsKICB9OwoKICByZXR1cm4gSUNFUlJfVU5TVVBQT1JURUQ7Cn0KCi8qIERsbE1haW4gLSBsaWJyYXJ5IGluaXRpYWxpemF0aW9uIGNvZGUgKi8KQk9PTCBXSU5BUEkgRGxsTWFpbihISU5TVEFOQ0UgaE1vZHVsZSwgRFdPUkQgZHdSZWFzb24sIExQVk9JRCBscFJlc2VydmVkKQp7CiAgVFJBQ0UoIiglcCwlbGQsJXApXG4iLChMUFZPSUQpaE1vZHVsZSxkd1JlYXNvbixscFJlc2VydmVkKTsKCiAgc3dpdGNoIChkd1JlYXNvbikgewogIGNhc2UgRExMX1BST0NFU1NfQVRUQUNIOgogICAgRGlzYWJsZVRocmVhZExpYnJhcnlDYWxscyhoTW9kdWxlKTsKICAgIE1TUkxFMzJfaE1vZHVsZSA9IGhNb2R1bGU7CiAgICBicmVhazsKCiAgY2FzZSBETExfUFJPQ0VTU19ERVRBQ0g6CiAgICBicmVhazsKICB9CgogIHJldHVybiBUUlVFOwp9Cg==