UG9sYXJTU0wgQ2hhbmdlTG9nDQoNCj0gVmVyc2lvbiAwLjEyLjIgcmVsZWFzZWQgb24gWFhYWFhYWFgNCkNoYW5nZXMNCiAgICogQWRkZWQgb3B0aW9uIHBhcnNpbmcgZm9yIGhvc3QgYW5kIHBvcnQgc2VsZWN0aW9uIHRvDQogICAgIHNzbF9jbGllbnQyDQogICAqIEFkZGVkIHN1cHBvcnQgZm9yIEdlbmVyYWxpemVkVGltZSBpbiBYNTA5IHBhcnNpbmcNCiAgICogQWRkZWQgY29uc3QgY29ycmVjdG5lc3MgZm9yIG1haW4gY29kZSBiYXNlDQoNCkJ1ZyBmaXhlcw0KICAgKiBGaXhlZCBidWcgcmVzdWx0aW5nIGluIGZhaWx1cmUgdG8gc2VuZCB0aGUgbGFzdA0KICAgICBjZXJ0aWZpY2F0ZSBpbiB0aGUgY2hhaW4gaW4gc3NsX3dyaXRlX2NlcnRpZmljYXRlKCkgYW5kDQoJIHNzbF93cml0ZV9jZXJ0aWZpY2F0ZV9yZXF1ZXN0KCkgKEZvdW5kIGJ5IGZhdGJvYikNCg0KPSBWZXJzaW9uIDAuMTIuMSByZWxlYXNlZCBvbiAyMDA5LTEwLTA0DQpDaGFuZ2VzDQogICAqIENvdmVyYWdlIHRlc3QgZGVmaW5pdGlvbnMgbm93IHN1cHBvcnQgJ2RlcGVuZHNfb24nDQogICAgIHRhZ2dpbmcgc3lzdGVtLg0KICAgKiBUZXN0cyByZXF1aXJpbmcgc3BlY2lmaWMgaGFzaGluZyBhbGdvcml0aG1zIG5vdyBob25vcg0KICAgICB0aGUgZGVmaW5lcy4NCg0KQnVnIGZpeGVzDQogICAqIENoYW5nZWQgdHlwbyBpbiAjaWZkZWYgaW4geDUwOXBhcnNlLmMgKGZvdW5kDQogICAgIGJ5IEVkdWFyZG8pDQoNCj0gVmVyc2lvbiAwLjEyLjAgcmVsZWFzZWQgb24gMjAwOS0wNy0yOA0KRmVhdHVyZXMNCiAgICogQWRkZWQgQ01ha2UgbWFrZWZpbGVzIGFzIGFsdGVybmF0aXZlIHRvIHJlZ3VsYXIgTWFrZWZpbGVzLg0KICAgKiBBZGRlZCBwcmVsaW1pbmFyeSBDb2RlIENvdmVyYWdlIHRlc3RzIGZvciBBRVMsIEFSQzQsDQogICAgIEJhc2U2NCwgTVBJLCBTSEEtZmFtaWx5LCBNRC1mYW1pbHksIEhNQUMtU0hBLWZhbWlseSwNCiAgICAgQ2FtZWxsaWEsIERFUywgMy1ERVMsIFJTQSBQS0NTIzEsIFhURUEsIERpZmZpZS1IZWxsbWFuDQogICAgIGFuZCBYNTA5cGFyc2UuDQoNCkNoYW5nZXMNCiAgICogRXJyb3IgY29kZXMgYXJlIG5vdCAobmVjZXNzYXJpbHkpIG5lZ2F0aXZlLiBLZWVwDQogICAgIHRoaXMgaXMgbWluZCB3aGVuIGNoZWNraW5nIGZvciBlcnJvcnMuDQogICAqIFJTQV9SQVcgcmVuYW1lZCB0byBTSUdfUlNBX1JBVyBmb3IgY29uc2lzdGVuY3kuDQogICAqIEZpeGVkIHR5cG8gaW4gbmFtZSBvZiBQT0xBUlNTTF9FUlJfUlNBX09VVFBVVF9UT09fTEFSR0UuDQogICAqIENoYW5nZWQgaW50ZXJmYWNlIGZvciBBRVMgYW5kIENhbWVsbGlhIHNldGtleSBmdW5jdGlvbnMNCiAgICAgdG8gaW5kaWNhdGUgaW52YWxpZCBrZXkgbGVuZ3Rocy4NCg0KQnVnIGZpeGVzDQogICAqIEZpeGVkIGluY2x1ZGUgbG9jYXRpb24gb2YgZW5kaWFuLmggb24gRnJlZUJTRCAoZm91bmQgYnkNCiAgICAgR2FicmllbCkNCiAgICogRml4ZWQgaW5jbHVkZSBsb2NhdGlvbiBvZiBlbmRpYW4uaCBhbmQgbmFtZSBjbGFzaCBvbg0KICAgICBBcHBsZXMgKGZvdW5kIGJ5IE1hcnRpbiB2YW4gSGVuc2JlcmdlbikNCiAgICogRml4ZWQgSE1BQy1NRDIgYnkgbW9kaWZ5aW5nIG1kMl9zdGFydHMoKSwgc28gdGhhdCB0aGUNCiAgICAgcmVxdWlyZWQgSE1BQyBpcGFkIGFuZCBvcGFkIHZhcmlhYmxlcyBhcmUgbm90IGNsZWFyZWQuDQogICAgIChmb3VuZCBieSBjb2RlIGNvdmVyYWdlIHRlc3RzKQ0KICAgKiBQcmV2ZW50ZWQgdXNlIG9mIGxvbmcgbG9uZyBpbiBiaWdudW0gaWYgDQogICAgIFBPTEFSU1NMX0hBVkVfTE9OR0xPTkcgbm90IGRlZmluZWQgKGZvdW5kIGJ5IEdpbGVzDQogICAgIEJhdGhnYXRlKS4NCiAgICogRml4ZWQgaW5jb3JyZWN0IGhhbmRsaW5nIG9mIG5lZ2F0aXZlIHN0cmluZ3MgaW4NCiAgICAgbXBpX3JlYWRfc3RyaW5nKCkgKGZvdW5kIGJ5IGNvZGUgY292ZXJhZ2UgdGVzdHMpLg0KICAgKiBGaXhlZCBzZWdmYXVsdCBvbiBoYW5kbGluZyBlbXB0eSByc2FfY29udGV4dCBpbg0KICAgICByc2FfY2hlY2tfcHVia2V5KCkgYW5kIHJzYV9jaGVja19wcml2a2V5KCkgKGZvdW5kIGJ5DQogICAgIGNvZGUgY292ZXJhZ2UgdGVzdHMpLg0KICAgKiBGaXhlZCBpbmNvcnJlY3QgaGFuZGxpbmcgb2Ygb25lIHNpbmdsZSBuZWdhdGl2ZSBpbnB1dA0KICAgICB2YWx1ZSBpbiBtcGlfYWRkX2FicygpIChmb3VuZCBieSBjb2RlIGNvdmVyYWdlIHRlc3RzKS4NCiAgICogRml4ZWQgaW5jb3JyZWN0IGhhbmRsaW5nIG9mIG5lZ2F0aXZlIGZpcnN0IGlucHV0DQogICAgIHZhbHVlIGluIG1waV9zdWJfYWJzKCkgKGZvdW5kIGJ5IGNvZGUgY292ZXJhZ2UgdGVzdHMpLg0KICAgKiBGaXhlZCBpbmNvcnJlY3QgaGFuZGxpbmcgb2YgbmVnYXRpdmUgZmlyc3QgaW5wdXQNCiAgICAgdmFsdWUgaW4gbXBpX21vZF9tcGkoKSBhbmQgbXBpX21vZF9pbnQoKS4gUmVzdWx0aW5nDQogICAgIGNoYW5nZSBhbHNvIGFmZmVjdHMgbXBpX3dyaXRlX3N0cmluZygpIChmb3VuZCBieSBjb2RlDQogICAgIGNvdmVyYWdlIHRlc3RzKS4NCiAgICogQ29ycmVjdGVkIGlzX3ByaW1lKCkgcmVzdWx0cyBmb3IgMCwgMSBhbmQgMiAoZm91bmQgYnkNCiAgICAgY29kZSBjb3ZlcmFnZSB0ZXN0cykuDQogICAqIEZpeGVkIENhbWVsbGlhIGFuZCBYVEVBIGZvciA2NC1iaXQgV2luZG93cyBzeXN0ZW1zLg0KDQo9IFZlcnNpb24gMC4xMS4xIHJlbGVhc2VkIG9uIDIwMDktMDUtMTcNCiAgICogRml4ZWQgbWlzc2luZyBmdW5jdGlvbmFsaXR5IGZvciBTSEEtMjI0LCBTSEEtMjU2LCBTSEEzODQsDQogICAgIFNIQS01MTIgaW4gcnNhX3BrY3MxX3NpZ24oKQ0KDQo9IFZlcnNpb24gMC4xMS4wIHJlbGVhc2VkIG9uIDIwMDktMDUtMDMNCiAgICogRml4ZWQgYSBidWcgaW4gbXBpX2djZCgpIHNvIHRoYXQgaXQgYWxzbyB3b3JrcyB3aGVuIGJvdGgNCiAgICAgaW5wdXQgbnVtYmVycyBhcmUgZXZlbiBhbmQgYWRkZWQgdGVzdGNhc2VzIHRvIGNoZWNrDQogICAgIChmb3VuZCBieSBQaWVycmUgSGFib3V6aXQpLg0KICAgKiBBZGRlZCBzdXBwb3J0IGZvciBTSEEtMjI0LCBTSEEtMjU2LCBTSEEtMzg0IGFuZCBTSEEtNTEyDQogICAgIG9uZSB3YXkgaGFzaCBmdW5jdGlvbnMgd2l0aCB0aGUgUEtDUyMxIHYxLjUgc2lnbmluZyBhbmQNCiAgICAgdmVyaWZpY2F0aW9uLg0KICAgKiBGaXhlZCBtaW5vciBidWcgcmVnYXJkaW5nIG1waV9nY2QgbG9jYXRlZCB3aXRoaW4gdGhlDQogICAgIFBPTEFSU1NMX0dFTlBSSU1FIGJsb2NrLg0KICAgKiBGaXhlZCBtaW5vciBtZW1vcnkgbGVhayBpbiB4NTA5cGFyc2VfY3J0KCkgYW5kIGFkZGVkIGJldHRlcg0KICAgICBoYW5kbGluZyBvZiAnZnVsbCcgY2VydGlmaWNhdGUgY2hhaW5zIChmb3VuZCBieSBNYXRoaWFzDQogICAgIE9sc3NvbikuDQogICAqIENlbnRyYWxpemVkIGZpbGUgb3BlbmluZyBhbmQgcmVhZGluZyBmb3IgeDUwOSBmaWxlcyBpbnRvDQogICAgIGxvYWRfZmlsZSgpDQogICAqIE1hZGUgZGVmaW5pdGlvbiBvZiBuZXRfaHRvbnMoKSBlbmRpYW4tY2xlYW4gZm9yIGJpZyBlbmRpYW4NCiAgICAgc3lzdGVtcyAoRm91bmQgYnkgR2Vybm90KS4NCiAgICogVW5kZWZpbmluZyBQT0xBUlNTTF9IQVZFX0FTTSBub3cgYWxzbyBoYW5kbGVzIHByZXZlbnRzIGFzbSBpbg0KICAgICBwYWRsb2NrIGFuZCB0aW1pbmcgY29kZS4gDQogICAqIEZpeGVkIGFuIG9mZi1ieS1vbmUgYnVmZmVyIGFsbG9jYXRpb24gaW4gc3NsX3NldF9ob3N0bmFtZSgpDQogICAgIHJlc3BvbnNpYmxlIGZvciBjcmFzaGVzIGFuZCB1bndhbnRlZCBiZWhhdmlvdXIuDQogICAqIEFkZGVkIHN1cHBvcnQgZm9yIENlcnRpZmljYXRlIFJldm9jYXRpb24gTGlzdCAoQ1JMKSBwYXJzaW5nLg0KICAgKiBBZGRlZCBzdXBwb3J0IGZvciBDUkwgcmV2b2NhdGlvbiB0byB4NTA5cGFyc2VfdmVyaWZ5KCkgYW5kDQogICAgIFNTTC9UTFMgY29kZS4NCiAgICogRml4ZWQgY29tcGF0aWJpbGl0eSBvZiBYVEVBIGFuZCBDYW1lbGxpYSBvbiBhIDY0LWJpdCBzeXN0ZW0NCiAgICAgKGZvdW5kIGJ5IEZlbGl4IHZvbiBMZWl0bmVyKS4NCg0KPSBWZXJzaW9uIDAuMTAuMCByZWxlYXNlZCBvbiAyMDA5LTAxLTEyDQogICAqIE1pZ3JhdGVkIFh5U1NMIHRvIFBvbGFyU1NMDQogICAqIEFkZGVkIFhURUEgc3ltbWV0cmljIGNpcGhlcg0KICAgKiBBZGRlZCBDYW1lbGxpYSBzeW1tZXRyaWMgY2lwaGVyDQogICAqIEFkZGVkIHN1cHBvcnQgZm9yIGNpcGhlcnN1aXRlczogU1NMX1JTQV9DQU1FTExJQV8xMjhfU0hBLA0KICAgICBTU0xfUlNBX0NBTUVMTElBXzI1Nl9TSEEgYW5kIFNTTF9FREhfUlNBX0NBTUVMTElBXzI1Nl9TSEENCiAgICogRml4ZWQgZGFuZ2Vyb3VzIGJ1ZyB0aGF0IGNhbiBjYXVzZSBhIGhlYXAgb3ZlcmZsb3cgaW4NCiAgICAgcnNhX3BrY3MxX2RlY3J5cHQgKGZvdW5kIGJ5IENocmlzdG9waGUgRGV2aW5lKQ0KDQo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09DQpYeVNTTCBDaGFuZ2VMb2cNCg0KPSBWZXJzaW9uIDAuOSByZWxlYXNlZCBvbiAyMDA4LTAzLTE2DQoNCiAgICAqIEFkZGVkIHN1cHBvcnQgZm9yIGNpcGhlcnN1aXRlOiBTU0xfUlNBX0FFU18xMjhfU0hBDQogICAgKiBFbmFibGVkIHN1cHBvcnQgZm9yIGxhcmdlIGZpbGVzIGJ5IGRlZmF1bHQgaW4gYWVzY3J5cHQyLmMNCiAgICAqIFByZWxpbWluYXJ5IG9wZW5zc2wgd3JhcHBlciBjb250cmlidXRlZCBieSBEYXZpZCBCYXJyZXR0DQogICAgKiBGaXhlZCBhIGJ1ZyBpbiBzc2xfd3JpdGUoKSB0aGF0IGNhdXNlZCB0aGUgc2FtZSBwYXlsb2FkIHRvDQogICAgICBiZSBzZW50IHR3aWNlIGluIG5vbi1ibG9ja2luZyBtb2RlIHdoZW4gc2VuZCByZXR1cm5zIEVBR0FJTg0KICAgICogRml4ZWQgc3NsX3BhcnNlX2NsaWVudF9oZWxsbygpOiBzZXNzaW9uIGlkIGFuZCBjaGFsbGVuZ2UgbXVzdA0KICAgICAgbm90IGJlIHN3YXBwZWQgaW4gdGhlIFNTTHYyIENsaWVudEhlbGxvIChmb3VuZCBieSBHcmVnIFJvYnNvbikNCiAgICAqIEFkZGVkIHVzZXItZGVmaW5lZCBjYWxsYmFjayBkZWJ1ZyBmdW5jdGlvbiAoS3J5c3RpYW4gS29sb2R6aWVqKQ0KICAgICogQmVmb3JlIGZyZWVpbmcgYSBjZXJ0aWZpY2F0ZSwgcHJvcGVybHkgemVybyBvdXQgYWxsIGNlcnQuIGRhdGENCiAgICAqIEZpeGVkIHRoZSAibW9kZSIgcGFyYW1ldGVyIHNvIHRoYXQgZW5jcnlwdGlvbi9kZWNyeXB0aW9uIGFyZQ0KICAgICAgbm90IHN3YXBwZWQgb24gUGFkTG9jazsgYWxzbyBmaXhlZCBjb21waWxhdGlvbiBvbiBvbGRlciB2ZXJzaW9ucw0KICAgICAgb2YgZ2NjIChidWcgcmVwb3J0ZWQgYnkgRGF2aWQgQmFycmV0dCkNCiAgICAqIENvcnJlY3RseSBoYW5kbGUgdGhlIGNhc2UgaW4gcGFkbG9ja194Y3J5cHRjYmMoKSB3aGVuIGlucHV0IG9yDQogICAgICBvdXB1dCBkYXRhIGlzIG5vbi1hbGlnbmVkIGJ5IGZhbGxpbmcgYmFjayB0byB0aGUgc29mdHdhcmUNCiAgICAgIGltcGxlbWVudGF0aW9uLCBhcyBWSUEgTmVoZW1pYWggY2Fubm90IGhhbmRsZSBub24tYWxpZ25lZCBidWZmZXJzDQogICAgKiBGaXhlZCBhIG1lbW9yeSBsZWFrIGluIHg1MDlwYXJzZV9jcnQoKSB3aGljaCB3YXMgcmVwb3J0ZWQgYnkgR3JlZw0KICAgICAgUm9ic29uLUdhcnRoOyBzb21lIHg1MDl3cml0ZS5jIGZpeGVzIGJ5IFBhc2NhbCBWaXplbGksIHRoYW5rcyB0bw0KICAgICAgTWF0dGhldyBQYWdlIHdobyByZXBvcnRlZCBzZXZlcmFsIGJ1Z3MNCiAgICAqIEZpeGVkIHg1MDlfZ2V0X2V4dCgpIHRvIGFjY2VwdCBzb21lIHJhcmUgY2VydGlmaWNhdGVzIHdoaWNoIGhhdmUNCiAgICAgIGFuIElOVEVHRVIgaW5zdGVhZCBvZiBhIEJPT0xFQU4gZm9yIEJhc2ljQ29uc3RyYWludHM6OmNBLg0KICAgICogQWRkZWQgc3VwcG9ydCBvbiB0aGUgY2xpZW50IHNpZGUgZm9yIHRoZSBUTFMgImhvc3RuYW1lIiBleHRlbnNpb24NCiAgICAgIChwYXRjaCBjb250cmlidXRlZCBieSBEYXZpZCBQYXRpbm8pDQogICAgKiBNYWtlIHg1MDlwYXJzZV92ZXJpZnkoKSByZXR1cm4gQkFEQ0VSVF9DTl9NSVNNQVRDSCB3aGVuIGFuIGVtcHR5DQogICAgICBzdHJpbmcgaXMgcGFzc2VkIGFzIHRoZSBDTiAoYnVnIHJlcG9ydGVkIGJ5IHNwb29meSkNCiAgICAqIEFkZGVkIGFuIG9wdGlvbiB0byBlbmFibGUvZGlzYWJsZSB0aGUgQk4gYXNzZW1ibHkgY29kZQ0KICAgICogVXBkYXRlZCByc2FfY2hlY2tfcHJpdmtleSgpIHRvIHZlcmlmeSB0aGF0IChEKkUpID0gMSAlIChQLTEpKihRLTEpDQogICAgKiBEaXNhYmxlZCBvYnNvbGV0ZSBoYXNoIGZ1bmN0aW9ucyBieSBkZWZhdWx0IChNRDIsIE1ENCk7IHVwZGF0ZWQNCiAgICAgIHNlbGZ0ZXN0IGFuZCBiZW5jaG1hcmsgdG8gbm90IHRlc3QgY2lwaGVycyB0aGF0IGhhdmUgYmVlbiBkaXNhYmxlZA0KICAgICogVXBkYXRlZCB4NTA5cGFyc2VfY2VydF9pbmZvKCkgdG8gY29ycmVjdGx5IGRpc3BsYXkgYnl0ZSAwIG9mIHRoZQ0KICAgICAgc2VyaWFsIG51bWJlciwgc2V0dXAgY29ycmVjdCBzZXJ2ZXIgcG9ydCBpbiB0aGUgc3NsIGNsaWVudCBleGFtcGxlDQogICAgKiBGaXhlZCBhIGNyaXRpY2FsIGRlbmlhbC1vZi1zZXJ2aWNlIHdpdGggWC41MDkgY2VydC4gdmVyaWZpY2F0aW9uOg0KICAgICAgcGVlciBtYXkgY2F1c2UgeHlzc2wgdG8gbG9vcCBpbmRlZmluaXRlbHkgYnkgc2VuZGluZyBhIGNlcnRpZmljYXRlDQogICAgICBmb3Igd2hpY2ggdGhlIFJTQSBzaWduYXR1cmUgY2hlY2sgZmFpbHMgKGJ1ZyByZXBvcnRlZCBieSBCZW5vaXQpDQogICAgKiBBZGRlZCB0ZXN0IHZlY3RvcnMgZm9yOiBBRVMtQ0JDLCBBRVMtQ0ZCLCBERVMtQ0JDIGFuZCAzREVTLUNCQywNCiAgICAgIEhNQUMtTUQ1LCBITUFDLVNIQTEsIEhNQUMtU0hBLTI1NiwgSE1BQy1TSEEtMzg0LCBhbmQgSE1BQy1TSEEtNTEyDQogICAgKiBGaXhlZCBITUFDLVNIQS0zODQgYW5kIEhNQUMtU0hBLTUxMiAodGhhbmtzIHRvIEpvc2ggU2lueWtpbikNCiAgICAqIE1vZGlmaWVkIHNzbF9wYXJzZV9jbGllbnRfa2V5X2V4Y2hhbmdlKCkgdG8gcHJvdGVjdCBhZ2FpbnN0DQogICAgICBEYW5pZWwgQmxlaWNoZW5iYWNoZXIgYXR0YWNrIG9uIFBLQ1MjMSB2MS41IHBhZGRpbmcsIGFzIHdlbGwNCiAgICAgIGFzIHRoZSBLbGltYS1Qb2tvcm55LVJvc2EgZXh0ZW5zaW9uIG9mIEJsZWljaGVuYmFjaGVyJ3MgYXR0YWNrDQogICAgKiBVcGRhdGVkIHJzYV9nZW5fa2V5KCkgc28gdGhhdCBjdHgtPk4gaXMgYWx3YXlzIG5iaXRzIGluIHNpemUNCiAgICAqIEZpeGVkIGFzc2VtYmx5IFBQQyBjb21waWxhdGlvbiBlcnJvcnMgb24gTWFjIE9TIFgsIHRoYW5rcyB0bw0KICAgICAgRGF2aWQgQmFycmV0dCBhbmQgRHVzYW4gU2VtZW4NCg0KPSBWZXJzaW9uIDAuOCByZWxlYXNlZCBvbiAyMDA3LTEwLTIwDQoNCiAgICAqIE1vZGlmaWVkIHRoZSBITUFDIGZ1bmN0aW9ucyB0byBoYW5kbGUga2V5cyBsYXJnZXINCiAgICAgIHRoYW4gNjQgYnl0ZXMsIHRoYW5rcyB0byBTdGVwaGFuZSBEZXNuZXV4IGFuZCBnYXJ5IG5nDQogICAgKiBGaXhlZCBzc2xfcmVhZF9yZWNvcmQoKSB0byBwcm9wZXJseSB1cGRhdGUgdGhlIGhhbmRzaGFrZQ0KICAgICAgbWVzc2FnZSBkaWdlc3RzLCB3aGljaCBmaXhlcyBJRTYvSUU3IGNsaWVudCBhdXRoZW50aWNhdGlvbg0KICAgICogQ2xlYW5lZCB1cCB0aGUgWFlTU0wqICNkZWZpbmVzLCBzdWdnZXN0ZWQgYnkgQXpyaWVsIEZhc3Rlbg0KICAgICogRml4ZWQgbmV0X3JlY3YoKSwgdGhhbmtzIHRvIExvcmVueiBTY2hvcmkgYW5kIEVnb24gS29jamFuDQogICAgKiBBZGRlZCB1c2VyLWRlZmluZWQgY2FsbGJhY2tzIGZvciBoYW5kbGluZyBJL08gYW5kIHNlc3Npb25zDQogICAgKiBBZGRlZCBsb3RzIG9mIGRlYnVnZ2luZyBvdXRwdXQgaW4gdGhlIFNTTC9UTFMgZnVuY3Rpb25zDQogICAgKiBBZGRlZCBwcmVsaW1pbmFyeSBYLjUwOSBjZXJ0LiB3cml0aW5nIGJ5IFBhc2NhbCBWaXplbGkNCiAgICAqIEFkZGVkIHByZWxpbWluYXJ5IHN1cHBvcnQgZm9yIHRoZSBWSUEgUGFkTG9jayByb3V0aW5lcw0KICAgICogQWRkZWQgQUVTLUNGQiBtb2RlIG9mIG9wZXJhdGlvbiwgY29udHJpYnV0ZWQgYnkgY2htaWtlDQogICAgKiBBZGRlZCBhbiBTU0wvVExTIHN0cmVzcyB0ZXN0aW5nIHByb2dyYW0gKHNzbF90ZXN0LmMpDQogICAgKiBVcGRhdGVkIHRoZSBSU0EgUEtDUyMxIGNvZGUgdG8gYWxsb3cgY2hvb3NpbmcgYmV0d2Vlbg0KICAgICAgUlNBX1BVQkxJQyBhbmQgUlNBX1BSSVZBVEUsIGFzIHN1Z2dlc3RlZCBieSBEYXZpZCBCYXJyZXR0DQogICAgKiBVcGRhdGVkIHNzbF9yZWFkKCkgdG8gc2tpcCAwLWxlbmd0aCByZWNvcmRzIGZyb20gT3BlblNTTA0KICAgICogRml4ZWQgdGhlIG1ha2UgaW5zdGFsbCB0YXJnZXQgdG8gY29tcGx5IHdpdGggKkJTRCBtYWtlDQogICAgKiBGaXhlZCBhIGJ1ZyBpbiBtcGlfcmVhZF9iaW5hcnkoKSBvbiA2NC1iaXQgcGxhdGZvcm1zDQogICAgKiBtcGlfaXNfcHJpbWUoKSBzcGVlZHVwcywgdGhhbmtzIHRvIEtldmluIE1jTGF1Z2hsaW4NCiAgICAqIEZpeGVkIGEgbG9uZyBzdGFuZGluZyBtZW1vcnkgbGVhayBpbiBtcGlfaXNfcHJpbWUoKQ0KICAgICogUmVwbGFjZWQgcmVhbGxvYyB3aXRoIG1hbGxvYyBpbiBtcGlfZ3JvdygpLCBhbmQgc2V0DQogICAgICB0aGUgc2lnbiBvZiB6ZXJvIGFzIHBvc2l0aXZlIGluIG1waV9pbml0KCkgKHJlcG9ydGVkDQogICAgICBieSBKb25hdGhhbiBNLiBNY0N1bmUpDQoNCj0gVmVyc2lvbiAwLjcgcmVsZWFzZWQgb24gMjAwNy0wNy0wNw0KDQogICAgKiBBZGRlZCBzdXBwb3J0IGZvciB0aGUgTWljcm9CbGF6ZSBzb2Z0LWNvcmUgcHJvY2Vzc29yDQogICAgKiBGaXhlZCBhIGJ1ZyBpbiBzc2xfdGxzLmMgd2hpY2ggc29tZXRpbWVzIHByZXZlbnRlZCBTU0wNCiAgICAgIGNvbm5lY3Rpb25zIGZyb20gYmVpbmcgZXN0YWJsaXNoZWQgd2l0aCBub24tYmxvY2tpbmcgSS9PDQogICAgKiBGaXhlZCBhIGNvdXBsZSBidWdzIGluIHRoZSBWUzYgYW5kIFVOSVggTWFrZWZpbGVzDQogICAgKiBGaXhlZCB0aGUgIlBJQyByZWdpc3RlciBlYnggY2xvYmJlcmVkIGluIGFzbSIgYnVnDQogICAgKiBBZGRlZCBITUFDIHN0YXJ0cy91cGRhdGUvZmluaXNoIHN1cHBvcnQgZnVuY3Rpb25zDQogICAgKiBBZGRlZCB0aGUgU0hBLTIyNCwgU0hBLTM4NCBhbmQgU0hBLTUxMiBoYXNoIGZ1bmN0aW9ucw0KICAgICogRml4ZWQgdGhlIG5ldF9zZXRfKmJsb2NrIHJvdXRpbmVzLCB0aGFua3MgdG8gQW5kcmVhcw0KICAgICogQWRkZWQgYSBmZXcgZGVtb25zdHJhdGlvbiBwcm9ncmFtczogbWQ1c3VtLCBzaGExc3VtLA0KICAgICAgZGhfY2xpZW50LCBkaF9zZXJ2ZXIsIHJzYV9nZW5rZXksIHJzYV9zaWduLCByc2FfdmVyaWZ5DQogICAgKiBBZGRlZCBuZXcgYmlnbnVtIGltcG9ydCBhbmQgZXhwb3J0IGhlbHBlciBmdW5jdGlvbnMNCiAgICAqIFJld3JvdGUgUkVBRE1FLnR4dCBpbiBwcm9ncmFtL3NzbC9jYSB0byBiZXR0ZXIgZXhwbGFpbg0KICAgICAgaG93IHRvIGNyZWF0ZSBhIHRlc3QgUEtJDQoNCj0gVmVyc2lvbiAwLjYgcmVsZWFzZWQgb24gMjAwNy0wNC0wMQ0KDQogICAgKiBDaXBoZXJzIHVzZWQgaW4gU1NML1RMUyBjYW4gbm93IGJlIGRpc2FibGVkIGF0IGNvbXBpbGUNCiAgICAgIHRpbWUsIHRvIHJlZHVjZSB0aGUgbWVtb3J5IGZvb3RwcmludCBvbiBlbWJlZGRlZCBzeXN0ZW1zDQogICAgKiBBZGRlZCBtdWx0aXBseSBhc3NlbWJseSBjb2RlIGZvciB0aGUgVHJpQ29yZSBhbmQgbW9kaWZpZWQNCiAgICAgIGhhdmVnZV9zdHJ1Y3QgZm9yIHRoaXMgcHJvY2Vzc29yLCB0aGFua3MgdG8gRGF2aWQgUGF0afFvDQogICAgKiBBZGRlZCBtdWx0aXBseSBhc3NlbWJseSBjb2RlIGZvciA2NC1iaXQgUG93ZXJQQ3MsDQogICAgICB0aGFua3MgdG8gUGVraW5nIFVuaXZlcnNpdHkgYW5kIHRoZSBPU1UgT3BlbiBTb3VyY2UgTGFiDQogICAgKiBBZGRlZCBleHBlcmltZW50YWwgc3VwcG9ydCBvZiBRdWFudHVtIENyeXB0b2dyYXBoeQ0KICAgICogQWRkZWQgc3VwcG9ydCBmb3IgYXV0b2NvbmYsIGNvbnRyaWJ1dGVkIGJ5IEFybmF1ZCBDb3JuZXQNCiAgICAqIEZpeGVkICJsb25nIGxvbmciIGNvbXBpbGF0aW9uIGlzc3VlcyBvbiBJQS02NCBhbmQgUFBDNjQNCiAgICAqIEZpeGVkIGEgYnVnIGludHJvZHVjZWQgaW4geHlzc2wtMC41L3RpbWluZy5jOiBoYXJkY2xvY2sNCiAgICAgIHdhcyBub3QgYmVpbmcgY29ycmVjdGx5IGRlZmluZWQgb24gQVJNIGFuZCBNSVBTDQoNCj0gVmVyc2lvbiAwLjUgcmVsZWFzZWQgb24gMjAwNy0wMy0wMQ0KDQogICAgKiBBZGRlZCBtdWx0aXBseSBhc3NlbWJseSBjb2RlIGZvciBTUEFSQyBhbmQgQWxwaGENCiAgICAqIEFkZGVkIChiZXRhKSBzdXBwb3J0IGZvciBub24tYmxvY2tpbmcgSS9PIG9wZXJhdGlvbnMNCiAgICAqIEltcGxlbWVudGVkIHNlc3Npb24gcmVzdW1pbmcgYW5kIGNsaWVudCBhdXRoZW50aWNhdGlvbg0KICAgICogRml4ZWQgc29tZSBwb3J0YWJpbGl0eSBpc3N1ZXMgb24gV2luQ0UsIE1JTklYIDMsIFBsYW45DQogICAgICAodGhhbmtzIHRvIEJlbmphbWluIE5ld21hbiksIEhQLVVYLCBGcmVlQlNEIGFuZCBTb2xhcmlzDQogICAgKiBJbXByb3ZlZCB0aGUgcGVyZm9ybWFuY2Ugb2YgdGhlIEVESCBrZXkgZXhjaGFuZ2UNCiAgICAqIEZpeGVkIGEgYnVnIHRoYXQgY2F1c2VkIHZhbGlkIHBhY2tldHMgd2l0aCBhIHBheWxvYWQNCiAgICAgIHNpemUgb2YgMTYzODQgYnl0ZXMgdG8gYmUgcmVqZWN0ZWQNCg0KPSBWZXJzaW9uIDAuNCByZWxlYXNlZCBvbiAyMDA3LTAyLTAxDQoNCiAgICAqIEFkZGVkIHN1cHBvcnQgZm9yIEVwaGVtZXJhbCBEaWZmaWUtSGVsbG1hbiBrZXkgZXhjaGFuZ2UNCiAgICAqIEFkZGVkIG11bHRpcGx5IGFzbSBjb2RlIGZvciBTU0UyLCBBUk0sIFBQQywgTUlQUyBhbmQgTTY4Sw0KICAgICogVmFyaW91cyBpbXByb3ZlbWVudCB0byB0aGUgbW9kdWxhciBleHBvbmVudGlhdGlvbiBjb2RlDQogICAgKiBSZXdyb3RlIHRoZSBoZWFkZXJzIHRvIGdlbmVyYXRlIHRoZSBBUEkgZG9jcyB3aXRoIGRveHlnZW4NCiAgICAqIEZpeGVkIGEgYnVnIGluIHNzbF9lbmNyeXB0X2J1ZiAoaW5jb3JyZWN0IHBhZGRpbmcgd2FzDQogICAgICBnZW5lcmF0ZWQpIGFuZCBpbiBzc2xfcGFyc2VfY2xpZW50X2hlbGxvIChtYXguIGNsaWVudA0KICAgICAgdmVyc2lvbiB3YXMgbm90IHByb3Blcmx5IHNldCksIHRoYW5rcyB0byBEaWRpZXIgUmViZWl4DQogICAgKiBGaXhlZCBhbm90aGVyIGJ1ZyBpbiBzc2xfcGFyc2VfY2xpZW50X2hlbGxvOiBjbGllbnRzIHdpdGgNCiAgICAgIGNpcGhlcmxpc3RzIGxhcmdlciB0aGFuIDk2IGJ5dGVzIHdlcmUgaW5jb3JyZWN0bHkgcmVqZWN0ZWQNCiAgICAqIEZpeGVkIGEgY291cGxlIG1lbW9yeSBsZWFrIGluIHg1MDlfcmVhZC5jDQoNCj0gVmVyc2lvbiAwLjMgcmVsZWFzZWQgb24gMjAwNy0wMS0wMQ0KDQogICAgKiBBZGRlZCBzZXJ2ZXItc2lkZSBTU0x2MyBhbmQgVExTdjEuMCBzdXBwb3J0DQogICAgKiBNdWx0aXBsZSBmaXhlcyB0byBlbmhhbmNlIHRoZSBjb21wYXRpYmlsaXR5IHdpdGggZysrLA0KICAgICAgdGhhbmtzIHRvIFhvc+kgQW50824gT3Rlcm8gRmVycmVpcmENCiAgICAqIEZpeGVkIGEgYnVnIGluIHRoZSBDQkMgY29kZSwgdGhhbmtzIHRvIGRvd3N0OyBhbHNvLA0KICAgICAgdGhlIGJpZ251bSBjb2RlIGlzIG5vIGxvbmdlciBkZXBlbmRhbnQgb24gbG9uZyBsb25nDQogICAgKiBVcGRhdGVkIHJzYV9wa2NzMV9zaWduIHRvIGhhbmRsZSBhcmJpdHJhcnkgbGFyZ2UgaW5wdXRzDQogICAgKiBVcGRhdGVkIHRpbWluZy5jIGZvciBpbXByb3ZlZCBjb21wYXRpYmlsaXR5IHdpdGggaTM4Ng0KICAgICAgYW5kIDQ4NiBwcm9jZXNzb3JzLCB0aGFua3MgdG8gQXJuYXVkIENvcm5ldA0KDQo9IFZlcnNpb24gMC4yIHJlbGVhc2VkIG9uIDIwMDYtMTItMDENCg0KICAgICogVXBkYXRlZCB0aW1pbmcuYyB0byBzdXBwb3J0IEFSTSBhbmQgTUlQUyBhcmNoDQogICAgKiBVcGRhdGVkIHRoZSBNUEkgY29kZSB0byBzdXBwb3J0IDgwODYgb24gTVNWQyAxLjUNCiAgICAqIEFkZGVkIHRoZSBjb3B5cmlnaHQgbm90aWNlIGF0IHRoZSB0b3Agb2YgaGF2ZWdlLmgNCiAgICAqIEZpeGVkIGEgYnVnIGluIHNoYTJfaG1hYywgdGhhbmtzIHRvIG5ld3NvZnQvV2VuZmFuZyBaaGFuZw0KICAgICogRml4ZWQgYSBidWcgcmVwb3J0ZWQgYnkgQWRyaWFuIFL8ZWdzZWdnZXIgaW4geDUwOV9yZWFkX2tleQ0KICAgICogRml4ZWQgYSBidWcgcmVwb3J0ZWQgYnkgVG9yc3RlbiBMYXV0ZXIgaW4gc3NsX3JlYWRfcmVjb3JkDQogICAgKiBGaXhlZCBhIGJ1ZyBpbiByc2FfY2hlY2tfcHJpdmtleSB0aGF0IHdvdWxkIHdyb25nbHkgY2F1c2UNCiAgICAgIHZhbGlkIFJTQSBrZXlzIHRvIGJlIGRpc21pc3NlZCAodGhhbmtzIHRvIG9sZHdvbGYpDQogICAgKiBGaXhlZCBhIGJ1ZyBpbiBtcGlfaXNfcHJpbWUgdGhhdCBjYXVzZWQgc29tZSBwcmltZXMgdG8gZmFpbA0KICAgICAgdGhlIE1pbGxlci1SYWJpbiBwcmltYWxpdHkgdGVzdA0KDQogICAgSSdkIGFsc28gbGlrZSB0byB0aGFuayBZb3Vu6HMgSGFmcmkgZm9yIHRoZSBDUlVYIGxpbnV4IHBvcnQsDQogICAgS2hhbGlsIFBldGl0IHdobyBhZGRlZCBYeVNTTCBpbnRvIHBrZ3NyYyBhbmQgQXJuYXVkIENvcm5ldA0KICAgIHdobyBtYWludGFpbnMgdGhlIERlYmlhbiBwYWNrYWdlIDotKQ0KDQo9IFZlcnNpb24gMC4xIHJlbGVhc2VkIG9uIDIwMDYtMTEtMDENCg0K