Ly89PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLy8KLy8gT3V0cHV0RGV2LmgKLy8KLy8gQ29weXJpZ2h0IDE5OTYtMjAwMyBHbHlwaCAmIENvZywgTExDCi8vCi8vPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgovLz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQovLwovLyBNb2RpZmllZCB1bmRlciB0aGUgUG9wcGxlciBwcm9qZWN0IC0gaHR0cDovL3BvcHBsZXIuZnJlZWRlc2t0b3Aub3JnCi8vCi8vIEFsbCBjaGFuZ2VzIG1hZGUgdW5kZXIgdGhlIFBvcHBsZXIgcHJvamVjdCB0byB0aGlzIGZpbGUgYXJlIGxpY2Vuc2VkCi8vIHVuZGVyIEdQTCB2ZXJzaW9uIDIgb3IgbGF0ZXIKLy8KLy8gQ29weXJpZ2h0IChDKSAyMDA1IEpvbmF0aGFuIEJsYW5kZm9yZCA8anJiQHJlZGhhdC5jb20+Ci8vIENvcHlyaWdodCAoQykgMjAwNiBUaG9ya2lsZCBTdHJheSA8dGhvcmtpbGRAaWZpLnVpby5ubz4KLy8gQ29weXJpZ2h0IChDKSAyMDA3IEplZmYgTXVpemVsYWFyIDxqZWZmQGluZmlkaWdtLm5ldD4KLy8gQ29weXJpZ2h0IChDKSAyMDA3LCAyMDExIEFkcmlhbiBKb2huc29uIDxham9obnNvbkByZWRuZW9uLmNvbT4KLy8gQ29weXJpZ2h0IChDKSAyMDA5LTIwMTMgVGhvbWFzIEZyZWl0YWcgPFRob21hcy5GcmVpdGFnQGFsZmEuZGU+Ci8vIENvcHlyaWdodCAoQykgMjAwOSwgMjAxMSBDYXJsb3MgR2FyY2lhIENhbXBvcyA8Y2FybG9zZ2NAZ25vbWUub3JnPgovLyBDb3B5cmlnaHQgKEMpIDIwMDksIDIwMTIsIDIwMTMgQWxiZXJ0IEFzdGFscyBDaWQgPGFhY2lkQGtkZS5vcmc+Ci8vIENvcHlyaWdodCAoQykgMjAxMCBDaHJpc3RpYW4gRmV1ZXJz5G5nZXIgPGNmZXVlcnNhZW5nZXJAZ29vZ2xlbWFpbC5jb20+Ci8vIENvcHlyaWdodCAoQykgMjAxMiBGYWJpbyBEJ1Vyc28gPGZhYmlvZHVyc29AaG90bWFpbC5pdD4KLy8gQ29weXJpZ2h0IChDKSAyMDEyIFdpbGxpYW0gQmFkZXIgPHdpbGxpYW1iYWRlckBob3RtYWlsLmNvbT4KLy8KLy8gVG8gc2VlIGEgZGVzY3JpcHRpb24gb2YgdGhlIGNoYW5nZXMgcGxlYXNlIHNlZSB0aGUgQ2hhbmdlbG9nIGZpbGUgdGhhdAovLyBjYW1lIHdpdGggeW91ciB0YXJiYWxsIG9yIHR5cGUgbWFrZSBDaGFuZ2VMb2cgaWYgeW91IGFyZSBidWlsZGluZyBmcm9tIGdpdAovLwovLz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKI2lmbmRlZiBPVVRQVVRERVZfSAojZGVmaW5lIE9VVFBVVERFVl9ICgojaWZkZWYgVVNFX0dDQ19QUkFHTUFTCiNwcmFnbWEgaW50ZXJmYWNlCiNlbmRpZgoKI2luY2x1ZGUgInBvcHBsZXItY29uZmlnLmgiCiNpbmNsdWRlICJnb28vZ3R5cGVzLmgiCiNpbmNsdWRlICJDaGFyVHlwZXMuaCIKI2luY2x1ZGUgIk9iamVjdC5oIgojaW5jbHVkZSAiUG9wcGxlckNhY2hlLmgiCgpjbGFzcyBBbm5vdDsKY2xhc3MgRGljdDsKY2xhc3MgR29vSGFzaDsKY2xhc3MgR29vU3RyaW5nOwpjbGFzcyBHZnhTdGF0ZTsKY2xhc3MgR2Z4OwpzdHJ1Y3QgR2Z4Q29sb3I7CmNsYXNzIEdmeENvbG9yU3BhY2U7CmNsYXNzIEdmeEltYWdlQ29sb3JNYXA7CmNsYXNzIEdmeEZ1bmN0aW9uU2hhZGluZzsKY2xhc3MgR2Z4QXhpYWxTaGFkaW5nOwpjbGFzcyBHZnhHb3VyYXVkVHJpYW5nbGVTaGFkaW5nOwpjbGFzcyBHZnhQYXRjaE1lc2hTaGFkaW5nOwpjbGFzcyBHZnhSYWRpYWxTaGFkaW5nOwpjbGFzcyBHZnhHb3VyYXVkVHJpYW5nbGVTaGFkaW5nOwpjbGFzcyBHZnhQYXRjaE1lc2hTaGFkaW5nOwpjbGFzcyBTdHJlYW07CmNsYXNzIExpbmtzOwpjbGFzcyBBbm5vdExpbms7CmNsYXNzIENhdGFsb2c7CmNsYXNzIFBhZ2U7CmNsYXNzIEZ1bmN0aW9uOwoKLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KLy8gT3V0cHV0RGV2Ci8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpjbGFzcyBPdXRwdXREZXYgewpwdWJsaWM6CgogIC8vIENvbnN0cnVjdG9yLgogIE91dHB1dERldigpIAojaWZkZWYgVVNFX0NNUwogOiBpY2NDb2xvclNwYWNlQ2FjaGUoNSkKI2VuZGlmCiAgewogICAgICBwcm9maWxlSGFzaCA9IE5VTEw7CiAgfQoKICAvLyBEZXN0cnVjdG9yLgogIHZpcnR1YWwgfk91dHB1dERldigpIHt9CgogIC8vLS0tLS0gZ2V0IGluZm8gYWJvdXQgb3V0cHV0IGRldmljZQoKICAvLyBEb2VzIHRoaXMgZGV2aWNlIHVzZSB1cHNpZGUtZG93biBjb29yZGluYXRlcz8KICAvLyAoVXBzaWRlLWRvd24gbWVhbnMgKDAsMCkgaXMgdGhlIHRvcCBsZWZ0IGNvcm5lciBvZiB0aGUgcGFnZS4pCiAgdmlydHVhbCBHQm9vbCB1cHNpZGVEb3duKCkgPSAwOwoKICAvLyBEb2VzIHRoaXMgZGV2aWNlIHVzZSBkcmF3Q2hhcigpIG9yIGRyYXdTdHJpbmcoKT8KICB2aXJ0dWFsIEdCb29sIHVzZURyYXdDaGFyKCkgPSAwOwoKICAvLyBEb2VzIHRoaXMgZGV2aWNlIHVzZSB0aWxpbmdQYXR0ZXJuRmlsbCgpPyAgSWYgdGhpcyByZXR1cm5zIGZhbHNlLAogIC8vIHRpbGluZyBwYXR0ZXJuIGZpbGxzIHdpbGwgYmUgcmVkdWNlZCB0byBhIHNlcmllcyBvZiBvdGhlciBkcmF3aW5nCiAgLy8gb3BlcmF0aW9ucy4KICB2aXJ0dWFsIEdCb29sIHVzZVRpbGluZ1BhdHRlcm5GaWxsKCkgeyByZXR1cm4gZ0ZhbHNlOyB9CgogIC8vIERvZXMgdGhpcyBkZXZpY2Ugc3VwcG9ydCBzcGVjaWZpYyBzaGFkaW5nIHR5cGVzPwogIC8vIHNlZSBnb3VyYXVkVHJpYW5nbGVTaGFkZWRGaWxsKCkgYW5kIHBhdGNoTWVzaFNoYWRlZEZpbGwoKQogIHZpcnR1YWwgR0Jvb2wgdXNlU2hhZGVkRmlsbHMoaW50IHR5cGUpIHsgcmV0dXJuIGdGYWxzZTsgfQoKICAvLyBEb2VzIHRoaXMgZGV2aWNlIHVzZSBGaWxsQ29sb3JTdG9wKCk/CiAgdmlydHVhbCBHQm9vbCB1c2VGaWxsQ29sb3JTdG9wKCkgeyByZXR1cm4gZ0ZhbHNlOyB9CgogIC8vIERvZXMgdGhpcyBkZXZpY2UgdXNlIGRyYXdGb3JtKCk/ICBJZiB0aGlzIHJldHVybnMgZmFsc2UsCiAgLy8gZm9ybS10eXBlIFhPYmplY3RzIHdpbGwgYmUgaW50ZXJwcmV0ZWQgKGkuZS4sIHVucm9sbGVkKS4KICB2aXJ0dWFsIEdCb29sIHVzZURyYXdGb3JtKCkgeyByZXR1cm4gZ0ZhbHNlOyB9CgogIC8vIERvZXMgdGhpcyBkZXZpY2UgdXNlIGJlZ2luVHlwZTNDaGFyL2VuZFR5cGUzQ2hhcj8gIE90aGVyd2lzZSwKICAvLyB0ZXh0IGluIFR5cGUgMyBmb250cyB3aWxsIGJlIGRyYXduIHdpdGggZHJhd0NoYXIvZHJhd1N0cmluZy4KICB2aXJ0dWFsIEdCb29sIGludGVycHJldFR5cGUzQ2hhcnMoKSA9IDA7CgogIC8vIERvZXMgdGhpcyBkZXZpY2UgbmVlZCBub24tdGV4dCBjb250ZW50PwogIHZpcnR1YWwgR0Jvb2wgbmVlZE5vblRleHQoKSB7IHJldHVybiBnVHJ1ZTsgfQoKICAvLyBEb2VzIHRoaXMgZGV2aWNlIHJlcXVpcmUgaW5jQ2hhckNvdW50IHRvIGJlIGNhbGxlZCBmb3IgdGV4dCBvbgogIC8vIG5vbi1zaG93biBsYXllcnM/CiAgdmlydHVhbCBHQm9vbCBuZWVkQ2hhckNvdW50KCkgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgCiAgLy8gRG9lcyB0aGlzIGRldmljZSBuZWVkIHRvIGNsaXAgcGFnZXMgdG8gdGhlIGNyb3AgYm94IGV2ZW4gd2hlbiB0aGUKICAvLyBib3ggaXMgdGhlIGNyb3AgYm94PwogIHZpcnR1YWwgR0Jvb2wgbmVlZENsaXBUb0Nyb3BCb3goKSB7IHJldHVybiBnRmFsc2U7IH0KCiAgLy8tLS0tLSBpbml0aWFsaXphdGlvbiBhbmQgY29udHJvbAoKICAvLyBTZXQgZGVmYXVsdCB0cmFuc2Zvcm0gbWF0cml4LgogIHZpcnR1YWwgdm9pZCBzZXREZWZhdWx0Q1RNKGRvdWJsZSAqY3RtKTsKCiAgLy8gQ2hlY2sgdG8gc2VlIGlmIGEgcGFnZSBzbGljZSBzaG91bGQgYmUgZGlzcGxheWVkLiAgSWYgdGhpcwogIC8vIHJldHVybnMgZmFsc2UsIHRoZSBwYWdlIGRpc3BsYXkgaXMgYWJvcnRlZC4gIFR5cGljYWxseSwgYW4KICAvLyBPdXRwdXREZXYgd2lsbCB1c2Ugc29tZSBhbHRlcm5hdGUgbWVhbnMgdG8gZGlzcGxheSB0aGUgcGFnZQogIC8vIGJlZm9yZSByZXR1cm5pbmcgZmFsc2UuCiAgdmlydHVhbCBHQm9vbCBjaGVja1BhZ2VTbGljZShQYWdlICpwYWdlLCBkb3VibGUgaERQSSwgZG91YmxlIHZEUEksCgkJCSAgICAgICBpbnQgcm90YXRlLCBHQm9vbCB1c2VNZWRpYUJveCwgR0Jvb2wgY3JvcCwKCQkJICAgICAgIGludCBzbGljZVgsIGludCBzbGljZVksIGludCBzbGljZVcsIGludCBzbGljZUgsCgkJCSAgICAgICBHQm9vbCBwcmludGluZywKCQkJICAgICAgIEdCb29sICgqIGFib3J0Q2hlY2tDYmspKHZvaWQgKmRhdGEpID0gTlVMTCwKCQkJICAgICAgIHZvaWQgKiBhYm9ydENoZWNrQ2JrRGF0YSA9IE5VTEwsCgkJCSAgICAgICBHQm9vbCAoKmFubm90RGlzcGxheURlY2lkZUNiaykoQW5ub3QgKmFubm90LCB2b2lkICp1c2VyX2RhdGEpID0gTlVMTCwKCQkJICAgICAgIHZvaWQgKmFubm90RGlzcGxheURlY2lkZUNia0RhdGEgPSBOVUxMKQogICAgeyByZXR1cm4gZ1RydWU7IH0KCiAgLy8gU3RhcnQgYSBwYWdlLgogIHZpcnR1YWwgdm9pZCBzdGFydFBhZ2UoaW50IHBhZ2VOdW0sIEdmeFN0YXRlICpzdGF0ZSwgWFJlZiAqeHJlZikge30KCiAgLy8gRW5kIGEgcGFnZS4KICB2aXJ0dWFsIHZvaWQgZW5kUGFnZSgpIHt9CgogIC8vIER1bXAgcGFnZSBjb250ZW50cyB0byBkaXNwbGF5LgogIHZpcnR1YWwgdm9pZCBkdW1wKCkge30KCiAgLy8tLS0tLSBjb29yZGluYXRlIGNvbnZlcnNpb24KCiAgLy8gQ29udmVydCBiZXR3ZWVuIGRldmljZSBhbmQgdXNlciBjb29yZGluYXRlcy4KICB2aXJ0dWFsIHZvaWQgY3Z0RGV2VG9Vc2VyKGRvdWJsZSBkeCwgZG91YmxlIGR5LCBkb3VibGUgKnV4LCBkb3VibGUgKnV5KTsKICB2aXJ0dWFsIHZvaWQgY3Z0VXNlclRvRGV2KGRvdWJsZSB1eCwgZG91YmxlIHV5LCBpbnQgKmR4LCBpbnQgKmR5KTsKCiAgZG91YmxlICpnZXREZWZDVE0oKSB7IHJldHVybiBkZWZDVE07IH0KICBkb3VibGUgKmdldERlZklDVE0oKSB7IHJldHVybiBkZWZJQ1RNOyB9CgogIC8vLS0tLS0gc2F2ZS9yZXN0b3JlIGdyYXBoaWNzIHN0YXRlCiAgdmlydHVhbCB2b2lkIHNhdmVTdGF0ZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgcmVzdG9yZVN0YXRlKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQoKICAvLy0tLS0tIHVwZGF0ZSBncmFwaGljcyBzdGF0ZQogIHZpcnR1YWwgdm9pZCB1cGRhdGVBbGwoR2Z4U3RhdGUgKnN0YXRlKTsKICB2aXJ0dWFsIHZvaWQgdXBkYXRlQ1RNKEdmeFN0YXRlICogLypzdGF0ZSovLCBkb3VibGUgLyptMTEqLywgZG91YmxlIC8qbTEyKi8sCgkJCSBkb3VibGUgLyptMjEqLywgZG91YmxlIC8qbTIyKi8sIGRvdWJsZSAvKm0zMSovLCBkb3VibGUgLyptMzIqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlTGluZURhc2goR2Z4U3RhdGUgKiAvKnN0YXRlKi8pIHt9CiAgdmlydHVhbCB2b2lkIHVwZGF0ZUZsYXRuZXNzKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVMaW5lSm9pbihHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlTGluZUNhcChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlTWl0ZXJMaW1pdChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlTGluZVdpZHRoKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVTdHJva2VBZGp1c3QoR2Z4U3RhdGUgKiAvKnN0YXRlKi8pIHt9CiAgdmlydHVhbCB2b2lkIHVwZGF0ZUFscGhhSXNTaGFwZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlVGV4dEtub2Nrb3V0KEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVGaWxsQ29sb3JTcGFjZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlU3Ryb2tlQ29sb3JTcGFjZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlRmlsbENvbG9yKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVTdHJva2VDb2xvcihHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlQmxlbmRNb2RlKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVGaWxsT3BhY2l0eShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlU3Ryb2tlT3BhY2l0eShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlRmlsbE92ZXJwcmludChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlU3Ryb2tlT3ZlcnByaW50KEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVPdmVycHJpbnRNb2RlKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVUcmFuc2ZlcihHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlRmlsbENvbG9yU3RvcChHZnhTdGF0ZSAqIC8qc3RhdGUqLywgZG91YmxlIC8qb2Zmc2V0Ki8pIHt9CgogIC8vLS0tLS0gdXBkYXRlIHRleHQgc3RhdGUKICB2aXJ0dWFsIHZvaWQgdXBkYXRlRm9udChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlVGV4dE1hdChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlQ2hhclNwYWNlKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVSZW5kZXIoR2Z4U3RhdGUgKiAvKnN0YXRlKi8pIHt9CiAgdmlydHVhbCB2b2lkIHVwZGF0ZVJpc2UoR2Z4U3RhdGUgKiAvKnN0YXRlKi8pIHt9CiAgdmlydHVhbCB2b2lkIHVwZGF0ZVdvcmRTcGFjZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgdXBkYXRlSG9yaXpTY2FsaW5nKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVUZXh0UG9zKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCB1cGRhdGVUZXh0U2hpZnQoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIGRvdWJsZSAvKnNoaWZ0Ki8pIHt9CiAgdmlydHVhbCB2b2lkIHNhdmVUZXh0UG9zKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCByZXN0b3JlVGV4dFBvcyhHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KCiAgLy8tLS0tLSBwYXRoIHBhaW50aW5nCiAgdmlydHVhbCB2b2lkIHN0cm9rZShHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgZmlsbChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgZW9GaWxsKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgR0Jvb2wgdGlsaW5nUGF0dGVybkZpbGwoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIEdmeCAqIC8qZ2Z4Ki8sIENhdGFsb2cgKiAvKmNhdCovLCBPYmplY3QgKiAvKnN0ciovLAoJCQkJICBkb3VibGUgKiAvKnBtYXQqLywgaW50IC8qcGFpbnRUeXBlKi8sIGludCAvKnRpbGluZ1R5cGUqLywgRGljdCAqIC8qcmVzRGljdCovLAoJCQkJICBkb3VibGUgKiAvKm1hdCovLCBkb3VibGUgKiAvKmJib3gqLywKCQkJCSAgaW50IC8qeDAqLywgaW50IC8qeTAqLywgaW50IC8qeDEqLywgaW50IC8qeTEqLywKCQkJCSAgZG91YmxlIC8qeFN0ZXAqLywgZG91YmxlIC8qeVN0ZXAqLykKICAgIHsgcmV0dXJuIGdGYWxzZTsgfQogIHZpcnR1YWwgR0Jvb2wgZnVuY3Rpb25TaGFkZWRGaWxsKEdmeFN0YXRlICogLypzdGF0ZSovLAoJCQkJICAgR2Z4RnVuY3Rpb25TaGFkaW5nICogLypzaGFkaW5nKi8pCiAgICB7IHJldHVybiBnRmFsc2U7IH0KICB2aXJ0dWFsIEdCb29sIGF4aWFsU2hhZGVkRmlsbChHZnhTdGF0ZSAqIC8qc3RhdGUqLywgR2Z4QXhpYWxTaGFkaW5nICogLypzaGFkaW5nKi8sIGRvdWJsZSAvKnRNaW4qLywgZG91YmxlIC8qdE1heCovKQogICAgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgdmlydHVhbCBHQm9vbCBheGlhbFNoYWRlZFN1cHBvcnRFeHRlbmQoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIEdmeEF4aWFsU2hhZGluZyAqIC8qc2hhZGluZyovKQogICAgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgdmlydHVhbCBHQm9vbCByYWRpYWxTaGFkZWRGaWxsKEdmeFN0YXRlICogLypzdGF0ZSovLCBHZnhSYWRpYWxTaGFkaW5nICogLypzaGFkaW5nKi8sIGRvdWJsZSAvKnNNaW4qLywgZG91YmxlIC8qc01heCovKQogICAgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgdmlydHVhbCBHQm9vbCByYWRpYWxTaGFkZWRTdXBwb3J0RXh0ZW5kKEdmeFN0YXRlICogLypzdGF0ZSovLCBHZnhSYWRpYWxTaGFkaW5nICogLypzaGFkaW5nKi8pCiAgICB7IHJldHVybiBnRmFsc2U7IH0KICB2aXJ0dWFsIEdCb29sIGdvdXJhdWRUcmlhbmdsZVNoYWRlZEZpbGwoR2Z4U3RhdGUgKnN0YXRlLCBHZnhHb3VyYXVkVHJpYW5nbGVTaGFkaW5nICpzaGFkaW5nKQogICAgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgdmlydHVhbCBHQm9vbCBwYXRjaE1lc2hTaGFkZWRGaWxsKEdmeFN0YXRlICpzdGF0ZSwgR2Z4UGF0Y2hNZXNoU2hhZGluZyAqc2hhZGluZykKICAgIHsgcmV0dXJuIGdGYWxzZTsgfQoKICAvLy0tLS0tIHBhdGggY2xpcHBpbmcKICB2aXJ0dWFsIHZvaWQgY2xpcChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgZW9DbGlwKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCBjbGlwVG9TdHJva2VQYXRoKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQoKICAvLy0tLS0tIHRleHQgZHJhd2luZwogIHZpcnR1YWwgdm9pZCBiZWdpblN0cmluZ09wKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCBlbmRTdHJpbmdPcChHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgYmVnaW5TdHJpbmcoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIEdvb1N0cmluZyAqIC8qcyovKSB7fQogIHZpcnR1YWwgdm9pZCBlbmRTdHJpbmcoR2Z4U3RhdGUgKiAvKnN0YXRlKi8pIHt9CiAgdmlydHVhbCB2b2lkIGRyYXdDaGFyKEdmeFN0YXRlICogLypzdGF0ZSovLCBkb3VibGUgLyp4Ki8sIGRvdWJsZSAvKnkqLywKCQkJZG91YmxlIC8qZHgqLywgZG91YmxlIC8qZHkqLywKCQkJZG91YmxlIC8qb3JpZ2luWCovLCBkb3VibGUgLypvcmlnaW5ZKi8sCgkJCUNoYXJDb2RlIC8qY29kZSovLCBpbnQgLypuQnl0ZXMqLywgVW5pY29kZSAqIC8qdSovLCBpbnQgLyp1TGVuKi8pIHt9CiAgdmlydHVhbCB2b2lkIGRyYXdTdHJpbmcoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIEdvb1N0cmluZyAqIC8qcyovKSB7fQogIHZpcnR1YWwgR0Jvb2wgYmVnaW5UeXBlM0NoYXIoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIGRvdWJsZSAvKngqLywgZG91YmxlIC8qeSovLAoJCQkgICAgICAgZG91YmxlIC8qZHgqLywgZG91YmxlIC8qZHkqLywKCQkJICAgICAgIENoYXJDb2RlIC8qY29kZSovLCBVbmljb2RlICogLyp1Ki8sIGludCAvKnVMZW4qLyk7CiAgdmlydHVhbCB2b2lkIGVuZFR5cGUzQ2hhcihHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KICB2aXJ0dWFsIHZvaWQgYmVnaW5UZXh0T2JqZWN0KEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCBlbmRUZXh0T2JqZWN0KEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCBpbmNDaGFyQ291bnQoaW50IC8qbkNoYXJzKi8pIHt9CiAgdmlydHVhbCB2b2lkIGJlZ2luQWN0dWFsVGV4dChHZnhTdGF0ZSAqIC8qc3RhdGUqLywgR29vU3RyaW5nICogLyp0ZXh0Ki8gKSB7fQogIHZpcnR1YWwgdm9pZCBlbmRBY3R1YWxUZXh0KEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQoKICAvLy0tLS0tIGltYWdlIGRyYXdpbmcKICB2aXJ0dWFsIHZvaWQgZHJhd0ltYWdlTWFzayhHZnhTdGF0ZSAqc3RhdGUsIE9iamVjdCAqcmVmLCBTdHJlYW0gKnN0ciwKCQkJICAgICBpbnQgd2lkdGgsIGludCBoZWlnaHQsIEdCb29sIGludmVydCwgR0Jvb2wgaW50ZXJwb2xhdGUsCgkJCSAgICAgR0Jvb2wgaW5saW5lSW1nKTsKICB2aXJ0dWFsIHZvaWQgc2V0U29mdE1hc2tGcm9tSW1hZ2VNYXNrKEdmeFN0YXRlICpzdGF0ZSwKCQkJCQlPYmplY3QgKnJlZiwgU3RyZWFtICpzdHIsCgkJCQkJaW50IHdpZHRoLCBpbnQgaGVpZ2h0LCBHQm9vbCBpbnZlcnQsCgkJCQkJR0Jvb2wgaW5saW5lSW1nLCBkb3VibGUgKmJhc2VNYXRyaXgpOwogIHZpcnR1YWwgdm9pZCB1bnNldFNvZnRNYXNrRnJvbUltYWdlTWFzayhHZnhTdGF0ZSAqc3RhdGUsIGRvdWJsZSAqYmFzZU1hdHJpeCk7CiAgdmlydHVhbCB2b2lkIGRyYXdJbWFnZShHZnhTdGF0ZSAqc3RhdGUsIE9iamVjdCAqcmVmLCBTdHJlYW0gKnN0ciwKCQkJIGludCB3aWR0aCwgaW50IGhlaWdodCwgR2Z4SW1hZ2VDb2xvck1hcCAqY29sb3JNYXAsCgkJCSBHQm9vbCBpbnRlcnBvbGF0ZSwgaW50ICptYXNrQ29sb3JzLCBHQm9vbCBpbmxpbmVJbWcpOwogIHZpcnR1YWwgdm9pZCBkcmF3TWFza2VkSW1hZ2UoR2Z4U3RhdGUgKnN0YXRlLCBPYmplY3QgKnJlZiwgU3RyZWFtICpzdHIsCgkJCSAgICAgICBpbnQgd2lkdGgsIGludCBoZWlnaHQsCgkJCSAgICAgICBHZnhJbWFnZUNvbG9yTWFwICpjb2xvck1hcCwgR0Jvb2wgaW50ZXJwb2xhdGUsCgkJCSAgICAgICBTdHJlYW0gKm1hc2tTdHIsIGludCBtYXNrV2lkdGgsIGludCBtYXNrSGVpZ2h0LAoJCQkgICAgICAgR0Jvb2wgbWFza0ludmVydCwgR0Jvb2wgbWFza0ludGVycG9sYXRlKTsKICB2aXJ0dWFsIHZvaWQgZHJhd1NvZnRNYXNrZWRJbWFnZShHZnhTdGF0ZSAqc3RhdGUsIE9iamVjdCAqcmVmLCBTdHJlYW0gKnN0ciwKCQkJCSAgIGludCB3aWR0aCwgaW50IGhlaWdodCwKCQkJCSAgIEdmeEltYWdlQ29sb3JNYXAgKmNvbG9yTWFwLAoJCQkJICAgR0Jvb2wgaW50ZXJwb2xhdGUsCgkJCQkgICBTdHJlYW0gKm1hc2tTdHIsCgkJCQkgICBpbnQgbWFza1dpZHRoLCBpbnQgbWFza0hlaWdodCwKCQkJCSAgIEdmeEltYWdlQ29sb3JNYXAgKm1hc2tDb2xvck1hcCwKCQkJCSAgIEdCb29sIG1hc2tJbnRlcnBvbGF0ZSk7CgogIC8vLS0tLS0gZ3JvdXBpbmcgb3BlcmF0b3JzCgogIHZpcnR1YWwgdm9pZCBlbmRNYXJrZWRDb250ZW50KEdmeFN0YXRlICpzdGF0ZSk7CiAgdmlydHVhbCB2b2lkIGJlZ2luTWFya2VkQ29udGVudChjaGFyICpuYW1lLCBEaWN0ICpwcm9wZXJ0aWVzKTsKICB2aXJ0dWFsIHZvaWQgbWFya1BvaW50KGNoYXIgKm5hbWUpOwogIHZpcnR1YWwgdm9pZCBtYXJrUG9pbnQoY2hhciAqbmFtZSwgRGljdCAqcHJvcGVydGllcyk7CgoKCiNpZiBPUElfU1VQUE9SVAogIC8vLS0tLS0gT1BJIGZ1bmN0aW9ucwogIHZpcnR1YWwgdm9pZCBvcGlCZWdpbihHZnhTdGF0ZSAqc3RhdGUsIERpY3QgKm9waURpY3QpOwogIHZpcnR1YWwgdm9pZCBvcGlFbmQoR2Z4U3RhdGUgKnN0YXRlLCBEaWN0ICpvcGlEaWN0KTsKI2VuZGlmCgogIC8vLS0tLS0gVHlwZSAzIGZvbnQgb3BlcmF0b3JzCiAgdmlydHVhbCB2b2lkIHR5cGUzRDAoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIGRvdWJsZSAvKnd4Ki8sIGRvdWJsZSAvKnd5Ki8pIHt9CiAgdmlydHVhbCB2b2lkIHR5cGUzRDEoR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIGRvdWJsZSAvKnd4Ki8sIGRvdWJsZSAvKnd5Ki8sCgkJICAgICAgIGRvdWJsZSAvKmxseCovLCBkb3VibGUgLypsbHkqLywgZG91YmxlIC8qdXJ4Ki8sIGRvdWJsZSAvKnVyeSovKSB7fQoKICAvLy0tLS0tIGZvcm0gWE9iamVjdHMKICB2aXJ0dWFsIHZvaWQgZHJhd0Zvcm0oUmVmIC8qaWQqLykge30KCiAgLy8tLS0tLSBQb3N0U2NyaXB0IFhPYmplY3RzCiAgdmlydHVhbCB2b2lkIHBzWE9iamVjdChTdHJlYW0gKiAvKnBzU3RyZWFtKi8sIFN0cmVhbSAqIC8qbGV2ZWwxU3RyZWFtKi8pIHt9CgogIC8vLS0tLS0gUHJvZmlsaW5nCiAgdmlydHVhbCB2b2lkIHN0YXJ0UHJvZmlsZSgpOwogIHZpcnR1YWwgR29vSGFzaCAqZ2V0UHJvZmlsZUhhc2goKSB7cmV0dXJuIHByb2ZpbGVIYXNoOyB9CiAgdmlydHVhbCBHb29IYXNoICplbmRQcm9maWxlKCk7CgogIC8vLS0tLS0gdHJhbnNwYXJlbmN5IGdyb3VwcyBhbmQgc29mdCBtYXNrcwogIHZpcnR1YWwgR0Jvb2wgY2hlY2tUcmFuc3BhcmVuY3lHcm91cChHZnhTdGF0ZSAqIC8qc3RhdGUqLywgR0Jvb2wgLyprbm9ja291dCovKSB7IHJldHVybiBnVHJ1ZTsgfQogIHZpcnR1YWwgdm9pZCBiZWdpblRyYW5zcGFyZW5jeUdyb3VwKEdmeFN0YXRlICogLypzdGF0ZSovLCBkb3VibGUgKiAvKmJib3gqLywKCQkJCSAgICAgIEdmeENvbG9yU3BhY2UgKiAvKmJsZW5kaW5nQ29sb3JTcGFjZSovLAoJCQkJICAgICAgR0Jvb2wgLyppc29sYXRlZCovLCBHQm9vbCAvKmtub2Nrb3V0Ki8sCgkJCQkgICAgICBHQm9vbCAvKmZvclNvZnRNYXNrKi8pIHt9CiAgdmlydHVhbCB2b2lkIGVuZFRyYW5zcGFyZW5jeUdyb3VwKEdmeFN0YXRlICogLypzdGF0ZSovKSB7fQogIHZpcnR1YWwgdm9pZCBwYWludFRyYW5zcGFyZW5jeUdyb3VwKEdmeFN0YXRlICogLypzdGF0ZSovLCBkb3VibGUgKiAvKmJib3gqLykge30KICB2aXJ0dWFsIHZvaWQgc2V0U29mdE1hc2soR2Z4U3RhdGUgKiAvKnN0YXRlKi8sIGRvdWJsZSAqIC8qYmJveCovLCBHQm9vbCAvKmFscGhhKi8sCgkJCSAgIEZ1bmN0aW9uICogLyp0cmFuc2ZlckZ1bmMqLywgR2Z4Q29sb3IgKiAvKmJhY2tkcm9wQ29sb3IqLykge30KICB2aXJ0dWFsIHZvaWQgY2xlYXJTb2Z0TWFzayhHZnhTdGF0ZSAqIC8qc3RhdGUqLykge30KCiAgLy8tLS0tLSBsaW5rcwogIHZpcnR1YWwgdm9pZCBwcm9jZXNzTGluayhBbm5vdExpbmsgKiAvKmxpbmsqLykge30KCiNpZiAxIC8vfnRtcDogdHVybiBvZmYgYW50aS1hbGlhc2luZyB0ZW1wb3JhcmlseQogIHZpcnR1YWwgR0Jvb2wgZ2V0VmVjdG9yQW50aWFsaWFzKCkgeyByZXR1cm4gZ0ZhbHNlOyB9CiAgdmlydHVhbCB2b2lkIHNldFZlY3RvckFudGlhbGlhcyhHQm9vbCAvKnZhYSovKSB7fQojZW5kaWYKCiNpZmRlZiBVU0VfQ01TCiAgUG9wcGxlckNhY2hlICpnZXRJY2NDb2xvclNwYWNlQ2FjaGUoKTsKI2VuZGlmCgpwcml2YXRlOgoKICBkb3VibGUgZGVmQ1RNWzZdOwkJLy8gZGVmYXVsdCBjb29yZGluYXRlIHRyYW5zZm9ybSBtYXRyaXgKICBkb3VibGUgZGVmSUNUTVs2XTsJCS8vIGludmVyc2Ugb2YgZGVmYXVsdCBDVE0KICBHb29IYXNoICpwcm9maWxlSGFzaDsKCiNpZmRlZiBVU0VfQ01TCiAgUG9wcGxlckNhY2hlIGljY0NvbG9yU3BhY2VDYWNoZTsKI2VuZGlmCn07CgojZW5kaWYK