LyoqCiAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAgKiBAZmlsZSAgICBzdG0zMmg3eHhfaGFsX2NyeXBfZXguYwogICogQGF1dGhvciAgTUNEIEFwcGxpY2F0aW9uIFRlYW0KICAqIEBicmllZiAgIEV4dGVuZGVkIENSWVAgSEFMIG1vZHVsZSBkcml2ZXIKICAqICAgICAgICAgIFRoaXMgZmlsZSBwcm92aWRlcyBmaXJtd2FyZSBmdW5jdGlvbnMgdG8gbWFuYWdlIHRoZSBmb2xsb3dpbmcKICAqICAgICAgICAgIGZ1bmN0aW9uYWxpdGllcyBvZiBDUllQIGV4dGVuc2lvbiBwZXJpcGhlcmFsOgogICogICAgICAgICAgICsgRXh0ZW5kZWQgQUVTIHByb2Nlc3NpbmcgZnVuY3Rpb25zCiAgKgogIEB2ZXJiYXRpbQogID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQogICAgICAgICAgICAgICAgICAgICAjIyMjIyBIb3cgdG8gdXNlIHRoaXMgZHJpdmVyICMjIyMjCiAgPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiAgICBbLi5dCiAgICBUaGUgQ1JZUCBleHRlbnNpb24gSEFMIGRyaXZlciBjYW4gYmUgdXNlZCBhZnRlciBBRVMtR0NNIG9yIEFFUy1DQ00KICAgIEVuY3J5cHRpb24vRGVjcnlwdGlvbiB0byBnZXQgdGhlIGF1dGhlbnRpY2F0aW9uIG1lc3NhZ2VzLgoKICBAZW5kdmVyYmF0aW0KICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICAqIEBhdHRlbnRpb24KICAqCiAgKiA8aDI+PGNlbnRlcj4mY29weTsgQ29weXJpZ2h0IChjKSAyMDE3IFNUTWljcm9lbGVjdHJvbmljcy4KICAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuPC9jZW50ZXI+PC9oMj4KICAqCiAgKiBUaGlzIHNvZnR3YXJlIGNvbXBvbmVudCBpcyBsaWNlbnNlZCBieSBTVCB1bmRlciBCU0QgMy1DbGF1c2UgbGljZW5zZSwKICAqIHRoZSAiTGljZW5zZSI7IFlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUKICAqIExpY2Vuc2UuIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdDoKICAqICAgICAgICAgICAgICAgICAgICAgICAgb3BlbnNvdXJjZS5vcmcvbGljZW5zZXMvQlNELTMtQ2xhdXNlCiAgKgogICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogICovCgovKiBJbmNsdWRlcyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwojaW5jbHVkZSAic3RtMzJoN3h4X2hhbC5oIgoKLyoqIEBhZGR0b2dyb3VwIFNUTTMySDd4eF9IQUxfRHJpdmVyCiAgKiBAewogICovCiNpZiBkZWZpbmVkIChDUllQKQovKiogQGRlZmdyb3VwIENSWVBFeCBDUllQRXgKICAqIEBicmllZiBDUllQIEV4dGVuc2lvbiBIQUwgbW9kdWxlIGRyaXZlci4KICAqIEB7CiAgKi8KCiNpZmRlZiBIQUxfQ1JZUF9NT0RVTEVfRU5BQkxFRAoKLyogUHJpdmF0ZSB0eXBlZGVmIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KLyogUHJpdmF0ZSBkZWZpbmUgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KLyoqIEBhZGR0b2dyb3VwIENSWVBFeF9Qcml2YXRlX0RlZmluZXMKICAqIEB7CiAgKi8KCiNkZWZpbmUgQ1JZUF9QSEFTRV9JTklUICAgICAgICAgICAgICAgICAweDAwMDAwMDAwVQojZGVmaW5lIENSWVBfUEhBU0VfSEVBREVSICAgICAgICAgICAgICAgQ1JZUF9DUl9HQ01fQ0NNUEhfMAojZGVmaW5lIENSWVBfUEhBU0VfUEFZTE9BRCAgICAgICAgICAgICAgQ1JZUF9DUl9HQ01fQ0NNUEhfMQojZGVmaW5lIENSWVBfUEhBU0VfRklOQUwgICAgICAgICAgICAgICAgQ1JZUF9DUl9HQ01fQ0NNUEgKCiNkZWZpbmUgQ1JZUF9PUEVSQVRJTkdNT0RFX0VOQ1JZUFQgICAgICAweDAwMDAwMDAwVQojZGVmaW5lIENSWVBfT1BFUkFUSU5HTU9ERV9ERUNSWVBUICAgICAgQ1JZUF9DUl9BTEdPRElSCgojZGVmaW5lICBDUllQRXhfUEhBU0VfUFJPQ0VTUyAgICAgICAweDAyVSAgICAgLyohPCBDUllQIHBlcmlwaGVyYWwgaXMgaW4gcHJvY2Vzc2luZyBwaGFzZSAqLwojZGVmaW5lICBDUllQRXhfUEhBU0VfRklOQUwgICAgICAgICAweDAzVSAgICAgLyohPCBDUllQIHBlcmlwaGVyYWwgaXMgaW4gZmluYWwgcGhhc2UgdGhpcyBpcyByZWxldmFudCBvbmx5IHdpdGggQ0NNIGFuZCBHQ00gbW9kZXMgKi8KCi8qICBDVFIwIGluZm9ybWF0aW9uIHRvIHVzZSBpbiBDQ00gYWxnb3JpdGhtICovCiNkZWZpbmUgQ1JZUF9DQ01fQ1RSMF8wICAgICAgICAgICAgMHgwN0ZGRkZGRlUKI2RlZmluZSBDUllQX0NDTV9DVFIwXzMgICAgICAgICAgICAweEZGRkZGRjAwVQoKLyoqCiAgKiBAfQogICovCgovKiBQcml2YXRlIG1hY3JvIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIHZhcmlhYmxlcyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiBQcml2YXRlIGZ1bmN0aW9uIHByb3RvdHlwZXMgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwoKCgovKiBFeHBvcnRlZCBmdW5jdGlvbnMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwovKiogQGFkZHRvZ3JvdXAgQ1JZUEV4X0V4cG9ydGVkX0Z1bmN0aW9ucwogICogQHsKICAqLwoKLyoqIEBkZWZncm91cCBDUllQRXhfRXhwb3J0ZWRfRnVuY3Rpb25zX0dyb3VwMSBFeHRlbmRlZCBBRVMgcHJvY2Vzc2luZyBmdW5jdGlvbnMKICAqICBAYnJpZWYgICAgQ1JZUEV4IEV4dGVuZGVkIHByb2Nlc3NpbmcgZnVuY3Rpb25zLgogICoKQHZlcmJhdGltCiAgPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiAgICAgICAgICAgICAgIyMjIyMgRXh0ZW5kZWQgQUVTIHByb2Nlc3NpbmcgZnVuY3Rpb25zICMjIyMjCiAgPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CiAgICBbLi5dICBUaGlzIHNlY3Rpb24gcHJvdmlkZXMgZnVuY3Rpb25zIGFsbG93aW5nIHRvIGdlbmVyYXRlIHRoZSBhdXRoZW50aWNhdGlvbgogICAgICAgICAgVEFHIGluIFBvbGxpbmcgbW9kZQogICAgICAoKylIQUxfQ1JZUEV4X0FFU0dDTV9HZW5lcmF0ZUF1dGhUQUcKICAgICAgKCspSEFMX0NSWVBFeF9BRVNDQ01fR2VuZXJhdGVBdXRoVEFHCiAgICAgICAgIHRoZXkgc2hvdWxkIGJlIHVzZWQgYWZ0ZXIgRW5jcnlwdC9EZWNyeXB0IG9wZXJhdGlvbi4KCkBlbmR2ZXJiYXRpbQogICogQHsKICAqLwoKCi8qKgogICogQGJyaWVmICBnZW5lcmF0ZSB0aGUgR0NNIGF1dGhlbnRpY2F0aW9uIFRBRy4KICAqIEBwYXJhbSAgaGNyeXA6IHBvaW50ZXIgdG8gYSBDUllQX0hhbmRsZVR5cGVEZWYgc3RydWN0dXJlIHRoYXQgY29udGFpbnMKICAqICAgICAgICAgdGhlIGNvbmZpZ3VyYXRpb24gaW5mb3JtYXRpb24gZm9yIENSWVAgbW9kdWxlCiAgKiBAcGFyYW0gIEF1dGhUYWc6IFBvaW50ZXIgdG8gdGhlIGF1dGhlbnRpY2F0aW9uIGJ1ZmZlcgogICogQHBhcmFtICBUaW1lb3V0OiBUaW1lb3V0IGR1cmF0aW9uCiAgKiBAcmV0dmFsIEhBTCBzdGF0dXMKICAqLwpIQUxfU3RhdHVzVHlwZURlZiBIQUxfQ1JZUEV4X0FFU0dDTV9HZW5lcmF0ZUF1dGhUQUcoQ1JZUF9IYW5kbGVUeXBlRGVmICpoY3J5cCwgdWludDMyX3QgKkF1dGhUYWcsIHVpbnQzMl90IFRpbWVvdXQpCnsKICB1aW50MzJfdCB0aWNrc3RhcnQ7CiAgdWludDY0X3QgaGVhZGVybGVuZ3RoID0gKHVpbnQ2NF90KShoY3J5cC0+SW5pdC5IZWFkZXJTaXplKSAqIDMyVTsgLyogSGVhZGVyIGxlbmd0aCBpbiBiaXRzICovCiAgdWludDY0X3QgaW5wdXRsZW5ndGggPSAodWludDY0X3QpaGNyeXAtPlNpemVzU3VtICogOFU7IC8qIGlucHV0IGxlbmd0aCBpbiBiaXRzICovCiAgdWludDMyX3QgdGFnYWRkciA9ICh1aW50MzJfdClBdXRoVGFnOwoKICBpZiAoaGNyeXAtPlN0YXRlID09IEhBTF9DUllQX1NUQVRFX1JFQURZKQogIHsKICAgIC8qIFByb2Nlc3MgbG9ja2VkICovCiAgICBfX0hBTF9MT0NLKGhjcnlwKTsKCiAgICAvKiBDaGFuZ2UgdGhlIENSWVAgcGVyaXBoZXJhbCBzdGF0ZSAqLwogICAgaGNyeXAtPlN0YXRlID0gSEFMX0NSWVBfU1RBVEVfQlVTWTsKCiAgICAvKiBDaGVjayBpZiBpbml0aWFsaXphdGlvbiBwaGFzZSBoYXMgYWxyZWFkeSBiZWVuIHBlcmZvcm1lZCAqLwogICAgaWYgKGhjcnlwLT5QaGFzZSA9PSBDUllQRXhfUEhBU0VfUFJPQ0VTUykKICAgIHsKICAgICAgLyogQ2hhbmdlIHRoZSBDUllQIHBoYXNlICovCiAgICAgIGhjcnlwLT5QaGFzZSA9IENSWVBFeF9QSEFTRV9GSU5BTDsKICAgIH0KICAgIGVsc2UgLyogSW5pdGlhbGl6YXRpb24gcGhhc2UgaGFzIG5vdCBiZWVuIHBlcmZvcm1lZCovCiAgICB7CiAgICAgIC8qIERpc2FibGUgdGhlIFBlcmlwaGVyYWwgKi8KICAgICAgX19IQUxfQ1JZUF9ESVNBQkxFKGhjcnlwKTsKCiAgICAgIC8qIFNlcXVlbmNlIGVycm9yIGNvZGUgZmllbGQgKi8KICAgICAgaGNyeXAtPkVycm9yQ29kZSB8PSBIQUxfQ1JZUF9FUlJPUl9BVVRIX1RBR19TRVFVRU5DRTsKCiAgICAgIC8qIENoYW5nZSB0aGUgQ1JZUCBwZXJpcGhlcmFsIHN0YXRlICovCiAgICAgIGhjcnlwLT5TdGF0ZSA9IEhBTF9DUllQX1NUQVRFX1JFQURZOwoKICAgICAgLyogUHJvY2VzcyB1bmxvY2tlZCAqLwogICAgICBfX0hBTF9VTkxPQ0soaGNyeXApOwogICAgICByZXR1cm4gSEFMX0VSUk9SOwogICAgfQoKICAgIC8qIERpc2FibGUgQ1JZUCB0byBzdGFydCB0aGUgZmluYWwgcGhhc2UgKi8KICAgIF9fSEFMX0NSWVBfRElTQUJMRShoY3J5cCk7CgogICAgLyogU2VsZWN0IGZpbmFsIHBoYXNlICovCiAgICBNT0RJRllfUkVHKGhjcnlwLT5JbnN0YW5jZS0+Q1IsIENSWVBfQ1JfR0NNX0NDTVBILCBDUllQX1BIQVNFX0ZJTkFMKTsKCiAgICAvKkFMR09ESVIgYml0IG11c3QgYmUgc2V0IHRvIJEwki4qLwogICAgaGNyeXAtPkluc3RhbmNlLT5DUiAmPSAgfkNSWVBfQ1JfQUxHT0RJUjsKCiAgICAvKiBFbmFibGUgdGhlIENSWVAgcGVyaXBoZXJhbCAqLwogICAgX19IQUxfQ1JZUF9FTkFCTEUoaGNyeXApOwoKICAgIC8qIFdyaXRlIHRoZSBudW1iZXIgb2YgYml0cyBpbiBoZWFkZXIgKDY0IGJpdHMpIGZvbGxvd2VkIGJ5IHRoZSBudW1iZXIgb2YgYml0cwogICAgaW4gdGhlIHBheWxvYWQgKi8KI2lmICFkZWZpbmVkIChDUllQX1ZFUl8yXzIpCiAgICAvKiBTVE0zMkg3IHJldi5CIGFuZCBhYm92ZSA6IGRhdGEgaGFzIHRvIGJlIGluc2VydGVkIG5vcm1hbGx5IChubyBzd2FwcGluZykqLwogICAgaWYgKGhjcnlwLT5WZXJzaW9uID49IFJFVl9JRF9CKQojZW5kaWYgLypFbmQgb2Ygbm90IGRlZmluZWQgQ1JZUF9WRVJfMl8yKi8KICAgIHsKICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAwVTsKICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAodWludDMyX3QpKGhlYWRlcmxlbmd0aCk7CiAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gMFU7CiAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gKHVpbnQzMl90KShpbnB1dGxlbmd0aCk7CiAgICB9CiNpZiAhZGVmaW5lZCAoQ1JZUF9WRVJfMl8yKQogICAgZWxzZS8qIGRhdGEgaGFzIHRvIGJlIHN3YXBwZWQgYWNjb3JkaW5nIHRvIHRoZSBEQVRBVFlQRSAqLwogICAgewogICAgICBpZiAoaGNyeXAtPkluaXQuRGF0YVR5cGUgPT0gQ1JZUF9EQVRBVFlQRV8xQikKICAgICAgewogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gMFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JCSVQoKHVpbnQzMl90KShoZWFkZXJsZW5ndGgpKTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IDBVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SQklUKCh1aW50MzJfdCkoaW5wdXRsZW5ndGgpKTsKICAgICAgfQogICAgICBlbHNlIGlmIChoY3J5cC0+SW5pdC5EYXRhVHlwZSA9PSBDUllQX0RBVEFUWVBFXzhCKQogICAgICB7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAwVTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IF9fUkVWKCh1aW50MzJfdCkoaGVhZGVybGVuZ3RoKSk7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAwVTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IF9fUkVWKCh1aW50MzJfdCkoaW5wdXRsZW5ndGgpKTsKICAgICAgfQogICAgICBlbHNlIGlmIChoY3J5cC0+SW5pdC5EYXRhVHlwZSA9PSBDUllQX0RBVEFUWVBFXzE2QikKICAgICAgewogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gMFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JPUigodWludDMyX3QpaGVhZGVybGVuZ3RoLCAxNlUpOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gMFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JPUigodWludDMyX3QpaW5wdXRsZW5ndGgsIDE2VSk7CiAgICAgIH0KICAgICAgZWxzZSBpZiAoaGNyeXAtPkluaXQuRGF0YVR5cGUgPT0gQ1JZUF9EQVRBVFlQRV8zMkIpCiAgICAgIHsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IDBVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gKHVpbnQzMl90KShoZWFkZXJsZW5ndGgpOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gMFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAodWludDMyX3QpKGlucHV0bGVuZ3RoKTsKICAgICAgfQogICAgICBlbHNlCiAgICAgIHsKICAgICAgICAvKiBOb3RoaW5nIHRvIGRvICovCiAgICAgIH0KICAgIH0KI2VuZGlmIC8qRW5kIG9mIG5vdCBkZWZpbmVkIENSWVBfVkVSXzJfMiovCiAgICAvKiBXYWl0IGZvciBPRk5FIGZsYWcgdG8gYmUgcmFpc2VkICovCiAgICB0aWNrc3RhcnQgPSBIQUxfR2V0VGljaygpOwogICAgd2hpbGUgKEhBTF9JU19CSVRfQ0xSKGhjcnlwLT5JbnN0YW5jZS0+U1IsIENSWVBfRkxBR19PRk5FKSkKICAgIHsKICAgICAgLyogQ2hlY2sgZm9yIHRoZSBUaW1lb3V0ICovCiAgICAgIGlmIChUaW1lb3V0ICE9IEhBTF9NQVhfREVMQVkpCiAgICAgIHsKICAgICAgICBpZiAoKChIQUxfR2V0VGljaygpIC0gdGlja3N0YXJ0KSA+IFRpbWVvdXQpIHx8IChUaW1lb3V0ID09IDBVKSkKICAgICAgICB7CiAgICAgICAgICAvKiBEaXNhYmxlIHRoZSBDUllQIFBlcmlwaGVyYWwgQ2xvY2sgKi8KICAgICAgICAgIF9fSEFMX0NSWVBfRElTQUJMRShoY3J5cCk7CgogICAgICAgICAgLyogQ2hhbmdlIHN0YXRlICovCiAgICAgICAgICBoY3J5cC0+RXJyb3JDb2RlIHw9IEhBTF9DUllQX0VSUk9SX1RJTUVPVVQ7CiAgICAgICAgICBoY3J5cC0+U3RhdGUgPSBIQUxfQ1JZUF9TVEFURV9SRUFEWTsKCiAgICAgICAgICAvKiBQcm9jZXNzIHVubG9ja2VkICovCiAgICAgICAgICBfX0hBTF9VTkxPQ0soaGNyeXApOwogICAgICAgICAgcmV0dXJuIEhBTF9FUlJPUjsKICAgICAgICB9CiAgICAgIH0KICAgIH0KCiAgICAvKiBSZWFkIHRoZSBhdXRoZW50aWNhdGlvbiBUQUcgaW4gdGhlIG91dHB1dCBGSUZPICovCiAgICAqKHVpbnQzMl90ICopKHRhZ2FkZHIpID0gaGNyeXAtPkluc3RhbmNlLT5ET1VUOwogICAgdGFnYWRkciArPSA0VTsKICAgICoodWludDMyX3QgKikodGFnYWRkcikgPSBoY3J5cC0+SW5zdGFuY2UtPkRPVVQ7CiAgICB0YWdhZGRyICs9IDRVOwogICAgKih1aW50MzJfdCAqKSh0YWdhZGRyKSA9IGhjcnlwLT5JbnN0YW5jZS0+RE9VVDsKICAgIHRhZ2FkZHIgKz0gNFU7CiAgICAqKHVpbnQzMl90ICopKHRhZ2FkZHIpID0gaGNyeXAtPkluc3RhbmNlLT5ET1VUOwoKICAgIC8qIERpc2FibGUgdGhlIHBlcmlwaGVyYWwgKi8KICAgIF9fSEFMX0NSWVBfRElTQUJMRShoY3J5cCk7CgogICAgLyogQ2hhbmdlIHRoZSBDUllQIHBlcmlwaGVyYWwgc3RhdGUgKi8KICAgIGhjcnlwLT5TdGF0ZSA9IEhBTF9DUllQX1NUQVRFX1JFQURZOwoKICAgIC8qIFByb2Nlc3MgdW5sb2NrZWQgKi8KICAgIF9fSEFMX1VOTE9DSyhoY3J5cCk7CiAgfQogIGVsc2UKICB7CiAgICAvKiBCdXN5IGVycm9yIGNvZGUgZmllbGQgKi8KICAgIGhjcnlwLT5FcnJvckNvZGUgfD0gSEFMX0NSWVBfRVJST1JfQlVTWTsKICAgIHJldHVybiBIQUxfRVJST1I7CiAgfQogIC8qIFJldHVybiBmdW5jdGlvbiBzdGF0dXMgKi8KICByZXR1cm4gSEFMX09LOwp9CgovKioKICAqIEBicmllZiAgQUVTIENDTSBBdXRoZW50aWNhdGlvbiBUQUcgZ2VuZXJhdGlvbi4KICAqIEBwYXJhbSAgaGNyeXA6IHBvaW50ZXIgdG8gYSBDUllQX0hhbmRsZVR5cGVEZWYgc3RydWN0dXJlIHRoYXQgY29udGFpbnMKICAqICAgICAgICAgdGhlIGNvbmZpZ3VyYXRpb24gaW5mb3JtYXRpb24gZm9yIENSWVAgbW9kdWxlCiAgKiBAcGFyYW0gIEF1dGhUYWc6IFBvaW50ZXIgdG8gdGhlIGF1dGhlbnRpY2F0aW9uIGJ1ZmZlcgogICogQHBhcmFtICBUaW1lb3V0OiBUaW1lb3V0IGR1cmF0aW9uCiAgKiBAcmV0dmFsIEhBTCBzdGF0dXMKICAqLwpIQUxfU3RhdHVzVHlwZURlZiBIQUxfQ1JZUEV4X0FFU0NDTV9HZW5lcmF0ZUF1dGhUQUcoQ1JZUF9IYW5kbGVUeXBlRGVmICpoY3J5cCwgdWludDMyX3QgKkF1dGhUYWcsIHVpbnQzMl90IFRpbWVvdXQpCnsKICB1aW50MzJfdCB0YWdhZGRyID0gKHVpbnQzMl90KUF1dGhUYWc7CiAgdWludDMyX3QgY3RyMCBbNF0gPSB7MH07CiAgdWludDMyX3QgY3RyMGFkZHIgPSAodWludDMyX3QpY3RyMDsKICB1aW50MzJfdCB0aWNrc3RhcnQ7CgogIGlmIChoY3J5cC0+U3RhdGUgPT0gSEFMX0NSWVBfU1RBVEVfUkVBRFkpCiAgewogICAgLyogUHJvY2VzcyBsb2NrZWQgKi8KICAgIF9fSEFMX0xPQ0soaGNyeXApOwoKICAgIC8qIENoYW5nZSB0aGUgQ1JZUCBwZXJpcGhlcmFsIHN0YXRlICovCiAgICBoY3J5cC0+U3RhdGUgPSBIQUxfQ1JZUF9TVEFURV9CVVNZOwoKICAgIC8qIENoZWNrIGlmIGluaXRpYWxpemF0aW9uIHBoYXNlIGhhcyBhbHJlYWR5IGJlZW4gcGVyZm9ybWVkICovCiAgICBpZiAoaGNyeXAtPlBoYXNlID09IENSWVBFeF9QSEFTRV9QUk9DRVNTKQogICAgewogICAgICAvKiBDaGFuZ2UgdGhlIENSWVAgcGhhc2UgKi8KICAgICAgaGNyeXAtPlBoYXNlID0gQ1JZUEV4X1BIQVNFX0ZJTkFMOwogICAgfQogICAgZWxzZSAvKiBJbml0aWFsaXphdGlvbiBwaGFzZSBoYXMgbm90IGJlZW4gcGVyZm9ybWVkKi8KICAgIHsKICAgICAgLyogRGlzYWJsZSB0aGUgcGVyaXBoZXJhbCAqLwogICAgICBfX0hBTF9DUllQX0RJU0FCTEUoaGNyeXApOwoKICAgICAgLyogU2VxdWVuY2UgZXJyb3IgY29kZSBmaWVsZCAqLwogICAgICBoY3J5cC0+RXJyb3JDb2RlIHw9IEhBTF9DUllQX0VSUk9SX0FVVEhfVEFHX1NFUVVFTkNFOwoKICAgICAgLyogQ2hhbmdlIHRoZSBDUllQIHBlcmlwaGVyYWwgc3RhdGUgKi8KICAgICAgaGNyeXAtPlN0YXRlID0gSEFMX0NSWVBfU1RBVEVfUkVBRFk7CgogICAgICAvKiBQcm9jZXNzIHVubG9ja2VkICovCiAgICAgIF9fSEFMX1VOTE9DSyhoY3J5cCk7CiAgICAgIHJldHVybiBIQUxfRVJST1I7CiAgICB9CgogICAgLyogRGlzYWJsZSBDUllQIHRvIHN0YXJ0IHRoZSBmaW5hbCBwaGFzZSAqLwogICAgX19IQUxfQ1JZUF9ESVNBQkxFKGhjcnlwKTsKCiAgICAvKiBTZWxlY3QgZmluYWwgcGhhc2UgJiBBTEdPRElSIGJpdCBtdXN0IGJlIHNldCB0byCRMJIuICovCiAgICBNT0RJRllfUkVHKGhjcnlwLT5JbnN0YW5jZS0+Q1IsIENSWVBfQ1JfR0NNX0NDTVBIIHwgQ1JZUF9DUl9BTEdPRElSLCBDUllQX1BIQVNFX0ZJTkFMIHwgQ1JZUF9PUEVSQVRJTkdNT0RFX0VOQ1JZUFQpOwoKICAgIC8qIEVuYWJsZSB0aGUgQ1JZUCBwZXJpcGhlcmFsICovCiAgICBfX0hBTF9DUllQX0VOQUJMRShoY3J5cCk7CgogICAgLyogV3JpdGUgdGhlIGNvdW50ZXIgYmxvY2sgaW4gdGhlIElOIEZJRk8sIENUUjAgaW5mb3JtYXRpb24gZnJvbSBCMAogICAgZGF0YSBoYXMgdG8gYmUgc3dhcHBlZCBhY2NvcmRpbmcgdG8gdGhlIERBVEFUWVBFKi8KICAgIGN0cjBbMF0gPSAoaGNyeXAtPkluaXQuQjBbMF0pICYgQ1JZUF9DQ01fQ1RSMF8wOwogICAgY3RyMFsxXSA9IGhjcnlwLT5Jbml0LkIwWzFdOwogICAgY3RyMFsyXSA9IGhjcnlwLT5Jbml0LkIwWzJdOwogICAgY3RyMFszXSA9IGhjcnlwLT5Jbml0LkIwWzNdICYgIENSWVBfQ0NNX0NUUjBfMzsKCiNpZiAhZGVmaW5lZCAoQ1JZUF9WRVJfMl8yKQogICAgLypTVE0zMkg3IHJldi5CIGFuZCBhYm92ZSA6IGRhdGEgaGFzIHRvIGJlIGluc2VydGVkIG5vcm1hbGx5IChubyBzd2FwcGluZykqLwogICAgaWYgKGhjcnlwLT5WZXJzaW9uID49IFJFVl9JRF9CKQojZW5kaWYgLypFbmQgb2Ygbm90IGRlZmluZWQgQ1JZUF9WRVJfMl8yKi8KICAgIHsKICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAqKHVpbnQzMl90ICopKGN0cjBhZGRyKTsKICAgICAgY3RyMGFkZHIgKz0gNFU7CiAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gKih1aW50MzJfdCAqKShjdHIwYWRkcik7CiAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9ICoodWludDMyX3QgKikoY3RyMGFkZHIpOwogICAgICBjdHIwYWRkciArPSA0VTsKICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAqKHVpbnQzMl90ICopKGN0cjBhZGRyKTsKICAgIH0KI2lmICFkZWZpbmVkIChDUllQX1ZFUl8yXzIpCiAgICBlbHNlIC8qIGRhdGEgaGFzIHRvIGJlIHN3YXBwZWQgYWNjb3JkaW5nIHRvIHRoZSBEQVRBVFlQRSAqLwogICAgewogICAgICBpZiAoaGNyeXAtPkluaXQuRGF0YVR5cGUgPT0gQ1JZUF9EQVRBVFlQRV84QikKICAgICAgewogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SRVYoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SRVYoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SRVYoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SRVYoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICB9CiAgICAgIGVsc2UgaWYgKGhjcnlwLT5Jbml0LkRhdGFUeXBlID09IENSWVBfREFUQVRZUEVfMTZCKQogICAgICB7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JPUigqKHVpbnQzMl90ICopKGN0cjBhZGRyKSwgMTZVKTsKICAgICAgICBjdHIwYWRkciArPSA0VTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IF9fUk9SKCoodWludDMyX3QgKikoY3RyMGFkZHIpLCAxNlUpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19ST1IoKih1aW50MzJfdCAqKShjdHIwYWRkciksIDE2VSk7CiAgICAgICAgY3RyMGFkZHIgKz0gNFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JPUigqKHVpbnQzMl90ICopKGN0cjBhZGRyKSwgMTZVKTsKICAgICAgfQogICAgICBlbHNlIGlmIChoY3J5cC0+SW5pdC5EYXRhVHlwZSA9PSBDUllQX0RBVEFUWVBFXzFCKQogICAgICB7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JCSVQoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gX19SQklUKCoodWludDMyX3QgKikoY3RyMGFkZHIpKTsKICAgICAgICBjdHIwYWRkciArPSA0VTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9IF9fUkJJVCgqKHVpbnQzMl90ICopKGN0cjBhZGRyKSk7CiAgICAgICAgY3RyMGFkZHIgKz0gNFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSBfX1JCSVQoKih1aW50MzJfdCAqKShjdHIwYWRkcikpOwogICAgICB9CiAgICAgIGVsc2UKICAgICAgewogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gKih1aW50MzJfdCAqKShjdHIwYWRkcik7CiAgICAgICAgY3RyMGFkZHIgKz0gNFU7CiAgICAgICAgaGNyeXAtPkluc3RhbmNlLT5ESU4gPSAqKHVpbnQzMl90ICopKGN0cjBhZGRyKTsKICAgICAgICBjdHIwYWRkciArPSA0VTsKICAgICAgICBoY3J5cC0+SW5zdGFuY2UtPkRJTiA9ICoodWludDMyX3QgKikoY3RyMGFkZHIpOwogICAgICAgIGN0cjBhZGRyICs9IDRVOwogICAgICAgIGhjcnlwLT5JbnN0YW5jZS0+RElOID0gKih1aW50MzJfdCAqKShjdHIwYWRkcik7CiAgICAgIH0KICAgIH0KI2VuZGlmIC8qRW5kIG9mIG5vdCBkZWZpbmVkIENSWVBfVkVSXzJfMiovCiAgICAvKiBXYWl0IGZvciBPRk5FIGZsYWcgdG8gYmUgcmFpc2VkICovCiAgICB0aWNrc3RhcnQgPSBIQUxfR2V0VGljaygpOwogICAgd2hpbGUgKEhBTF9JU19CSVRfQ0xSKGhjcnlwLT5JbnN0YW5jZS0+U1IsIENSWVBfRkxBR19PRk5FKSkKICAgIHsKICAgICAgLyogQ2hlY2sgZm9yIHRoZSBUaW1lb3V0ICovCiAgICAgIGlmIChUaW1lb3V0ICE9IEhBTF9NQVhfREVMQVkpCiAgICAgIHsKICAgICAgICBpZiAoKChIQUxfR2V0VGljaygpIC0gdGlja3N0YXJ0KSA+IFRpbWVvdXQpIHx8IChUaW1lb3V0ID09IDBVKSkKICAgICAgICB7CiAgICAgICAgICAvKiBEaXNhYmxlIHRoZSBDUllQIHBlcmlwaGVyYWwgQ2xvY2sgKi8KICAgICAgICAgIF9fSEFMX0NSWVBfRElTQUJMRShoY3J5cCk7CgogICAgICAgICAgLyogQ2hhbmdlIHN0YXRlICovCiAgICAgICAgICBoY3J5cC0+RXJyb3JDb2RlIHw9IEhBTF9DUllQX0VSUk9SX1RJTUVPVVQ7CiAgICAgICAgICBoY3J5cC0+U3RhdGUgPSBIQUxfQ1JZUF9TVEFURV9SRUFEWTsKCiAgICAgICAgICAvKiBQcm9jZXNzIHVubG9ja2VkICovCiAgICAgICAgICBfX0hBTF9VTkxPQ0soaGNyeXApOwogICAgICAgICAgcmV0dXJuIEhBTF9FUlJPUjsKICAgICAgICB9CiAgICAgIH0KICAgIH0KCiAgICAvKiBSZWFkIHRoZSBBdXRoIFRBRyBpbiB0aGUgSU4gRklGTyAqLwogICAgKih1aW50MzJfdCAqKSh0YWdhZGRyKSA9IGhjcnlwLT5JbnN0YW5jZS0+RE9VVDsKICAgIHRhZ2FkZHIgKz0gNFU7CiAgICAqKHVpbnQzMl90ICopKHRhZ2FkZHIpID0gaGNyeXAtPkluc3RhbmNlLT5ET1VUOwogICAgdGFnYWRkciArPSA0VTsKICAgICoodWludDMyX3QgKikodGFnYWRkcikgPSBoY3J5cC0+SW5zdGFuY2UtPkRPVVQ7CiAgICB0YWdhZGRyICs9IDRVOwogICAgKih1aW50MzJfdCAqKSh0YWdhZGRyKSA9IGhjcnlwLT5JbnN0YW5jZS0+RE9VVDsKCiAgICAvKiBDaGFuZ2UgdGhlIENSWVAgcGVyaXBoZXJhbCBzdGF0ZSAqLwogICAgaGNyeXAtPlN0YXRlID0gSEFMX0NSWVBfU1RBVEVfUkVBRFk7CgogICAgLyogUHJvY2VzcyB1bmxvY2tlZCAqLwogICAgX19IQUxfVU5MT0NLKGhjcnlwKTsKCiAgICAvKiBEaXNhYmxlIENSWVAgICovCiAgICBfX0hBTF9DUllQX0RJU0FCTEUoaGNyeXApOwogIH0KICBlbHNlCiAgewogICAgLyogQnVzeSBlcnJvciBjb2RlIGZpZWxkICovCiAgICBoY3J5cC0+RXJyb3JDb2RlID0gSEFMX0NSWVBfRVJST1JfQlVTWTsKICAgIHJldHVybiBIQUxfRVJST1I7CiAgfQogIC8qIFJldHVybiBmdW5jdGlvbiBzdGF0dXMgKi8KICByZXR1cm4gSEFMX09LOwp9CgovKioKICAqIEB9CiAgKi8KCgojZW5kaWYgLyogSEFMX0NSWVBfTU9EVUxFX0VOQUJMRUQgKi8KCi8qKgogICogQH0KICAqLwojZW5kaWYgLyogQ1JZUCAqLwovKioKICAqIEB9CiAgKi8KCi8qKgogICogQH0KICAqLwovKioqKioqKioqKioqKioqKioqKioqKioqIChDKSBDT1BZUklHSFQgU1RNaWNyb2VsZWN0cm9uaWNzICoqKioqRU5EIE9GIEZJTEUqKioqLwo=