LyoNCiAqIEZyZWVSVE9TIEtlcm5lbCBWMTAuMy4wDQogKiBDb3B5cmlnaHQgKEMpIDIwMjAgQW1hem9uLmNvbSwgSW5jLiBvciBpdHMgYWZmaWxpYXRlcy4gIEFsbCBSaWdodHMgUmVzZXJ2ZWQuDQogKg0KICogUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weSBvZg0KICogdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgIlNvZnR3YXJlIiksIHRvIGRlYWwgaW4NCiAqIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHMgdG8NCiAqIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgY29waWVzIG9mDQogKiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpcyBmdXJuaXNoZWQgdG8gZG8gc28sDQogKiBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoNCiAqDQogKiBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbiBhbGwNCiAqIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuDQogKg0KICogVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEICJBUyBJUyIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1INCiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTDQogKiBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFIEFVVEhPUlMgT1INCiAqIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSIExJQUJJTElUWSwgV0hFVEhFUg0KICogSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4NCiAqIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEUgU09GVFdBUkUuDQogKg0KICogaHR0cDovL3d3dy5GcmVlUlRPUy5vcmcNCiAqIGh0dHA6Ly9hd3MuYW1hem9uLmNvbS9mcmVlcnRvcw0KICoNCiAqIDEgdGFiID09IDQgc3BhY2VzIQ0KICovDQoNCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioNCiAqIFRoaXMgcHJvamVjdCBwcm92aWRlcyB0d28gZGVtbyBhcHBsaWNhdGlvbnMuICBBIHNpbXBsZSBibGlua3kgc3R5bGUgcHJvamVjdCwNCiAqIGFuZCBhIG1vcmUgY29tcHJlaGVuc2l2ZSB0ZXN0IGFuZCBkZW1vIGFwcGxpY2F0aW9uLiAgVGhlDQogKiBtYWluQ1JFQVRFX1NJTVBMRV9CTElOS1lfREVNT19PTkxZIHNldHRpbmcgKGRlZmluZWQgaW4gdGhpcyBmaWxlKSBpcyB1c2VkIHRvDQogKiBzZWxlY3QgYmV0d2VlbiB0aGUgdHdvLiAgVGhlIHNpbXBseSBibGlua3kgZGVtbyBpcyBpbXBsZW1lbnRlZCBhbmQgZGVzY3JpYmVkDQogKiBpbiBtYWluX2JsaW5reS5jLiAgVGhlIG1vcmUgY29tcHJlaGVuc2l2ZSB0ZXN0IGFuZCBkZW1vIGFwcGxpY2F0aW9uIGlzDQogKiBpbXBsZW1lbnRlZCBhbmQgZGVzY3JpYmVkIGluIG1haW5fZnVsbC5jLg0KICoNCiAqIFRoaXMgZmlsZSBpbXBsZW1lbnRzIHRoZSBjb2RlIHRoYXQgaXMgbm90IGRlbW8gc3BlY2lmaWMsIGluY2x1ZGluZyB0aGUNCiAqIGhhcmR3YXJlIHNldHVwLCBzdGFuZGFyZCBGcmVlUlRPUyBob29rIGZ1bmN0aW9ucywgYW5kIHRoZSBJU1IgaGFuZGVyIGNhbGxlZA0KICogYnkgdGhlIFJUT1MgYWZ0ZXIgaW50ZXJydXB0IGVudHJ5IChpbmNsdWRpbmcgbmVzdGluZykgaGFzIGJlZW4gdGFrZW4gY2FyZSBvZi4NCiAqDQogKiBOT1RFIG9uIExFRFM6DQogKg0KICogICAgIFRoaXMgZGVtbyBpcyBOT1QgY29uZmlndXJlZCB0byB1c2UgdGhlIExFRCBidWlsdCBvbnRvIHRoZSBTQU1BNkQyDQogKiAgICAgWFBMYWluZWQgYm9hcmQhDQogKg0KICogICAgIFRoZSBMRUQgZHJpdmVyIFBJTl9MRUQgZGVmaW5pdGlvbnMgaGF2ZSBiZWVuIGFsdGVyZWQgaW4NCiAqICAgICBib2FyZF9zYW1hNWQyLXhwbGFpbmVkLmggdG8gcmVtYXAgdGhlbSB0byBHUElPcyB0ZXJtaW5hdGluZyBvbiBwaW5zIDMwLA0KICogICAgIDMyIGFuZCAzNCBvZiBKMTcuIChUaGlzIGNoYW5nZSBpcyBjb25kaXRpb25hbCBvbiB0aGUgcHJlcHJvY2Vzc29yDQogKiAgICAgI2RlZmluZSAiTEVEU19PTl9KMTciLikgVGhlc2UgR1BJT3MgYXJlIGNvbmZpZ3VyZWQgdG8gYmUgImhpZ2ggZHJpdmUiDQogKiAgICAgcHVzaC1wdWxsIG91dHB1dHM7IHRoZXkgY2FuIHNvdXJjZSB1cCB0byAxOG1BIGF0IDEuOHYuIExvdw0KICogICAgIGZvcndhcmQtdm9sdGFnZSBMRURzIG1heSBiZSBjb25uZWN0ZWQgdmlhIDEwMCBvaG0gcmVzaXN0b3JzIHRvIHBpbnMNCiAqICAgICAzMCwgMzIgYW5kIDM0IHdpdGggdGhlaXIgY2F0aG9kZXMgdG8gcGluIDM1LzM2IChHTkQpLg0KICoNCiAqLw0KDQovKg0KICogUHJvY2VkdXJlIHRvIGRvd25sb2FkIGFuZCBleGVjdXRlIGNvZGUgZnJvbSBSQU0NCiAqIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQogKg0KICogMS4gQ2xvc2UganVtcGVyIEpQOShCT09UX0RJUykgYW5kIEpQMihERUJVR19ESVMpLg0KICogMi4gT3BlbiBqdW1wZXIgSlAxKEVEQkdfRElTKS4NCiAqIDMuIFBvd2VyIG9uIHRoZSBib2FyZCBieSBVU0IgY29ubmVjdGlvbiBvbiBKMTQoRURCR19KVEFHKS4NCiAqIDQuIE9wZW4gk0VEQkcgVmlydHVhbCBDT00gUG9ydJQgd2l0aCBzZXR0aW5nIJM1NzYwMCw4LE4sMZQuDQogKiA1LiBUeXBlIJMjlCBvbiBIeXBlclRlcm1pbmFsIGFuZCBnZXQgkz6UIGFzIGEgcmVwbHkuDQogKiA2LiBEb26SdCByZXNldCB0aGUgYm9hcmQgZHVyaW5nIGRlYnVnZ2luZy4gRm9yIElBUiwgc2V0IHRoZSBEZWJ1Z2dlciB0byBDTVNJUw0KICogICAgREFQLCB3aXRoIHRoZSAiRGlzYWJsZWQobm8gcmVzZXQpIiBvcHRpb24uDQogKi8NCg0KLyogU2NoZWR1bGVyIGluY2x1ZGUgZmlsZXMuICovDQojaW5jbHVkZSAiRnJlZVJUT1MuaCINCiNpbmNsdWRlICJ0YXNrLmgiDQojaW5jbHVkZSAic2VtcGhyLmgiDQoNCi8qIFN0YW5kYXJkIGRlbW8gaW5jbHVkZXMuICovDQojaW5jbHVkZSAicGFydGVzdC5oIg0KI2luY2x1ZGUgIlRpbWVyRGVtby5oIg0KI2luY2x1ZGUgIlF1ZXVlT3ZlcndyaXRlLmgiDQojaW5jbHVkZSAiRXZlbnRHcm91cHNEZW1vLmgiDQoNCi8qIExpYnJhcnkgaW5jbHVkZXMuICovDQojaW5jbHVkZSAiYm9hcmRfc2FtYTVkMi14cGxhaW5lZC5oIg0KI2luY2x1ZGUgInBlcmlwaGVyYWxzL3dkdC5oIg0KI2luY2x1ZGUgInBlcmlwaGVyYWxzL3Bpby5oIg0KI2luY2x1ZGUgImNoaXAuaCINCg0KLyogU2V0IG1haW5DUkVBVEVfU0lNUExFX0JMSU5LWV9ERU1PX09OTFkgdG8gb25lIHRvIHJ1biB0aGUgc2ltcGxlIGJsaW5reSBkZW1vLA0Kb3IgMCB0byBydW4gdGhlIG1vcmUgY29tcHJlaGVuc2l2ZSB0ZXN0IGFuZCBkZW1vIGFwcGxpY2F0aW9uLiAqLw0KI2RlZmluZSBtYWluQ1JFQVRFX1NJTVBMRV9CTElOS1lfREVNT19PTkxZCTENCg0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCi8qDQogKiBDb25maWd1cmUgdGhlIGhhcmR3YXJlIGFzIG5lY2Vzc2FyeSB0byBydW4gdGhpcyBkZW1vLg0KICovDQpzdGF0aWMgdm9pZCBwcnZTZXR1cEhhcmR3YXJlKCB2b2lkICk7DQoNCi8qDQogKiBtYWluX2JsaW5reSgpIGlzIHVzZWQgd2hlbiBtYWluQ1JFQVRFX1NJTVBMRV9CTElOS1lfREVNT19PTkxZIGlzIHNldCB0byAxLg0KICogbWFpbl9mdWxsKCkgaXMgdXNlZCB3aGVuIG1haW5DUkVBVEVfU0lNUExFX0JMSU5LWV9ERU1PX09OTFkgaXMgc2V0IHRvIDAuDQogKi8NCiNpZiBtYWluQ1JFQVRFX1NJTVBMRV9CTElOS1lfREVNT19PTkxZID09IDENCglleHRlcm4gdm9pZCBtYWluX2JsaW5reSggdm9pZCApOw0KI2Vsc2UNCglleHRlcm4gdm9pZCBtYWluX2Z1bGwoIHZvaWQgKTsNCiNlbmRpZiAvKiAjaWYgbWFpbkNSRUFURV9TSU1QTEVfQkxJTktZX0RFTU9fT05MWSA9PSAxICovDQoNCi8qIFByb3RvdHlwZXMgZm9yIHRoZSBzdGFuZGFyZCBGcmVlUlRPUyBjYWxsYmFjay9ob29rIGZ1bmN0aW9ucyBpbXBsZW1lbnRlZA0Kd2l0aGluIHRoaXMgZmlsZS4gKi8NCnZvaWQgdkFwcGxpY2F0aW9uTWFsbG9jRmFpbGVkSG9vayggdm9pZCApOw0Kdm9pZCB2QXBwbGljYXRpb25JZGxlSG9vayggdm9pZCApOw0Kdm9pZCB2QXBwbGljYXRpb25TdGFja092ZXJmbG93SG9vayggVGFza0hhbmRsZV90IHB4VGFzaywgY2hhciAqcGNUYXNrTmFtZSApOw0Kdm9pZCB2QXBwbGljYXRpb25UaWNrSG9vayggdm9pZCApOw0KDQovKiBQcm90b3R5cGUgZm9yIHRoZSBJUlEgaGFuZGxlciBjYWxsZWQgYnkgdGhlIGdlbmVyaWMgQ29ydGV4LUE1IFJUT1MgcG9ydA0KbGF5ZXIuICovDQp2b2lkIHZBcHBsaWNhdGlvbklSUUhhbmRsZXIoIHZvaWQgKTsNCg0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCmludCBtYWluKCB2b2lkICkNCnsNCgkvKiBDb25maWd1cmUgdGhlIGhhcmR3YXJlIHJlYWR5IHRvIHJ1biB0aGUgZGVtby4gKi8NCglwcnZTZXR1cEhhcmR3YXJlKCk7DQoNCgkvKiBUaGUgbWFpbkNSRUFURV9TSU1QTEVfQkxJTktZX0RFTU9fT05MWSBzZXR0aW5nIGlzIGRlc2NyaWJlZCBhdCB0aGUgdG9wDQoJb2YgdGhpcyBmaWxlLiAqLw0KCSNpZiggbWFpbkNSRUFURV9TSU1QTEVfQkxJTktZX0RFTU9fT05MWSA9PSAxICkNCgl7DQoJCW1haW5fYmxpbmt5KCk7DQoJfQ0KCSNlbHNlDQoJew0KCQltYWluX2Z1bGwoKTsNCgl9DQoJI2VuZGlmDQoNCglyZXR1cm4gMDsNCn0NCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLw0KDQpzdGF0aWMgdm9pZCBwcnZTZXR1cEhhcmR3YXJlKCB2b2lkICkNCnsNCgkvKiBEaXNhYmxlIHdhdGNoZG9nICovDQoJd2R0X2Rpc2FibGUoICk7DQoNCgkvKiBTZXQgcHJvdGVjdCBtb2RlIGluIHRoZSBBSUMgZm9yIGVhc2llciBkZWJ1Z2dpbmcuICovDQoJQUlDLT5BSUNfRENSIHw9IEFJQ19EQ1JfUFJPVDsNCg0KCS8qIENvbmZpZ3VyZSBwb3J0cyB1c2VkIGJ5IExFRHMuICovDQoJdlBhclRlc3RJbml0aWFsaXNlKCk7DQoNCgkjaWYgZGVmaW5lZCAoZGRyYW0pDQoJCU1NVV9Jbml0aWFsaXplKCAoIHVpbnQzMl90ICogKSAweDMwQzAwMCApOw0KCQlDUDE1X0VuYWJsZU1NVSgpOw0KCQlDUDE1X0VuYWJsZURjYWNoZSgpOw0KCQlDUDE1X0VuYWJsZUljYWNoZSgpOw0KCSNlbmRpZg0KfQ0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCnZvaWQgdkFwcGxpY2F0aW9uTWFsbG9jRmFpbGVkSG9vayggdm9pZCApDQp7DQoJLyogQ2FsbGVkIGlmIGEgY2FsbCB0byBwdlBvcnRNYWxsb2MoKSBmYWlscyBiZWNhdXNlIHRoZXJlIGlzIGluc3VmZmljaWVudA0KCWZyZWUgbWVtb3J5IGF2YWlsYWJsZSBpbiB0aGUgRnJlZVJUT1MgaGVhcC4gIHB2UG9ydE1hbGxvYygpIGlzIGNhbGxlZA0KCWludGVybmFsbHkgYnkgRnJlZVJUT1MgQVBJIGZ1bmN0aW9ucyB0aGF0IGNyZWF0ZSB0YXNrcywgcXVldWVzLCBzb2Z0d2FyZQ0KCXRpbWVycywgYW5kIHNlbWFwaG9yZXMuICBUaGUgc2l6ZSBvZiB0aGUgRnJlZVJUT1MgaGVhcCBpcyBzZXQgYnkgdGhlDQoJY29uZmlnVE9UQUxfSEVBUF9TSVpFIGNvbmZpZ3VyYXRpb24gY29uc3RhbnQgaW4gRnJlZVJUT1NDb25maWcuaC4gKi8NCg0KCS8qIEZvcmNlIGFuIGFzc2VydC4gKi8NCgljb25maWdBU1NFUlQoICggdm9sYXRpbGUgdm9pZCAqICkgTlVMTCApOw0KfQ0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCnZvaWQgdkFwcGxpY2F0aW9uU3RhY2tPdmVyZmxvd0hvb2soIFRhc2tIYW5kbGVfdCBweFRhc2ssIGNoYXIgKnBjVGFza05hbWUgKQ0Kew0KCSggdm9pZCApIHBjVGFza05hbWU7DQoJKCB2b2lkICkgcHhUYXNrOw0KDQoJLyogUnVuIHRpbWUgc3RhY2sgb3ZlcmZsb3cgY2hlY2tpbmcgaXMgcGVyZm9ybWVkIGlmDQoJY29uZmlnQ0hFQ0tfRk9SX1NUQUNLX09WRVJGTE9XIGlzIGRlZmluZWQgdG8gMSBvciAyLiAgVGhpcyBob29rDQoJZnVuY3Rpb24gaXMgY2FsbGVkIGlmIGEgc3RhY2sgb3ZlcmZsb3cgaXMgZGV0ZWN0ZWQuICovDQoNCgkvKiBGb3JjZSBhbiBhc3NlcnQuICovDQoJY29uZmlnQVNTRVJUKCAoIHZvbGF0aWxlIHZvaWQgKiApIE5VTEwgKTsNCn0NCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLw0KDQp2b2lkIHZBcHBsaWNhdGlvbklkbGVIb29rKCB2b2lkICkNCnsNCnZvbGF0aWxlIHNpemVfdCB4RnJlZUhlYXBTcGFjZTsNCg0KCS8qIFRoaXMgaXMganVzdCBhIHRyaXZpYWwgZXhhbXBsZSBvZiBhbiBpZGxlIGhvb2suICBJdCBpcyBjYWxsZWQgb24gZWFjaA0KCWN5Y2xlIG9mIHRoZSBpZGxlIHRhc2suICBJdCBtdXN0ICpOT1QqIGF0dGVtcHQgdG8gYmxvY2suICBJbiB0aGlzIGNhc2UgdGhlDQoJaWRsZSB0YXNrIGp1c3QgcXVlcmllcyB0aGUgYW1vdW50IG9mIEZyZWVSVE9TIGhlYXAgdGhhdCByZW1haW5zLiAgU2VlIHRoZQ0KCW1lbW9yeSBtYW5hZ2VtZW50IHNlY3Rpb24gb24gdGhlIGh0dHA6Ly93d3cuRnJlZVJUT1Mub3JnIHdlYiBzaXRlIGZvciBtZW1vcnkNCgltYW5hZ2VtZW50IG9wdGlvbnMuICBJZiB0aGVyZSBpcyBhIGxvdCBvZiBoZWFwIG1lbW9yeSBmcmVlIHRoZW4gdGhlDQoJY29uZmlnVE9UQUxfSEVBUF9TSVpFIHZhbHVlIGluIEZyZWVSVE9TQ29uZmlnLmggY2FuIGJlIHJlZHVjZWQgdG8gZnJlZSB1cA0KCVJBTS4gKi8NCgl4RnJlZUhlYXBTcGFjZSA9IHhQb3J0R2V0RnJlZUhlYXBTaXplKCk7DQoNCgkvKiBSZW1vdmUgY29tcGlsZXIgd2FybmluZyBhYm91dCB4RnJlZUhlYXBTcGFjZSBiZWluZyBzZXQgYnV0IG5ldmVyIHVzZWQuICovDQoJKCB2b2lkICkgeEZyZWVIZWFwU3BhY2U7DQp9DQovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8NCg0Kdm9pZCB2QXNzZXJ0Q2FsbGVkKCBjb25zdCBjaGFyICogcGNGaWxlLCB1bnNpZ25lZCBsb25nIHVsTGluZSApDQp7DQp2b2xhdGlsZSB1bnNpZ25lZCBsb25nIHVsID0gMDsNCg0KCSggdm9pZCApIHBjRmlsZTsNCgkoIHZvaWQgKSB1bExpbmU7DQoNCgl0YXNrRU5URVJfQ1JJVElDQUwoKTsNCgl7DQoJCS8qIFNldCB1bCB0byBhIG5vbi16ZXJvIHZhbHVlIHVzaW5nIHRoZSBkZWJ1Z2dlciB0byBzdGVwIG91dCBvZiB0aGlzDQoJCWZ1bmN0aW9uLiAqLw0KCQl3aGlsZSggdWwgPT0gMCApDQoJCXsNCgkJCXBvcnROT1AoKTsNCgkJfQ0KCX0NCgl0YXNrRVhJVF9DUklUSUNBTCgpOw0KfQ0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCnZvaWQgdkFwcGxpY2F0aW9uVGlja0hvb2soIHZvaWQgKQ0Kew0KCSNpZiBtYWluQ1JFQVRFX1NJTVBMRV9CTElOS1lfREVNT19PTkxZID09IDANCgl7DQoJCS8qIFRoZSBmdWxsIGRlbW8gaW5jbHVkZXMgYSBzb2Z0d2FyZSB0aW1lciBkZW1vL3Rlc3QgdGhhdCByZXF1aXJlcw0KCQlwcm9kZGluZyBwZXJpb2RpY2FsbHkgZnJvbSB0aGUgdGljayBpbnRlcnJ1cHQuICovDQoJCXZUaW1lclBlcmlvZGljSVNSVGVzdHMoKTsNCg0KCQkvKiBDYWxsIHRoZSBwZXJpb2RpYyBxdWV1ZSBvdmVyd3JpdGUgZnJvbSBJU1IgZGVtby4gKi8NCgkJdlF1ZXVlT3ZlcndyaXRlUGVyaW9kaWNJU1JEZW1vKCk7DQoNCgkJLyogQ2FsbCB0aGUgcGVyaW9kaWMgZXZlbnQgZ3JvdXAgZnJvbSBJU1IgZGVtby4gKi8NCgkJdlBlcmlvZGljRXZlbnRHcm91cHNQcm9jZXNzaW5nKCk7DQoJfQ0KCSNlbmRpZg0KfQ0KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovDQoNCi8qIFRoZSBmdW5jdGlvbiBjYWxsZWQgYnkgdGhlIFJUT1MgcG9ydCBsYXllciBhZnRlciBpdCBoYXMgbWFuYWdlZCBpbnRlcnJ1cHQNCmVudHJ5LiAqLw0Kdm9pZCB2QXBwbGljYXRpb25JUlFIYW5kbGVyKCB2b2lkICkNCnsNCnR5cGVkZWYgdm9pZCAoKklTUkZ1bmN0aW9uX3QpKCB2b2lkICk7DQpJU1JGdW5jdGlvbl90IHB4SVNSRnVuY3Rpb247DQp2b2xhdGlsZSB1aW50MzJfdCAqIHB1bEFJQ19JVlIgPSAoIHVpbnQzMl90ICogKSBjb25maWdJTlRFUlJVUFRfVkVDVE9SX0FERFJFU1M7DQoNCgkvKiBPYnRhaW4gdGhlIGFkZHJlc3Mgb2YgdGhlIGludGVycnVwdCBoYW5kbGVyIGZyb20gdGhlIEFJUi4gKi8NCglweElTUkZ1bmN0aW9uID0gKCBJU1JGdW5jdGlvbl90ICkgKnB1bEFJQ19JVlI7DQoNCgkvKiBXcml0ZSBiYWNrIHRvIHRoZSBTQU1BNSdzIGludGVycnVwdCBjb250cm9sbGVyJ3MgSVZSIHJlZ2lzdGVyIGluIGNhc2UgdGhlDQoJQ1BVIGlzIGluIHByb3RlY3QgbW9kZS4gIElmIHRoZSBpbnRlcnJ1cHQgY29udHJvbGxlciBpcyBub3QgaW4gcHJvdGVjdCBtb2RlDQoJdGhlbiB0aGlzIHdyaXRlIGlzIG5vdCBuZWNlc3NhcnkuICovDQoJKnB1bEFJQ19JVlIgPSAoIHVpbnQzMl90ICkgcHhJU1JGdW5jdGlvbjsNCg0KCS8qIEVuc3VyZSB0aGUgd3JpdGUgdGFrZXMgYmVmb3JlIHJlLWVuYWJsaW5nIGludGVycnVwdHMuICovDQoJX19EU0IoKTsNCglfX0lTQigpOw0KCV9fZW5hYmxlX2lycSgpOw0KDQoJLyogQ2FsbCB0aGUgaW5zdGFsbGVkIElTUi4gKi8NCglweElTUkZ1bmN0aW9uKCk7DQp9DQoNCi8qIEtlZXAgdGhlIGxpbmtlciBxdWlldC4gKi8NCnNpemVfdCBfX3dyaXRlKGludCwgY29uc3QgdW5zaWduZWQgY2hhciAqLCBzaXplX3QpOw0Kc2l6ZV90IF9fd3JpdGUoaW50IGYsIGNvbnN0IHVuc2lnbmVkIGNoYXIgKnAsIHNpemVfdCBzKQ0Kew0KICAodm9pZCkgZjsNCiAgKHZvaWQpIHA7DQogICh2b2lkKSBzOw0KICByZXR1cm4gMDsNCn0NCg0KDQoNCg==