LyoqCiAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAgKiBAZmlsZSAgICBzdG0zMmc0eHhfaGFsX3d3ZGcuYwogICogQGF1dGhvciAgTUNEIEFwcGxpY2F0aW9uIFRlYW0KICAqIEBicmllZiAgIFdXREcgSEFMIG1vZHVsZSBkcml2ZXIuCiAgKiAgICAgICAgICBUaGlzIGZpbGUgcHJvdmlkZXMgZmlybXdhcmUgZnVuY3Rpb25zIHRvIG1hbmFnZSB0aGUgZm9sbG93aW5nCiAgKiAgICAgICAgICBmdW5jdGlvbmFsaXRpZXMgb2YgdGhlIFdpbmRvdyBXYXRjaGRvZyAoV1dERykgcGVyaXBoZXJhbDoKICAqICAgICAgICAgICArIEluaXRpYWxpemF0aW9uIGFuZCBDb25maWd1cmF0aW9uIGZ1bmN0aW9ucwogICogICAgICAgICAgICsgSU8gb3BlcmF0aW9uIGZ1bmN0aW9ucwogIEB2ZXJiYXRpbQogID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQogICAgICAgICAgICAgICAgICAgICAgIyMjIyMgV1dERyBTcGVjaWZpYyBmZWF0dXJlcyAjIyMjIwogID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQogIFsuLl0KICAgIE9uY2UgZW5hYmxlZCB0aGUgV1dERyBnZW5lcmF0ZXMgYSBzeXN0ZW0gcmVzZXQgb24gZXhwaXJ5IG9mIGEgcHJvZ3JhbW1lZAogICAgdGltZSBwZXJpb2QsIHVubGVzcyB0aGUgcHJvZ3JhbSByZWZyZXNoZXMgdGhlIGNvdW50ZXIgKFRbNjswXSBkb3duY291bnRlcikKICAgIGJlZm9yZSByZWFjaGluZyAweDNGIHZhbHVlIChpLmUuIGEgcmVzZXQgaXMgZ2VuZXJhdGVkIHdoZW4gdGhlIGNvdW50ZXIKICAgIHZhbHVlIHJvbGxzIGRvd24gZnJvbSAweDQwIHRvIDB4M0YpLgoKICAgICgrKSBBbiBNQ1UgcmVzZXQgaXMgYWxzbyBnZW5lcmF0ZWQgaWYgdGhlIGNvdW50ZXIgdmFsdWUgaXMgcmVmcmVzaGVkCiAgICAgICAgYmVmb3JlIHRoZSBjb3VudGVyIGhhcyByZWFjaGVkIHRoZSByZWZyZXNoIHdpbmRvdyB2YWx1ZS4gVGhpcwogICAgICAgIGltcGxpZXMgdGhhdCB0aGUgY291bnRlciBtdXN0IGJlIHJlZnJlc2hlZCBpbiBhIGxpbWl0ZWQgd2luZG93LgogICAgKCspIE9uY2UgZW5hYmxlZCB0aGUgV1dERyBjYW5ub3QgYmUgZGlzYWJsZWQgZXhjZXB0IGJ5IGEgc3lzdGVtIHJlc2V0LgogICAgKCspIElmIHJlcXVpcmVkIGJ5IGFwcGxpY2F0aW9uLCBhbiBFYXJseSBXYWtldXAgSW50ZXJydXB0IGNhbiBiZSB0cmlnZ2VyZWQKICAgICAgICBpbiBvcmRlciB0byBiZSB3YXJuZWQgYmVmb3JlIFdXREcgZXhwaXJhdGlvbi4gVGhlIEVhcmx5IFdha2V1cCBJbnRlcnJ1cHQKICAgICAgICAoRVdJKSBjYW4gYmUgdXNlZCBpZiBzcGVjaWZpYyBzYWZldHkgb3BlcmF0aW9ucyBvciBkYXRhIGxvZ2dpbmcgbXVzdAogICAgICAgIGJlIHBlcmZvcm1lZCBiZWZvcmUgdGhlIGFjdHVhbCByZXNldCBpcyBnZW5lcmF0ZWQuIFdoZW4gdGhlIGRvd25jb3VudGVyCiAgICAgICAgcmVhY2hlcyAweDQwLCBpbnRlcnJ1cHQgb2NjdXJzLiBUaGlzIG1lY2hhbmlzbSByZXF1aXJlcyBXV0RHIGludGVycnVwdAogICAgICAgIGxpbmUgdG8gYmUgZW5hYmxlZCBpbiBOVklDLiBPbmNlIGVuYWJsZWQsIEVXSSBpbnRlcnJ1cHQgY2Fubm90IGJlCiAgICAgICAgZGlzYWJsZWQgZXhjZXB0IGJ5IGEgc3lzdGVtIHJlc2V0LgogICAgKCspIFdXREdSU1QgZmxhZyBpbiBSQ0MgQ1NSIHJlZ2lzdGVyIGNhbiBiZSB1c2VkIHRvIGluZm9ybSB3aGVuIGEgV1dERwogICAgICAgIHJlc2V0IG9jY3Vycy4KICAgICgrKSBUaGUgV1dERyBjb3VudGVyIGlucHV0IGNsb2NrIGlzIGRlcml2ZWQgZnJvbSB0aGUgQVBCIGNsb2NrIGRpdmlkZWQKICAgICAgICBieSBhIHByb2dyYW1tYWJsZSBwcmVzY2FsZXIuCiAgICAoKykgV1dERyBjbG9jayAoSHopID0gUENMSzEgLyAoNDA5NiAqIFByZXNjYWxlcikKICAgICgrKSBXV0RHIHRpbWVvdXQgKG1TKSA9IDEwMDAgKiAoVFs1OzBdICsgMSkgLyBXV0RHIGNsb2NrIChIeikKICAgICAgICB3aGVyZSBUWzU7MF0gYXJlIHRoZSBsb3dlc3QgNiBiaXRzIG9mIENvdW50ZXIuCiAgICAoKykgV1dERyBDb3VudGVyIHJlZnJlc2ggaXMgYWxsb3dlZCBiZXR3ZWVuIHRoZSBmb2xsb3dpbmcgbGltaXRzIDoKICAgICAgICAoKyspIG1pbiB0aW1lIChtUykgPSAxMDAwICogKENvdW50ZXIgLSBXaW5kb3cpIC8gV1dERyBjbG9jawogICAgICAgICgrKykgbWF4IHRpbWUgKG1TKSA9IDEwMDAgKiAoQ291bnRlciAtIDB4NDApIC8gV1dERyBjbG9jawogICAgKCspIFR5cGljYWwgdmFsdWVzOgogICAgICAgICgrKykgQ291bnRlciBtaW4gKFRbNTswXSA9IDB4MDApIGF0IDE3ME1IeiAoUENMSzEpIHdpdGggemVybyBwcmVzY2FsZXI6CiAgICAgICAgICAgICBtYXggdGltZW91dCBiZWZvcmUgcmVzZXQ6IGFwcHJveGltYXRlbHkgMjQuMDm1cwogICAgICAgICgrKykgQ291bnRlciBtYXggKFRbNTswXSA9IDB4M0YpIGF0IDE3ME1IeiAoUENMSzEpIHdpdGggcHJlc2NhbGVyCiAgICAgICAgICAgICBkaXZpZGluZyBieSAxMjg6CiAgICAgICAgICAgICBtYXggdGltZW91dCBiZWZvcmUgcmVzZXQ6IGFwcHJveGltYXRlbHkgMTk3LjM4bXMKCiAgICAgICAgICAgICAgICAgICAgICMjIyMjIEhvdyB0byB1c2UgdGhpcyBkcml2ZXIgIyMjIyMKICA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCiAgICAqKiogQ29tbW9uIGRyaXZlciB1c2FnZSAqKioKICAgID09PT09PT09PT09PT09PT09PT09PT09PT09PQoKICBbLi5dCiAgICAoKykgRW5hYmxlIFdXREcgQVBCMSBjbG9jayB1c2luZyBfX0hBTF9SQ0NfV1dER19DTEtfRU5BQkxFKCkuCiAgICAoKykgQ29uZmlndXJlIHRoZSBXV0RHIHByZXNjYWxlciwgcmVmcmVzaCB3aW5kb3cgdmFsdWUsIGNvdW50ZXIgdmFsdWUgYW5kIGVhcmx5CiAgICAgICAgaW50ZXJydXB0IHN0YXR1cyB1c2luZyBIQUxfV1dER19Jbml0KCkgZnVuY3Rpb24uIFRoaXMgd2lsbCBhdXRvbWF0aWNhbGx5CiAgICAgICAgZW5hYmxlIFdXREcgYW5kIHN0YXJ0IGl0cyBkb3duY291bnRlci4gVGltZSByZWZlcmVuY2UgY2FuIGJlIHRha2VuIGZyb20gCiAgICAgICAgZnVuY3Rpb24gZXhpdC4gQ2FyZSBtdXN0IGJlIHRha2VuIHRvIHByb3ZpZGUgYSBjb3VudGVyIHZhbHVlCiAgICAgICAgZ3JlYXRlciB0aGFuIDB4NDAgdG8gcHJldmVudCBnZW5lcmF0aW9uIG9mIGltbWVkaWF0ZSByZXNldC4KICAgICgrKSBJZiB0aGUgRWFybHkgV2FrZXVwIEludGVycnVwdCAoRVdJKSBmZWF0dXJlIGlzIGVuYWJsZWQsIGFuIGludGVycnVwdCBpcwogICAgICAgIGdlbmVyYXRlZCB3aGVuIHRoZSBjb3VudGVyIHJlYWNoZXMgMHg0MC4gV2hlbiBIQUxfV1dER19JUlFIYW5kbGVyIGlzCiAgICAgICAgdHJpZ2dlcmVkIGJ5IHRoZSBpbnRlcnJ1cHQgc2VydmljZSByb3V0aW5lLCBmbGFnIHdpbGwgYmUgYXV0b21hdGljYWxseQogICAgICAgIGNsZWFyZWQgYW5kIEhBTF9XV0RHX1dha2V1cENhbGxiYWNrIHVzZXIgY2FsbGJhY2sgd2lsbCBiZSBleGVjdXRlZC4gVXNlcgogICAgICAgIGNhbiBhZGQgaGlzIG93biBjb2RlIGJ5IGN1c3RvbWl6YXRpb24gb2YgY2FsbGJhY2sgSEFMX1dXREdfV2FrZXVwQ2FsbGJhY2suCiAgICAoKykgVGhlbiB0aGUgYXBwbGljYXRpb24gcHJvZ3JhbSBtdXN0IHJlZnJlc2ggdGhlIFdXREcgY291bnRlciBhdCByZWd1bGFyCiAgICAgICAgaW50ZXJ2YWxzIGR1cmluZyBub3JtYWwgb3BlcmF0aW9uIHRvIHByZXZlbnQgYW4gTUNVIHJlc2V0LCB1c2luZwogICAgICAgIEhBTF9XV0RHX1JlZnJlc2goKSBmdW5jdGlvbi4gVGhpcyBvcGVyYXRpb24gbXVzdCBvY2N1ciBvbmx5IHdoZW4KICAgICAgICB0aGUgY291bnRlciBpcyBsb3dlciB0aGFuIHRoZSByZWZyZXNoIHdpbmRvdyB2YWx1ZSBhbHJlYWR5IHByb2dyYW1tZWQuCgogICAgKioqIENhbGxiYWNrIHJlZ2lzdHJhdGlvbiAqKioKICAgID09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgogIFsuLl0KICAgIFRoZSBjb21waWxhdGlvbiBkZWZpbmUgVVNFX0hBTF9XV0RHX1JFR0lTVEVSX0NBTExCQUNLUyB3aGVuIHNldCB0byAxIGFsbG93cwogICAgdGhlIHVzZXIgdG8gY29uZmlndXJlIGR5bmFtaWNhbGx5IHRoZSBkcml2ZXIgY2FsbGJhY2tzLiBVc2UgRnVuY3Rpb25zCiAgICBIQUxfV1dER19SZWdpc3RlckNhbGxiYWNrKCkgdG8gcmVnaXN0ZXIgYSB1c2VyIGNhbGxiYWNrLgoKICAgICgrKSBGdW5jdGlvbiBIQUxfV1dER19SZWdpc3RlckNhbGxiYWNrKCkgYWxsb3dzIHRvIHJlZ2lzdGVyIGZvbGxvd2luZwogICAgICAgIGNhbGxiYWNrczoKICAgICAgICAoKyspIEV3aUNhbGxiYWNrIDogY2FsbGJhY2sgZm9yIEVhcmx5IFdha2VVcCBJbnRlcnJ1cHQuCiAgICAgICAgKCsrKSBNc3BJbml0Q2FsbGJhY2sgOiBXV0RHIE1zcEluaXQuCiAgICBUaGlzIGZ1bmN0aW9uIHRha2VzIGFzIHBhcmFtZXRlcnMgdGhlIEhBTCBwZXJpcGhlcmFsIGhhbmRsZSwgdGhlIENhbGxiYWNrIElECiAgICBhbmQgYSBwb2ludGVyIHRvIHRoZSB1c2VyIGNhbGxiYWNrIGZ1bmN0aW9uLgoKICAgICgrKSBVc2UgZnVuY3Rpb24gSEFMX1dXREdfVW5SZWdpc3RlckNhbGxiYWNrKCkgdG8gcmVzZXQgYSBjYWxsYmFjayB0bwogICAgdGhlIGRlZmF1bHQgd2VhayAoc3VyY2hhcmdlZCkgZnVuY3Rpb24uIEhBTF9XV0RHX1VuUmVnaXN0ZXJDYWxsYmFjaygpCiAgICB0YWtlcyBhcyBwYXJhbWV0ZXJzIHRoZSBIQUwgcGVyaXBoZXJhbCBoYW5kbGUgYW5kIHRoZSBDYWxsYmFjayBJRC4KICAgIFRoaXMgZnVuY3Rpb24gYWxsb3dzIHRvIHJlc2V0IGZvbGxvd2luZyBjYWxsYmFja3M6CiAgICAgICAgKCsrKSBFd2lDYWxsYmFjayA6IGNhbGxiYWNrIGZvciAgRWFybHkgV2FrZVVwIEludGVycnVwdC4KICAgICAgICAoKyspIE1zcEluaXRDYWxsYmFjayA6IFdXREcgTXNwSW5pdC4KCiAgICBbLi5dCiAgICBXaGVuIGNhbGxpbmcgSEFMX1dXREdfSW5pdCBmdW5jdGlvbiwgY2FsbGJhY2tzIGFyZSByZXNldCB0byB0aGUKICAgIGNvcnJlc3BvbmRpbmcgbGVnYWN5IHdlYWsgKHN1cmNoYXJnZWQpIGZ1bmN0aW9uczoKICAgIEhBTF9XV0RHX0Vhcmx5V2FrZXVwQ2FsbGJhY2soKSBhbmQgSEFMX1dXREdfTXNwSW5pdCgpIG9ubHkgaWYgdGhleSBoYXZlCiAgICBub3QgYmVlbiByZWdpc3RlcmVkIGJlZm9yZS4KCiAgICBbLi5dCiAgICBXaGVuIGNvbXBpbGF0aW9uIGRlZmluZSBVU0VfSEFMX1dXREdfUkVHSVNURVJfQ0FMTEJBQ0tTIGlzIHNldCB0byAwIG9yCiAgICBub3QgZGVmaW5lZCwgdGhlIGNhbGxiYWNrIHJlZ2lzdGVyaW5nIGZlYXR1cmUgaXMgbm90IGF2YWlsYWJsZQogICAgYW5kIHdlYWsgKHN1cmNoYXJnZWQpIGNhbGxiYWNrcyBhcmUgdXNlZC4KCiAgICAqKiogV1dERyBIQUwgZHJpdmVyIG1hY3JvcyBsaXN0ICoqKgogICAgPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KICAgIFsuLl0KICAgICAgQmVsb3cgdGhlIGxpc3Qgb2YgYXZhaWxhYmxlIG1hY3JvcyBpbiBXV0RHIEhBTCBkcml2ZXIuCiAgICAgICgrKSBfX0hBTF9XV0RHX0VOQUJMRTogRW5hYmxlIHRoZSBXV0RHIHBlcmlwaGVyYWwKICAgICAgKCspIF9fSEFMX1dXREdfR0VUX0ZMQUc6IEdldCB0aGUgc2VsZWN0ZWQgV1dERydzIGZsYWcgc3RhdHVzCiAgICAgICgrKSBfX0hBTF9XV0RHX0NMRUFSX0ZMQUc6IENsZWFyIHRoZSBXV0RHJ3MgcGVuZGluZyBmbGFncwogICAgICAoKykgX19IQUxfV1dER19FTkFCTEVfSVQ6IEVuYWJsZSB0aGUgV1dERyBlYXJseSB3YWtldXAgaW50ZXJydXB0CgogIEBlbmR2ZXJiYXRpbQogICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogICogQGF0dGVudGlvbgogICoKICAqIDxoMj48Y2VudGVyPiZjb3B5OyBDb3B5cmlnaHQgKGMpIDIwMTkgU1RNaWNyb2VsZWN0cm9uaWNzLgogICogQWxsIHJpZ2h0cyByZXNlcnZlZC48L2NlbnRlcj48L2gyPgogICoKICAqIFRoaXMgc29mdHdhcmUgY29tcG9uZW50IGlzIGxpY2Vuc2VkIGJ5IFNUIHVuZGVyIEJTRCAzLUNsYXVzZSBsaWNlbnNlLAogICogdGhlICJMaWNlbnNlIjsgWW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZQogICogTGljZW5zZS4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0OgogICogICAgICAgICAgICAgICAgICAgICAgICBvcGVuc291cmNlLm9yZy9saWNlbnNlcy9CU0QtMy1DbGF1c2UKICAqCiAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAgKi8KCi8qIEluY2x1ZGVzIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCiNpbmNsdWRlICJzdG0zMmc0eHhfaGFsLmgiCgovKiogQGFkZHRvZ3JvdXAgU1RNMzJHNHh4X0hBTF9Ecml2ZXIKICAqIEB7CiAgKi8KCiNpZmRlZiBIQUxfV1dER19NT0RVTEVfRU5BQkxFRAovKiogQGRlZmdyb3VwIFdXREcgV1dERwogICogQGJyaWVmIFdXREcgSEFMIG1vZHVsZSBkcml2ZXIuCiAgKiBAewogICovCgovKiBQcml2YXRlIHR5cGVkZWYgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIGRlZmluZSAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIG1hY3JvIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIHZhcmlhYmxlcyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIGZ1bmN0aW9uIHByb3RvdHlwZXMgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBFeHBvcnRlZCBmdW5jdGlvbnMgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwoKLyoqIEBkZWZncm91cCBXV0RHX0V4cG9ydGVkX0Z1bmN0aW9ucyBXV0RHIEV4cG9ydGVkIEZ1bmN0aW9ucwogICogQHsKICAqLwoKLyoqIEBkZWZncm91cCBXV0RHX0V4cG9ydGVkX0Z1bmN0aW9uc19Hcm91cDEgSW5pdGlhbGl6YXRpb24gYW5kIENvbmZpZ3VyYXRpb24gZnVuY3Rpb25zCiAgKiAgQGJyaWVmICAgIEluaXRpYWxpemF0aW9uIGFuZCBDb25maWd1cmF0aW9uIGZ1bmN0aW9ucy4KICAqCkB2ZXJiYXRpbQogID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQogICAgICAgICAgIyMjIyMgSW5pdGlhbGl6YXRpb24gYW5kIENvbmZpZ3VyYXRpb24gZnVuY3Rpb25zICMjIyMjCiAgPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiAgWy4uXQogICAgVGhpcyBzZWN0aW9uIHByb3ZpZGVzIGZ1bmN0aW9ucyBhbGxvd2luZyB0bzoKICAgICAgKCspIEluaXRpYWxpemUgYW5kIHN0YXJ0IHRoZSBXV0RHIGFjY29yZGluZyB0byB0aGUgc3BlY2lmaWVkIHBhcmFtZXRlcnMKICAgICAgICAgIGluIHRoZSBXV0RHX0luaXRUeXBlRGVmIG9mIGFzc29jaWF0ZWQgaGFuZGxlLgogICAgICAoKykgSW5pdGlhbGl6ZSB0aGUgV1dERyBNU1AuCgpAZW5kdmVyYmF0aW0KICAqIEB7CiAgKi8KCi8qKgogICogQGJyaWVmICBJbml0aWFsaXplIHRoZSBXV0RHIGFjY29yZGluZyB0byB0aGUgc3BlY2lmaWVkLgogICogICAgICAgICBwYXJhbWV0ZXJzIGluIHRoZSBXV0RHX0luaXRUeXBlRGVmIG9mICBhc3NvY2lhdGVkIGhhbmRsZS4KICAqIEBwYXJhbSAgaHd3ZGcgIHBvaW50ZXIgdG8gYSBXV0RHX0hhbmRsZVR5cGVEZWYgc3RydWN0dXJlIHRoYXQgY29udGFpbnMKICAqICAgICAgICAgICAgICAgIHRoZSBjb25maWd1cmF0aW9uIGluZm9ybWF0aW9uIGZvciB0aGUgc3BlY2lmaWVkIFdXREcgbW9kdWxlLgogICogQHJldHZhbCBIQUwgc3RhdHVzCiAgKi8KSEFMX1N0YXR1c1R5cGVEZWYgSEFMX1dXREdfSW5pdChXV0RHX0hhbmRsZVR5cGVEZWYgKmh3d2RnKQp7CiAgLyogQ2hlY2sgdGhlIFdXREcgaGFuZGxlIGFsbG9jYXRpb24gKi8KICBpZiAoaHd3ZGcgPT0gTlVMTCkKICB7CiAgICByZXR1cm4gSEFMX0VSUk9SOwogIH0KCiAgLyogQ2hlY2sgdGhlIHBhcmFtZXRlcnMgKi8KICBhc3NlcnRfcGFyYW0oSVNfV1dER19BTExfSU5TVEFOQ0UoaHd3ZGctPkluc3RhbmNlKSk7CiAgYXNzZXJ0X3BhcmFtKElTX1dXREdfUFJFU0NBTEVSKGh3d2RnLT5Jbml0LlByZXNjYWxlcikpOwogIGFzc2VydF9wYXJhbShJU19XV0RHX1dJTkRPVyhod3dkZy0+SW5pdC5XaW5kb3cpKTsKICBhc3NlcnRfcGFyYW0oSVNfV1dER19DT1VOVEVSKGh3d2RnLT5Jbml0LkNvdW50ZXIpKTsKICBhc3NlcnRfcGFyYW0oSVNfV1dER19FV0lfTU9ERShod3dkZy0+SW5pdC5FV0lNb2RlKSk7CgojaWYgKFVTRV9IQUxfV1dER19SRUdJU1RFUl9DQUxMQkFDS1MgPT0gMSkKICAvKiBSZXNldCBDYWxsYmFjayBwb2ludGVycyAqLwogIGlmIChod3dkZy0+RXdpQ2FsbGJhY2sgPT0gTlVMTCkKICB7CiAgICBod3dkZy0+RXdpQ2FsbGJhY2sgPSBIQUxfV1dER19FYXJseVdha2V1cENhbGxiYWNrOwogIH0KCiAgaWYgKGh3d2RnLT5Nc3BJbml0Q2FsbGJhY2sgPT0gTlVMTCkKICB7CiAgICBod3dkZy0+TXNwSW5pdENhbGxiYWNrID0gSEFMX1dXREdfTXNwSW5pdDsKICB9CgogIC8qIEluaXQgdGhlIGxvdyBsZXZlbCBoYXJkd2FyZSAqLwogIGh3d2RnLT5Nc3BJbml0Q2FsbGJhY2soaHd3ZGcpOwojZWxzZQogIC8qIEluaXQgdGhlIGxvdyBsZXZlbCBoYXJkd2FyZSAqLwogIEhBTF9XV0RHX01zcEluaXQoaHd3ZGcpOwojZW5kaWYgLyogVVNFX0hBTF9XV0RHX1JFR0lTVEVSX0NBTExCQUNLUyAqLwoKICAvKiBTZXQgV1dERyBDb3VudGVyICovCiAgV1JJVEVfUkVHKGh3d2RnLT5JbnN0YW5jZS0+Q1IsIChXV0RHX0NSX1dER0EgfCBod3dkZy0+SW5pdC5Db3VudGVyKSk7CgogIC8qIFNldCBXV0RHIFByZXNjYWxlciBhbmQgV2luZG93ICovCiAgV1JJVEVfUkVHKGh3d2RnLT5JbnN0YW5jZS0+Q0ZSLCAoaHd3ZGctPkluaXQuRVdJTW9kZSB8IGh3d2RnLT5Jbml0LlByZXNjYWxlciB8IGh3d2RnLT5Jbml0LldpbmRvdykpOwoKICAvKiBSZXR1cm4gZnVuY3Rpb24gc3RhdHVzICovCiAgcmV0dXJuIEhBTF9PSzsKfQoKCi8qKgogICogQGJyaWVmICBJbml0aWFsaXplIHRoZSBXV0RHIE1TUC4KICAqIEBwYXJhbSAgaHd3ZGcgIHBvaW50ZXIgdG8gYSBXV0RHX0hhbmRsZVR5cGVEZWYgc3RydWN0dXJlIHRoYXQgY29udGFpbnMKICAqICAgICAgICAgICAgICAgIHRoZSBjb25maWd1cmF0aW9uIGluZm9ybWF0aW9uIGZvciB0aGUgc3BlY2lmaWVkIFdXREcgbW9kdWxlLgogICogQG5vdGUgICBXaGVuIHJld3JpdGluZyB0aGlzIGZ1bmN0aW9uIGluIHVzZXIgZmlsZSwgbWVjaGFuaXNtIG1heSBiZSBhZGRlZAogICogICAgICAgICB0byBhdm9pZCBtdWx0aXBsZSBpbml0aWFsaXplIHdoZW4gSEFMX1dXREdfSW5pdCBmdW5jdGlvbiBpcyBjYWxsZWQKICAqICAgICAgICAgYWdhaW4gdG8gY2hhbmdlIHBhcmFtZXRlcnMuCiAgKiBAcmV0dmFsIE5vbmUKICAqLwpfX3dlYWsgdm9pZCBIQUxfV1dER19Nc3BJbml0KFdXREdfSGFuZGxlVHlwZURlZiAqaHd3ZGcpCnsKICAvKiBQcmV2ZW50IHVudXNlZCBhcmd1bWVudChzKSBjb21waWxhdGlvbiB3YXJuaW5nICovCiAgVU5VU0VEKGh3d2RnKTsKCiAgLyogTk9URTogVGhpcyBmdW5jdGlvbiBzaG91bGQgbm90IGJlIG1vZGlmaWVkLCB3aGVuIHRoZSBjYWxsYmFjayBpcyBuZWVkZWQsCiAgICAgICAgICAgdGhlIEhBTF9XV0RHX01zcEluaXQgY291bGQgYmUgaW1wbGVtZW50ZWQgaW4gdGhlIHVzZXIgZmlsZQogICAqLwp9CgoKI2lmIChVU0VfSEFMX1dXREdfUkVHSVNURVJfQ0FMTEJBQ0tTID09IDEpCi8qKgogICogQGJyaWVmICBSZWdpc3RlciBhIFVzZXIgV1dERyBDYWxsYmFjawogICogICAgICAgICBUbyBiZSB1c2VkIGluc3RlYWQgb2YgdGhlIHdlYWsgKHN1cmNoYXJnZWQpIHByZWRlZmluZWQgY2FsbGJhY2sKICAqIEBwYXJhbSAgaHd3ZGcgV1dERyBoYW5kbGUKICAqIEBwYXJhbSAgQ2FsbGJhY2tJRCBJRCBvZiB0aGUgY2FsbGJhY2sgdG8gYmUgcmVnaXN0ZXJlZAogICogICAgICAgICBUaGlzIHBhcmFtZXRlciBjYW4gYmUgb25lIG9mIHRoZSBmb2xsb3dpbmcgdmFsdWVzOgogICogICAgICAgICAgIEBhcmcgQHJlZiBIQUxfV1dER19FV0lfQ0JfSUQgRWFybHkgV2FrZVVwIEludGVycnVwdCBDYWxsYmFjayBJRAogICogICAgICAgICAgIEBhcmcgQHJlZiBIQUxfV1dER19NU1BJTklUX0NCX0lEIE1zcEluaXQgY2FsbGJhY2sgSUQKICAqIEBwYXJhbSAgcENhbGxiYWNrIHBvaW50ZXIgdG8gdGhlIENhbGxiYWNrIGZ1bmN0aW9uCiAgKiBAcmV0dmFsIHN0YXR1cwogICovCkhBTF9TdGF0dXNUeXBlRGVmIEhBTF9XV0RHX1JlZ2lzdGVyQ2FsbGJhY2soV1dER19IYW5kbGVUeXBlRGVmICpod3dkZywgSEFMX1dXREdfQ2FsbGJhY2tJRFR5cGVEZWYgQ2FsbGJhY2tJRCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwV1dER19DYWxsYmFja1R5cGVEZWYgcENhbGxiYWNrKQp7CiAgSEFMX1N0YXR1c1R5cGVEZWYgc3RhdHVzID0gSEFMX09LOwoKICBpZiAocENhbGxiYWNrID09IE5VTEwpCiAgewogICAgc3RhdHVzID0gSEFMX0VSUk9SOwogIH0KICBlbHNlCiAgewogICAgc3dpdGNoIChDYWxsYmFja0lEKQogICAgewogICAgICBjYXNlIEhBTF9XV0RHX0VXSV9DQl9JRDoKICAgICAgICBod3dkZy0+RXdpQ2FsbGJhY2sgPSBwQ2FsbGJhY2s7CiAgICAgICAgYnJlYWs7CgogICAgICBjYXNlIEhBTF9XV0RHX01TUElOSVRfQ0JfSUQ6CiAgICAgICAgaHd3ZGctPk1zcEluaXRDYWxsYmFjayA9IHBDYWxsYmFjazsKICAgICAgICBicmVhazsKCiAgICAgIGRlZmF1bHQ6CiAgICAgICAgc3RhdHVzID0gSEFMX0VSUk9SOwogICAgICAgIGJyZWFrOwogICAgfQogIH0KCiAgcmV0dXJuIHN0YXR1czsKfQoKCi8qKgogICogQGJyaWVmICBVbnJlZ2lzdGVyIGEgV1dERyBDYWxsYmFjawogICogICAgICAgICBXV0RHIENhbGxiYWNrIGlzIHJlZGlyZWN0ZWQgdG8gdGhlIHdlYWsgKHN1cmNoYXJnZWQpIHByZWRlZmluZWQgY2FsbGJhY2sKICAqIEBwYXJhbSAgaHd3ZGcgV1dERyBoYW5kbGUKICAqIEBwYXJhbSAgQ2FsbGJhY2tJRCBJRCBvZiB0aGUgY2FsbGJhY2sgdG8gYmUgcmVnaXN0ZXJlZAogICogICAgICAgICBUaGlzIHBhcmFtZXRlciBjYW4gYmUgb25lIG9mIHRoZSBmb2xsb3dpbmcgdmFsdWVzOgogICogICAgICAgICAgIEBhcmcgQHJlZiBIQUxfV1dER19FV0lfQ0JfSUQgRWFybHkgV2FrZVVwIEludGVycnVwdCBDYWxsYmFjayBJRAogICogICAgICAgICAgIEBhcmcgQHJlZiBIQUxfV1dER19NU1BJTklUX0NCX0lEIE1zcEluaXQgY2FsbGJhY2sgSUQKICAqIEByZXR2YWwgc3RhdHVzCiAgKi8KSEFMX1N0YXR1c1R5cGVEZWYgSEFMX1dXREdfVW5SZWdpc3RlckNhbGxiYWNrKFdXREdfSGFuZGxlVHlwZURlZiAqaHd3ZGcsIEhBTF9XV0RHX0NhbGxiYWNrSURUeXBlRGVmIENhbGxiYWNrSUQpCnsKICBIQUxfU3RhdHVzVHlwZURlZiBzdGF0dXMgPSBIQUxfT0s7CgogIHN3aXRjaCAoQ2FsbGJhY2tJRCkKICB7CiAgICBjYXNlIEhBTF9XV0RHX0VXSV9DQl9JRDoKICAgICAgaHd3ZGctPkV3aUNhbGxiYWNrID0gSEFMX1dXREdfRWFybHlXYWtldXBDYWxsYmFjazsKICAgICAgYnJlYWs7CgogICAgY2FzZSBIQUxfV1dER19NU1BJTklUX0NCX0lEOgogICAgICBod3dkZy0+TXNwSW5pdENhbGxiYWNrID0gSEFMX1dXREdfTXNwSW5pdDsKICAgICAgYnJlYWs7CgogICAgZGVmYXVsdDoKICAgICAgc3RhdHVzID0gSEFMX0VSUk9SOwogICAgICBicmVhazsKICB9CgogIHJldHVybiBzdGF0dXM7Cn0KI2VuZGlmIC8qIFVTRV9IQUxfV1dER19SRUdJU1RFUl9DQUxMQkFDS1MgKi8KCi8qKgogICogQH0KICAqLwoKLyoqIEBkZWZncm91cCBXV0RHX0V4cG9ydGVkX0Z1bmN0aW9uc19Hcm91cDIgSU8gb3BlcmF0aW9uIGZ1bmN0aW9ucwogICogIEBicmllZiAgICBJTyBvcGVyYXRpb24gZnVuY3Rpb25zCiAgKgpAdmVyYmF0aW0KICA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KICAgICAgICAgICAgICAgICAgICAgICMjIyMjIElPIG9wZXJhdGlvbiBmdW5jdGlvbnMgIyMjIyMKICA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KICBbLi5dCiAgICBUaGlzIHNlY3Rpb24gcHJvdmlkZXMgZnVuY3Rpb25zIGFsbG93aW5nIHRvOgogICAgKCspIFJlZnJlc2ggdGhlIFdXREcuCiAgICAoKykgSGFuZGxlIFdXREcgaW50ZXJydXB0IHJlcXVlc3QgYW5kIGFzc29jaWF0ZWQgZnVuY3Rpb24gY2FsbGJhY2suCgpAZW5kdmVyYmF0aW0KICAqIEB7CiAgKi8KCi8qKgogICogQGJyaWVmICBSZWZyZXNoIHRoZSBXV0RHLgogICogQHBhcmFtICBod3dkZyAgcG9pbnRlciB0byBhIFdXREdfSGFuZGxlVHlwZURlZiBzdHJ1Y3R1cmUgdGhhdCBjb250YWlucwogICogICAgICAgICAgICAgICAgdGhlIGNvbmZpZ3VyYXRpb24gaW5mb3JtYXRpb24gZm9yIHRoZSBzcGVjaWZpZWQgV1dERyBtb2R1bGUuCiAgKiBAcmV0dmFsIEhBTCBzdGF0dXMKICAqLwpIQUxfU3RhdHVzVHlwZURlZiBIQUxfV1dER19SZWZyZXNoKFdXREdfSGFuZGxlVHlwZURlZiAqaHd3ZGcpCnsKICAvKiBXcml0ZSB0byBXV0RHIENSIHRoZSBXV0RHIENvdW50ZXIgdmFsdWUgdG8gcmVmcmVzaCB3aXRoICovCiAgV1JJVEVfUkVHKGh3d2RnLT5JbnN0YW5jZS0+Q1IsIChod3dkZy0+SW5pdC5Db3VudGVyKSk7CgogIC8qIFJldHVybiBmdW5jdGlvbiBzdGF0dXMgKi8KICByZXR1cm4gSEFMX09LOwp9CgovKioKICAqIEBicmllZiAgSGFuZGxlIFdXREcgaW50ZXJydXB0IHJlcXVlc3QuCiAgKiBAbm90ZSAgIFRoZSBFYXJseSBXYWtldXAgSW50ZXJydXB0IChFV0kpIGNhbiBiZSB1c2VkIGlmIHNwZWNpZmljIHNhZmV0eSBvcGVyYXRpb25zCiAgKiAgICAgICAgIG9yIGRhdGEgbG9nZ2luZyBtdXN0IGJlIHBlcmZvcm1lZCBiZWZvcmUgdGhlIGFjdHVhbCByZXNldCBpcyBnZW5lcmF0ZWQuCiAgKiAgICAgICAgIFRoZSBFV0kgaW50ZXJydXB0IGlzIGVuYWJsZWQgYnkgY2FsbGluZyBIQUxfV1dER19Jbml0IGZ1bmN0aW9uIHdpdGgKICAqICAgICAgICAgRVdJTW9kZSBzZXQgdG8gV1dER19FV0lfRU5BQkxFLgogICogICAgICAgICBXaGVuIHRoZSBkb3duY291bnRlciByZWFjaGVzIHRoZSB2YWx1ZSAweDQwLCBhbmQgRVdJIGludGVycnVwdCBpcwogICogICAgICAgICBnZW5lcmF0ZWQgYW5kIHRoZSBjb3JyZXNwb25kaW5nIEludGVycnVwdCBTZXJ2aWNlIFJvdXRpbmUgKElTUikgY2FuCiAgKiAgICAgICAgIGJlIHVzZWQgdG8gdHJpZ2dlciBzcGVjaWZpYyBhY3Rpb25zIChzdWNoIGFzIGNvbW11bmljYXRpb25zIG9yIGRhdGEKICAqICAgICAgICAgbG9nZ2luZyksIGJlZm9yZSByZXNldHRpbmcgdGhlIGRldmljZS4KICAqIEBwYXJhbSAgaHd3ZGcgIHBvaW50ZXIgdG8gYSBXV0RHX0hhbmRsZVR5cGVEZWYgc3RydWN0dXJlIHRoYXQgY29udGFpbnMKICAqICAgICAgICAgICAgICAgIHRoZSBjb25maWd1cmF0aW9uIGluZm9ybWF0aW9uIGZvciB0aGUgc3BlY2lmaWVkIFdXREcgbW9kdWxlLgogICogQHJldHZhbCBOb25lCiAgKi8Kdm9pZCBIQUxfV1dER19JUlFIYW5kbGVyKFdXREdfSGFuZGxlVHlwZURlZiAqaHd3ZGcpCnsKICAvKiBDaGVjayBpZiBFYXJseSBXYWtldXAgSW50ZXJydXB0IGlzIGVuYWJsZSAqLwogIGlmIChfX0hBTF9XV0RHX0dFVF9JVF9TT1VSQ0UoaHd3ZGcsIFdXREdfSVRfRVdJKSAhPSBSRVNFVCkKICB7CiAgICAvKiBDaGVjayBpZiBXV0RHIEVhcmx5IFdha2V1cCBJbnRlcnJ1cHQgb2NjdXJyZWQgKi8KICAgIGlmIChfX0hBTF9XV0RHX0dFVF9GTEFHKGh3d2RnLCBXV0RHX0ZMQUdfRVdJRikgIT0gUkVTRVQpCiAgICB7CiAgICAgIC8qIENsZWFyIHRoZSBXV0RHIEVhcmx5IFdha2V1cCBmbGFnICovCiAgICAgIF9fSEFMX1dXREdfQ0xFQVJfRkxBRyhod3dkZywgV1dER19GTEFHX0VXSUYpOwoKI2lmIChVU0VfSEFMX1dXREdfUkVHSVNURVJfQ0FMTEJBQ0tTID09IDEpCiAgICAgIC8qIEVhcmx5IFdha2V1cCByZWdpc3RlcmVkIGNhbGxiYWNrICovCiAgICAgIGh3d2RnLT5Fd2lDYWxsYmFjayhod3dkZyk7CiNlbHNlCiAgICAgIC8qIEVhcmx5IFdha2V1cCBjYWxsYmFjayAqLwogICAgICBIQUxfV1dER19FYXJseVdha2V1cENhbGxiYWNrKGh3d2RnKTsKI2VuZGlmIC8qIFVTRV9IQUxfV1dER19SRUdJU1RFUl9DQUxMQkFDS1MgKi8KICAgIH0KICB9Cn0KCgovKioKICAqIEBicmllZiAgV1dERyBFYXJseSBXYWtldXAgY2FsbGJhY2suCiAgKiBAcGFyYW0gIGh3d2RnICBwb2ludGVyIHRvIGEgV1dER19IYW5kbGVUeXBlRGVmIHN0cnVjdHVyZSB0aGF0IGNvbnRhaW5zCiAgKiAgICAgICAgICAgICAgICB0aGUgY29uZmlndXJhdGlvbiBpbmZvcm1hdGlvbiBmb3IgdGhlIHNwZWNpZmllZCBXV0RHIG1vZHVsZS4KICAqIEByZXR2YWwgTm9uZQogICovCl9fd2VhayB2b2lkIEhBTF9XV0RHX0Vhcmx5V2FrZXVwQ2FsbGJhY2soV1dER19IYW5kbGVUeXBlRGVmICpod3dkZykKewogIC8qIFByZXZlbnQgdW51c2VkIGFyZ3VtZW50KHMpIGNvbXBpbGF0aW9uIHdhcm5pbmcgKi8KICBVTlVTRUQoaHd3ZGcpOwoKICAvKiBOT1RFOiBUaGlzIGZ1bmN0aW9uIHNob3VsZCBub3QgYmUgbW9kaWZpZWQsIHdoZW4gdGhlIGNhbGxiYWNrIGlzIG5lZWRlZCwKICAgICAgICAgICB0aGUgSEFMX1dXREdfRWFybHlXYWtldXBDYWxsYmFjayBjb3VsZCBiZSBpbXBsZW1lbnRlZCBpbiB0aGUgdXNlciBmaWxlCiAgICovCn0KCi8qKgogICogQH0KICAqLwoKLyoqCiAgKiBAfQogICovCgojZW5kaWYgLyogSEFMX1dXREdfTU9EVUxFX0VOQUJMRUQgKi8KLyoqCiAgKiBAfQogICovCgovKioKICAqIEB9CiAgKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKiogKEMpIENPUFlSSUdIVCBTVE1pY3JvZWxlY3Ryb25pY3MgKioqKipFTkQgT0YgRklMRSoqKiovCg==