ZGlmZiAtLWdpdCBhL3Bob3RhcmstYXBwZW5naW5lLXdlYmFwcC93YXIvTUVUQS1JTkYvTElDRU5TRSBiL3Bob3RhcmstYXBwZW5naW5lLXdlYmFwcC93YXIvTUVUQS1JTkYvTElDRU5TRQpuZXcgZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwLi40NTE4ODBhCi0tLSAvZGV2L251bGwKKysrIGIvcGhvdGFyay1hcHBlbmdpbmUtd2ViYXBwL3dhci9NRVRBLUlORi9MSUNFTlNFCkBAIC0wLDAgKzEsOTQ5IEBACisKKyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFwYWNoZSBMaWNlbnNlCisgICAgICAgICAgICAgICAgICAgICAgICAgICBWZXJzaW9uIDIuMCwgSmFudWFyeSAyMDA0CisgICAgICAgICAgICAgICAgICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvCisKKyAgIFRFUk1TIEFORCBDT05ESVRJT05TIEZPUiBVU0UsIFJFUFJPRFVDVElPTiwgQU5EIERJU1RSSUJVVElPTgorCisgICAxLiBEZWZpbml0aW9ucy4KKworICAgICAgIkxpY2Vuc2UiIHNoYWxsIG1lYW4gdGhlIHRlcm1zIGFuZCBjb25kaXRpb25zIGZvciB1c2UsIHJlcHJvZHVjdGlvbiwKKyAgICAgIGFuZCBkaXN0cmlidXRpb24gYXMgZGVmaW5lZCBieSBTZWN0aW9ucyAxIHRocm91Z2ggOSBvZiB0aGlzIGRvY3VtZW50LgorCisgICAgICAiTGljZW5zb3IiIHNoYWxsIG1lYW4gdGhlIGNvcHlyaWdodCBvd25lciBvciBlbnRpdHkgYXV0aG9yaXplZCBieQorICAgICAgdGhlIGNvcHlyaWdodCBvd25lciB0aGF0IGlzIGdyYW50aW5nIHRoZSBMaWNlbnNlLgorCisgICAgICAiTGVnYWwgRW50aXR5IiBzaGFsbCBtZWFuIHRoZSB1bmlvbiBvZiB0aGUgYWN0aW5nIGVudGl0eSBhbmQgYWxsCisgICAgICBvdGhlciBlbnRpdGllcyB0aGF0IGNvbnRyb2wsIGFyZSBjb250cm9sbGVkIGJ5LCBvciBhcmUgdW5kZXIgY29tbW9uCisgICAgICBjb250cm9sIHdpdGggdGhhdCBlbnRpdHkuIEZvciB0aGUgcHVycG9zZXMgb2YgdGhpcyBkZWZpbml0aW9uLAorICAgICAgImNvbnRyb2wiIG1lYW5zIChpKSB0aGUgcG93ZXIsIGRpcmVjdCBvciBpbmRpcmVjdCwgdG8gY2F1c2UgdGhlCisgICAgICBkaXJlY3Rpb24gb3IgbWFuYWdlbWVudCBvZiBzdWNoIGVudGl0eSwgd2hldGhlciBieSBjb250cmFjdCBvcgorICAgICAgb3RoZXJ3aXNlLCBvciAoaWkpIG93bmVyc2hpcCBvZiBmaWZ0eSBwZXJjZW50ICg1MCUpIG9yIG1vcmUgb2YgdGhlCisgICAgICBvdXRzdGFuZGluZyBzaGFyZXMsIG9yIChpaWkpIGJlbmVmaWNpYWwgb3duZXJzaGlwIG9mIHN1Y2ggZW50aXR5LgorCisgICAgICAiWW91IiAob3IgIllvdXIiKSBzaGFsbCBtZWFuIGFuIGluZGl2aWR1YWwgb3IgTGVnYWwgRW50aXR5CisgICAgICBleGVyY2lzaW5nIHBlcm1pc3Npb25zIGdyYW50ZWQgYnkgdGhpcyBMaWNlbnNlLgorCisgICAgICAiU291cmNlIiBmb3JtIHNoYWxsIG1lYW4gdGhlIHByZWZlcnJlZCBmb3JtIGZvciBtYWtpbmcgbW9kaWZpY2F0aW9ucywKKyAgICAgIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gc29mdHdhcmUgc291cmNlIGNvZGUsIGRvY3VtZW50YXRpb24KKyAgICAgIHNvdXJjZSwgYW5kIGNvbmZpZ3VyYXRpb24gZmlsZXMuCisKKyAgICAgICJPYmplY3QiIGZvcm0gc2hhbGwgbWVhbiBhbnkgZm9ybSByZXN1bHRpbmcgZnJvbSBtZWNoYW5pY2FsCisgICAgICB0cmFuc2Zvcm1hdGlvbiBvciB0cmFuc2xhdGlvbiBvZiBhIFNvdXJjZSBmb3JtLCBpbmNsdWRpbmcgYnV0CisgICAgICBub3QgbGltaXRlZCB0byBjb21waWxlZCBvYmplY3QgY29kZSwgZ2VuZXJhdGVkIGRvY3VtZW50YXRpb24sCisgICAgICBhbmQgY29udmVyc2lvbnMgdG8gb3RoZXIgbWVkaWEgdHlwZXMuCisKKyAgICAgICJXb3JrIiBzaGFsbCBtZWFuIHRoZSB3b3JrIG9mIGF1dGhvcnNoaXAsIHdoZXRoZXIgaW4gU291cmNlIG9yCisgICAgICBPYmplY3QgZm9ybSwgbWFkZSBhdmFpbGFibGUgdW5kZXIgdGhlIExpY2Vuc2UsIGFzIGluZGljYXRlZCBieSBhCisgICAgICBjb3B5cmlnaHQgbm90aWNlIHRoYXQgaXMgaW5jbHVkZWQgaW4gb3IgYXR0YWNoZWQgdG8gdGhlIHdvcmsKKyAgICAgIChhbiBleGFtcGxlIGlzIHByb3ZpZGVkIGluIHRoZSBBcHBlbmRpeCBiZWxvdykuCisKKyAgICAgICJEZXJpdmF0aXZlIFdvcmtzIiBzaGFsbCBtZWFuIGFueSB3b3JrLCB3aGV0aGVyIGluIFNvdXJjZSBvciBPYmplY3QKKyAgICAgIGZvcm0sIHRoYXQgaXMgYmFzZWQgb24gKG9yIGRlcml2ZWQgZnJvbSkgdGhlIFdvcmsgYW5kIGZvciB3aGljaCB0aGUKKyAgICAgIGVkaXRvcmlhbCByZXZpc2lvbnMsIGFubm90YXRpb25zLCBlbGFib3JhdGlvbnMsIG9yIG90aGVyIG1vZGlmaWNhdGlvbnMKKyAgICAgIHJlcHJlc2VudCwgYXMgYSB3aG9sZSwgYW4gb3JpZ2luYWwgd29yayBvZiBhdXRob3JzaGlwLiBGb3IgdGhlIHB1cnBvc2VzCisgICAgICBvZiB0aGlzIExpY2Vuc2UsIERlcml2YXRpdmUgV29ya3Mgc2hhbGwgbm90IGluY2x1ZGUgd29ya3MgdGhhdCByZW1haW4KKyAgICAgIHNlcGFyYWJsZSBmcm9tLCBvciBtZXJlbHkgbGluayAob3IgYmluZCBieSBuYW1lKSB0byB0aGUgaW50ZXJmYWNlcyBvZiwKKyAgICAgIHRoZSBXb3JrIGFuZCBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YuCisKKyAgICAgICJDb250cmlidXRpb24iIHNoYWxsIG1lYW4gYW55IHdvcmsgb2YgYXV0aG9yc2hpcCwgaW5jbHVkaW5nCisgICAgICB0aGUgb3JpZ2luYWwgdmVyc2lvbiBvZiB0aGUgV29yayBhbmQgYW55IG1vZGlmaWNhdGlvbnMgb3IgYWRkaXRpb25zCisgICAgICB0byB0aGF0IFdvcmsgb3IgRGVyaXZhdGl2ZSBXb3JrcyB0aGVyZW9mLCB0aGF0IGlzIGludGVudGlvbmFsbHkKKyAgICAgIHN1Ym1pdHRlZCB0byBMaWNlbnNvciBmb3IgaW5jbHVzaW9uIGluIHRoZSBXb3JrIGJ5IHRoZSBjb3B5cmlnaHQgb3duZXIKKyAgICAgIG9yIGJ5IGFuIGluZGl2aWR1YWwgb3IgTGVnYWwgRW50aXR5IGF1dGhvcml6ZWQgdG8gc3VibWl0IG9uIGJlaGFsZiBvZgorICAgICAgdGhlIGNvcHlyaWdodCBvd25lci4gRm9yIHRoZSBwdXJwb3NlcyBvZiB0aGlzIGRlZmluaXRpb24sICJzdWJtaXR0ZWQiCisgICAgICBtZWFucyBhbnkgZm9ybSBvZiBlbGVjdHJvbmljLCB2ZXJiYWwsIG9yIHdyaXR0ZW4gY29tbXVuaWNhdGlvbiBzZW50CisgICAgICB0byB0aGUgTGljZW5zb3Igb3IgaXRzIHJlcHJlc2VudGF0aXZlcywgaW5jbHVkaW5nIGJ1dCBub3QgbGltaXRlZCB0bworICAgICAgY29tbXVuaWNhdGlvbiBvbiBlbGVjdHJvbmljIG1haWxpbmcgbGlzdHMsIHNvdXJjZSBjb2RlIGNvbnRyb2wgc3lzdGVtcywKKyAgICAgIGFuZCBpc3N1ZSB0cmFja2luZyBzeXN0ZW1zIHRoYXQgYXJlIG1hbmFnZWQgYnksIG9yIG9uIGJlaGFsZiBvZiwgdGhlCisgICAgICBMaWNlbnNvciBmb3IgdGhlIHB1cnBvc2Ugb2YgZGlzY3Vzc2luZyBhbmQgaW1wcm92aW5nIHRoZSBXb3JrLCBidXQKKyAgICAgIGV4Y2x1ZGluZyBjb21tdW5pY2F0aW9uIHRoYXQgaXMgY29uc3BpY3VvdXNseSBtYXJrZWQgb3Igb3RoZXJ3aXNlCisgICAgICBkZXNpZ25hdGVkIGluIHdyaXRpbmcgYnkgdGhlIGNvcHlyaWdodCBvd25lciBhcyAiTm90IGEgQ29udHJpYnV0aW9uLiIKKworICAgICAgIkNvbnRyaWJ1dG9yIiBzaGFsbCBtZWFuIExpY2Vuc29yIGFuZCBhbnkgaW5kaXZpZHVhbCBvciBMZWdhbCBFbnRpdHkKKyAgICAgIG9uIGJlaGFsZiBvZiB3aG9tIGEgQ29udHJpYnV0aW9uIGhhcyBiZWVuIHJlY2VpdmVkIGJ5IExpY2Vuc29yIGFuZAorICAgICAgc3Vic2VxdWVudGx5IGluY29ycG9yYXRlZCB3aXRoaW4gdGhlIFdvcmsuCisKKyAgIDIuIEdyYW50IG9mIENvcHlyaWdodCBMaWNlbnNlLiBTdWJqZWN0IHRvIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZgorICAgICAgdGhpcyBMaWNlbnNlLCBlYWNoIENvbnRyaWJ1dG9yIGhlcmVieSBncmFudHMgdG8gWW91IGEgcGVycGV0dWFsLAorICAgICAgd29ybGR3aWRlLCBub24tZXhjbHVzaXZlLCBuby1jaGFyZ2UsIHJveWFsdHktZnJlZSwgaXJyZXZvY2FibGUKKyAgICAgIGNvcHlyaWdodCBsaWNlbnNlIHRvIHJlcHJvZHVjZSwgcHJlcGFyZSBEZXJpdmF0aXZlIFdvcmtzIG9mLAorICAgICAgcHVibGljbHkgZGlzcGxheSwgcHVibGljbHkgcGVyZm9ybSwgc3VibGljZW5zZSwgYW5kIGRpc3RyaWJ1dGUgdGhlCisgICAgICBXb3JrIGFuZCBzdWNoIERlcml2YXRpdmUgV29ya3MgaW4gU291cmNlIG9yIE9iamVjdCBmb3JtLgorCisgICAzLiBHcmFudCBvZiBQYXRlbnQgTGljZW5zZS4gU3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YKKyAgICAgIHRoaXMgTGljZW5zZSwgZWFjaCBDb250cmlidXRvciBoZXJlYnkgZ3JhbnRzIHRvIFlvdSBhIHBlcnBldHVhbCwKKyAgICAgIHdvcmxkd2lkZSwgbm9uLWV4Y2x1c2l2ZSwgbm8tY2hhcmdlLCByb3lhbHR5LWZyZWUsIGlycmV2b2NhYmxlCisgICAgICAoZXhjZXB0IGFzIHN0YXRlZCBpbiB0aGlzIHNlY3Rpb24pIHBhdGVudCBsaWNlbnNlIHRvIG1ha2UsIGhhdmUgbWFkZSwKKyAgICAgIHVzZSwgb2ZmZXIgdG8gc2VsbCwgc2VsbCwgaW1wb3J0LCBhbmQgb3RoZXJ3aXNlIHRyYW5zZmVyIHRoZSBXb3JrLAorICAgICAgd2hlcmUgc3VjaCBsaWNlbnNlIGFwcGxpZXMgb25seSB0byB0aG9zZSBwYXRlbnQgY2xhaW1zIGxpY2Vuc2FibGUKKyAgICAgIGJ5IHN1Y2ggQ29udHJpYnV0b3IgdGhhdCBhcmUgbmVjZXNzYXJpbHkgaW5mcmluZ2VkIGJ5IHRoZWlyCisgICAgICBDb250cmlidXRpb24ocykgYWxvbmUgb3IgYnkgY29tYmluYXRpb24gb2YgdGhlaXIgQ29udHJpYnV0aW9uKHMpCisgICAgICB3aXRoIHRoZSBXb3JrIHRvIHdoaWNoIHN1Y2ggQ29udHJpYnV0aW9uKHMpIHdhcyBzdWJtaXR0ZWQuIElmIFlvdQorICAgICAgaW5zdGl0dXRlIHBhdGVudCBsaXRpZ2F0aW9uIGFnYWluc3QgYW55IGVudGl0eSAoaW5jbHVkaW5nIGEKKyAgICAgIGNyb3NzLWNsYWltIG9yIGNvdW50ZXJjbGFpbSBpbiBhIGxhd3N1aXQpIGFsbGVnaW5nIHRoYXQgdGhlIFdvcmsKKyAgICAgIG9yIGEgQ29udHJpYnV0aW9uIGluY29ycG9yYXRlZCB3aXRoaW4gdGhlIFdvcmsgY29uc3RpdHV0ZXMgZGlyZWN0CisgICAgICBvciBjb250cmlidXRvcnkgcGF0ZW50IGluZnJpbmdlbWVudCwgdGhlbiBhbnkgcGF0ZW50IGxpY2Vuc2VzCisgICAgICBncmFudGVkIHRvIFlvdSB1bmRlciB0aGlzIExpY2Vuc2UgZm9yIHRoYXQgV29yayBzaGFsbCB0ZXJtaW5hdGUKKyAgICAgIGFzIG9mIHRoZSBkYXRlIHN1Y2ggbGl0aWdhdGlvbiBpcyBmaWxlZC4KKworICAgNC4gUmVkaXN0cmlidXRpb24uIFlvdSBtYXkgcmVwcm9kdWNlIGFuZCBkaXN0cmlidXRlIGNvcGllcyBvZiB0aGUKKyAgICAgIFdvcmsgb3IgRGVyaXZhdGl2ZSBXb3JrcyB0aGVyZW9mIGluIGFueSBtZWRpdW0sIHdpdGggb3Igd2l0aG91dAorICAgICAgbW9kaWZpY2F0aW9ucywgYW5kIGluIFNvdXJjZSBvciBPYmplY3QgZm9ybSwgcHJvdmlkZWQgdGhhdCBZb3UKKyAgICAgIG1lZXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOgorCisgICAgICAoYSkgWW91IG11c3QgZ2l2ZSBhbnkgb3RoZXIgcmVjaXBpZW50cyBvZiB0aGUgV29yayBvcgorICAgICAgICAgIERlcml2YXRpdmUgV29ya3MgYSBjb3B5IG9mIHRoaXMgTGljZW5zZTsgYW5kCisKKyAgICAgIChiKSBZb3UgbXVzdCBjYXVzZSBhbnkgbW9kaWZpZWQgZmlsZXMgdG8gY2FycnkgcHJvbWluZW50IG5vdGljZXMKKyAgICAgICAgICBzdGF0aW5nIHRoYXQgWW91IGNoYW5nZWQgdGhlIGZpbGVzOyBhbmQKKworICAgICAgKGMpIFlvdSBtdXN0IHJldGFpbiwgaW4gdGhlIFNvdXJjZSBmb3JtIG9mIGFueSBEZXJpdmF0aXZlIFdvcmtzCisgICAgICAgICAgdGhhdCBZb3UgZGlzdHJpYnV0ZSwgYWxsIGNvcHlyaWdodCwgcGF0ZW50LCB0cmFkZW1hcmssIGFuZAorICAgICAgICAgIGF0dHJpYnV0aW9uIG5vdGljZXMgZnJvbSB0aGUgU291cmNlIGZvcm0gb2YgdGhlIFdvcmssCisgICAgICAgICAgZXhjbHVkaW5nIHRob3NlIG5vdGljZXMgdGhhdCBkbyBub3QgcGVydGFpbiB0byBhbnkgcGFydCBvZgorICAgICAgICAgIHRoZSBEZXJpdmF0aXZlIFdvcmtzOyBhbmQKKworICAgICAgKGQpIElmIHRoZSBXb3JrIGluY2x1ZGVzIGEgIk5PVElDRSIgdGV4dCBmaWxlIGFzIHBhcnQgb2YgaXRzCisgICAgICAgICAgZGlzdHJpYnV0aW9uLCB0aGVuIGFueSBEZXJpdmF0aXZlIFdvcmtzIHRoYXQgWW91IGRpc3RyaWJ1dGUgbXVzdAorICAgICAgICAgIGluY2x1ZGUgYSByZWFkYWJsZSBjb3B5IG9mIHRoZSBhdHRyaWJ1dGlvbiBub3RpY2VzIGNvbnRhaW5lZAorICAgICAgICAgIHdpdGhpbiBzdWNoIE5PVElDRSBmaWxlLCBleGNsdWRpbmcgdGhvc2Ugbm90aWNlcyB0aGF0IGRvIG5vdAorICAgICAgICAgIHBlcnRhaW4gdG8gYW55IHBhcnQgb2YgdGhlIERlcml2YXRpdmUgV29ya3MsIGluIGF0IGxlYXN0IG9uZQorICAgICAgICAgIG9mIHRoZSBmb2xsb3dpbmcgcGxhY2VzOiB3aXRoaW4gYSBOT1RJQ0UgdGV4dCBmaWxlIGRpc3RyaWJ1dGVkCisgICAgICAgICAgYXMgcGFydCBvZiB0aGUgRGVyaXZhdGl2ZSBXb3Jrczsgd2l0aGluIHRoZSBTb3VyY2UgZm9ybSBvcgorICAgICAgICAgIGRvY3VtZW50YXRpb24sIGlmIHByb3ZpZGVkIGFsb25nIHdpdGggdGhlIERlcml2YXRpdmUgV29ya3M7IG9yLAorICAgICAgICAgIHdpdGhpbiBhIGRpc3BsYXkgZ2VuZXJhdGVkIGJ5IHRoZSBEZXJpdmF0aXZlIFdvcmtzLCBpZiBhbmQKKyAgICAgICAgICB3aGVyZXZlciBzdWNoIHRoaXJkLXBhcnR5IG5vdGljZXMgbm9ybWFsbHkgYXBwZWFyLiBUaGUgY29udGVudHMKKyAgICAgICAgICBvZiB0aGUgTk9USUNFIGZpbGUgYXJlIGZvciBpbmZvcm1hdGlvbmFsIHB1cnBvc2VzIG9ubHkgYW5kCisgICAgICAgICAgZG8gbm90IG1vZGlmeSB0aGUgTGljZW5zZS4gWW91IG1heSBhZGQgWW91ciBvd24gYXR0cmlidXRpb24KKyAgICAgICAgICBub3RpY2VzIHdpdGhpbiBEZXJpdmF0aXZlIFdvcmtzIHRoYXQgWW91IGRpc3RyaWJ1dGUsIGFsb25nc2lkZQorICAgICAgICAgIG9yIGFzIGFuIGFkZGVuZHVtIHRvIHRoZSBOT1RJQ0UgdGV4dCBmcm9tIHRoZSBXb3JrLCBwcm92aWRlZAorICAgICAgICAgIHRoYXQgc3VjaCBhZGRpdGlvbmFsIGF0dHJpYnV0aW9uIG5vdGljZXMgY2Fubm90IGJlIGNvbnN0cnVlZAorICAgICAgICAgIGFzIG1vZGlmeWluZyB0aGUgTGljZW5zZS4KKworICAgICAgWW91IG1heSBhZGQgWW91ciBvd24gY29weXJpZ2h0IHN0YXRlbWVudCB0byBZb3VyIG1vZGlmaWNhdGlvbnMgYW5kCisgICAgICBtYXkgcHJvdmlkZSBhZGRpdGlvbmFsIG9yIGRpZmZlcmVudCBsaWNlbnNlIHRlcm1zIGFuZCBjb25kaXRpb25zCisgICAgICBmb3IgdXNlLCByZXByb2R1Y3Rpb24sIG9yIGRpc3RyaWJ1dGlvbiBvZiBZb3VyIG1vZGlmaWNhdGlvbnMsIG9yCisgICAgICBmb3IgYW55IHN1Y2ggRGVyaXZhdGl2ZSBXb3JrcyBhcyBhIHdob2xlLCBwcm92aWRlZCBZb3VyIHVzZSwKKyAgICAgIHJlcHJvZHVjdGlvbiwgYW5kIGRpc3RyaWJ1dGlvbiBvZiB0aGUgV29yayBvdGhlcndpc2UgY29tcGxpZXMgd2l0aAorICAgICAgdGhlIGNvbmRpdGlvbnMgc3RhdGVkIGluIHRoaXMgTGljZW5zZS4KKworICAgNS4gU3VibWlzc2lvbiBvZiBDb250cmlidXRpb25zLiBVbmxlc3MgWW91IGV4cGxpY2l0bHkgc3RhdGUgb3RoZXJ3aXNlLAorICAgICAgYW55IENvbnRyaWJ1dGlvbiBpbnRlbnRpb25hbGx5IHN1Ym1pdHRlZCBmb3IgaW5jbHVzaW9uIGluIHRoZSBXb3JrCisgICAgICBieSBZb3UgdG8gdGhlIExpY2Vuc29yIHNoYWxsIGJlIHVuZGVyIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZgorICAgICAgdGhpcyBMaWNlbnNlLCB3aXRob3V0IGFueSBhZGRpdGlvbmFsIHRlcm1zIG9yIGNvbmRpdGlvbnMuCisgICAgICBOb3R3aXRoc3RhbmRpbmcgdGhlIGFib3ZlLCBub3RoaW5nIGhlcmVpbiBzaGFsbCBzdXBlcnNlZGUgb3IgbW9kaWZ5CisgICAgICB0aGUgdGVybXMgb2YgYW55IHNlcGFyYXRlIGxpY2Vuc2UgYWdyZWVtZW50IHlvdSBtYXkgaGF2ZSBleGVjdXRlZAorICAgICAgd2l0aCBMaWNlbnNvciByZWdhcmRpbmcgc3VjaCBDb250cmlidXRpb25zLgorCisgICA2LiBUcmFkZW1hcmtzLiBUaGlzIExpY2Vuc2UgZG9lcyBub3QgZ3JhbnQgcGVybWlzc2lvbiB0byB1c2UgdGhlIHRyYWRlCisgICAgICBuYW1lcywgdHJhZGVtYXJrcywgc2VydmljZSBtYXJrcywgb3IgcHJvZHVjdCBuYW1lcyBvZiB0aGUgTGljZW5zb3IsCisgICAgICBleGNlcHQgYXMgcmVxdWlyZWQgZm9yIHJlYXNvbmFibGUgYW5kIGN1c3RvbWFyeSB1c2UgaW4gZGVzY3JpYmluZyB0aGUKKyAgICAgIG9yaWdpbiBvZiB0aGUgV29yayBhbmQgcmVwcm9kdWNpbmcgdGhlIGNvbnRlbnQgb2YgdGhlIE5PVElDRSBmaWxlLgorCisgICA3LiBEaXNjbGFpbWVyIG9mIFdhcnJhbnR5LiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IKKyAgICAgIGFncmVlZCB0byBpbiB3cml0aW5nLCBMaWNlbnNvciBwcm92aWRlcyB0aGUgV29yayAoYW5kIGVhY2gKKyAgICAgIENvbnRyaWJ1dG9yIHByb3ZpZGVzIGl0cyBDb250cmlidXRpb25zKSBvbiBhbiAiQVMgSVMiIEJBU0lTLAorICAgICAgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yCisgICAgICBpbXBsaWVkLCBpbmNsdWRpbmcsIHdpdGhvdXQgbGltaXRhdGlvbiwgYW55IHdhcnJhbnRpZXMgb3IgY29uZGl0aW9ucworICAgICAgb2YgVElUTEUsIE5PTi1JTkZSSU5HRU1FTlQsIE1FUkNIQU5UQUJJTElUWSwgb3IgRklUTkVTUyBGT1IgQQorICAgICAgUEFSVElDVUxBUiBQVVJQT1NFLiBZb3UgYXJlIHNvbGVseSByZXNwb25zaWJsZSBmb3IgZGV0ZXJtaW5pbmcgdGhlCisgICAgICBhcHByb3ByaWF0ZW5lc3Mgb2YgdXNpbmcgb3IgcmVkaXN0cmlidXRpbmcgdGhlIFdvcmsgYW5kIGFzc3VtZSBhbnkKKyAgICAgIHJpc2tzIGFzc29jaWF0ZWQgd2l0aCBZb3VyIGV4ZXJjaXNlIG9mIHBlcm1pc3Npb25zIHVuZGVyIHRoaXMgTGljZW5zZS4KKworICAgOC4gTGltaXRhdGlvbiBvZiBMaWFiaWxpdHkuIEluIG5vIGV2ZW50IGFuZCB1bmRlciBubyBsZWdhbCB0aGVvcnksCisgICAgICB3aGV0aGVyIGluIHRvcnQgKGluY2x1ZGluZyBuZWdsaWdlbmNlKSwgY29udHJhY3QsIG9yIG90aGVyd2lzZSwKKyAgICAgIHVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyAoc3VjaCBhcyBkZWxpYmVyYXRlIGFuZCBncm9zc2x5CisgICAgICBuZWdsaWdlbnQgYWN0cykgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNoYWxsIGFueSBDb250cmlidXRvciBiZQorICAgICAgbGlhYmxlIHRvIFlvdSBmb3IgZGFtYWdlcywgaW5jbHVkaW5nIGFueSBkaXJlY3QsIGluZGlyZWN0LCBzcGVjaWFsLAorICAgICAgaW5jaWRlbnRhbCwgb3IgY29uc2VxdWVudGlhbCBkYW1hZ2VzIG9mIGFueSBjaGFyYWN0ZXIgYXJpc2luZyBhcyBhCisgICAgICByZXN1bHQgb2YgdGhpcyBMaWNlbnNlIG9yIG91dCBvZiB0aGUgdXNlIG9yIGluYWJpbGl0eSB0byB1c2UgdGhlCisgICAgICBXb3JrIChpbmNsdWRpbmcgYnV0IG5vdCBsaW1pdGVkIHRvIGRhbWFnZXMgZm9yIGxvc3Mgb2YgZ29vZHdpbGwsCisgICAgICB3b3JrIHN0b3BwYWdlLCBjb21wdXRlciBmYWlsdXJlIG9yIG1hbGZ1bmN0aW9uLCBvciBhbnkgYW5kIGFsbAorICAgICAgb3RoZXIgY29tbWVyY2lhbCBkYW1hZ2VzIG9yIGxvc3NlcyksIGV2ZW4gaWYgc3VjaCBDb250cmlidXRvcgorICAgICAgaGFzIGJlZW4gYWR2aXNlZCBvZiB0aGUgcG9zc2liaWxpdHkgb2Ygc3VjaCBkYW1hZ2VzLgorCisgICA5LiBBY2NlcHRpbmcgV2FycmFudHkgb3IgQWRkaXRpb25hbCBMaWFiaWxpdHkuIFdoaWxlIHJlZGlzdHJpYnV0aW5nCisgICAgICB0aGUgV29yayBvciBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YsIFlvdSBtYXkgY2hvb3NlIHRvIG9mZmVyLAorICAgICAgYW5kIGNoYXJnZSBhIGZlZSBmb3IsIGFjY2VwdGFuY2Ugb2Ygc3VwcG9ydCwgd2FycmFudHksIGluZGVtbml0eSwKKyAgICAgIG9yIG90aGVyIGxpYWJpbGl0eSBvYmxpZ2F0aW9ucyBhbmQvb3IgcmlnaHRzIGNvbnNpc3RlbnQgd2l0aCB0aGlzCisgICAgICBMaWNlbnNlLiBIb3dldmVyLCBpbiBhY2NlcHRpbmcgc3VjaCBvYmxpZ2F0aW9ucywgWW91IG1heSBhY3Qgb25seQorICAgICAgb24gWW91ciBvd24gYmVoYWxmIGFuZCBvbiBZb3VyIHNvbGUgcmVzcG9uc2liaWxpdHksIG5vdCBvbiBiZWhhbGYKKyAgICAgIG9mIGFueSBvdGhlciBDb250cmlidXRvciwgYW5kIG9ubHkgaWYgWW91IGFncmVlIHRvIGluZGVtbmlmeSwKKyAgICAgIGRlZmVuZCwgYW5kIGhvbGQgZWFjaCBDb250cmlidXRvciBoYXJtbGVzcyBmb3IgYW55IGxpYWJpbGl0eQorICAgICAgaW5jdXJyZWQgYnksIG9yIGNsYWltcyBhc3NlcnRlZCBhZ2FpbnN0LCBzdWNoIENvbnRyaWJ1dG9yIGJ5IHJlYXNvbgorICAgICAgb2YgeW91ciBhY2NlcHRpbmcgYW55IHN1Y2ggd2FycmFudHkgb3IgYWRkaXRpb25hbCBsaWFiaWxpdHkuCisKKyAgIEVORCBPRiBURVJNUyBBTkQgQ09ORElUSU9OUworCisgICBBUFBFTkRJWDogSG93IHRvIGFwcGx5IHRoZSBBcGFjaGUgTGljZW5zZSB0byB5b3VyIHdvcmsuCisKKyAgICAgIFRvIGFwcGx5IHRoZSBBcGFjaGUgTGljZW5zZSB0byB5b3VyIHdvcmssIGF0dGFjaCB0aGUgZm9sbG93aW5nCisgICAgICBib2lsZXJwbGF0ZSBub3RpY2UsIHdpdGggdGhlIGZpZWxkcyBlbmNsb3NlZCBieSBicmFja2V0cyAiW10iCisgICAgICByZXBsYWNlZCB3aXRoIHlvdXIgb3duIGlkZW50aWZ5aW5nIGluZm9ybWF0aW9uLiAoRG9uJ3QgaW5jbHVkZQorICAgICAgdGhlIGJyYWNrZXRzISkgIFRoZSB0ZXh0IHNob3VsZCBiZSBlbmNsb3NlZCBpbiB0aGUgYXBwcm9wcmlhdGUKKyAgICAgIGNvbW1lbnQgc3ludGF4IGZvciB0aGUgZmlsZSBmb3JtYXQuIFdlIGFsc28gcmVjb21tZW5kIHRoYXQgYQorICAgICAgZmlsZSBvciBjbGFzcyBuYW1lIGFuZCBkZXNjcmlwdGlvbiBvZiBwdXJwb3NlIGJlIGluY2x1ZGVkIG9uIHRoZQorICAgICAgc2FtZSAicHJpbnRlZCBwYWdlIiBhcyB0aGUgY29weXJpZ2h0IG5vdGljZSBmb3IgZWFzaWVyCisgICAgICBpZGVudGlmaWNhdGlvbiB3aXRoaW4gdGhpcmQtcGFydHkgYXJjaGl2ZXMuCisKKyAgIENvcHlyaWdodCBbeXl5eV0gW25hbWUgb2YgY29weXJpZ2h0IG93bmVyXQorCisgICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgIkxpY2Vuc2UiKTsKKyAgIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS4KKyAgIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdAorCisgICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wCisKKyAgIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmUKKyAgIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICJBUyBJUyIgQkFTSVMsCisgICBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC4KKyAgIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQKKyAgIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLgorCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworQVBBQ0hFIFRVU0NBTlkgU1VCQ09NUE9ORU5UUzogCisKK1RoZSBBcGFjaGUgVHVzY2FueSBiaW5hcnkgZGlzdHJpYnV0aW9uIGluY2x1ZGVzIGEgbnVtYmVyIG9mIHN1YmNvbXBvbmVudHMKK3dpdGggc2VwYXJhdGUgY29weXJpZ2h0IG5vdGljZXMgYW5kIGxpY2Vuc2UgdGVybXMuIFlvdXIgdXNlIG9mIHRoZQorY29kZSBmb3IgdGhlIHRoZXNlIHN1YmNvbXBvbmVudHMgaXMgc3ViamVjdCB0byB0aGUgdGVybXMgYW5kCitjb25kaXRpb25zIG9mIHRoZSBmb2xsb3dpbmcgbGljZW5zZXMuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorVGhlIGZvbGxvd2luZyBjb21wb25lbnRzIGNvbWUgdW5kZXIgQXBhY2hlIFNvZnR3YXJlIExpY2Vuc2UgMi4wCisKKyBjZ2xpYi0yLjIuamFyCisgY29tbW9ucy1jb2RlYy0xLjMuamFyCisgY29tbW9ucy1sb2dnaW5nLTEuMS4xLmphcgorIGdlcm9uaW1vLXN0YXgtYXBpXzEuMF9zcGVjLTEuMC4xLmphcgorIGh0dHBjbGllbnQtNC4wLmphcgorIGh0dHBjb3JlLTQuMC4xLmphcgorIGphYnNvcmItMS4zLjEuamFyCisgamV0dGlzb24tMS4yLmphcgorIG5la29odG1sLTEuOS43LmphcgorIHNhbnNlbGFuLTAuOTctaW5jdWJhdG9yLmphcgorIHR1c2NhbnktYXNzZW1ibHktMi4wLU01LjEuamFyCisgdHVzY2FueS1hc3NlbWJseS14bWwtMi4wLU01LjEuamFyCisgdHVzY2FueS1hc3NlbWJseS14c2QtMi4wLU01LjEuamFyCisgdHVzY2FueS1iaW5kaW5nLWpzb25ycGMtMi4wLU01LjEuamFyCisgdHVzY2FueS1iaW5kaW5nLWpzb25ycGMtcnVudGltZS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWJpbmRpbmctc2NhLXJ1bnRpbWUtMi4wLU01LjEuamFyCisgdHVzY2FueS1idWlsZGVyLTIuMC1NNS4xLmphcgorIHR1c2NhbnktY29tbW9uLWphdmEtMi4wLU01LjEuamFyCisgdHVzY2FueS1jb21tb24teG1sLTIuMC1NNS4xLmphcgorIHR1c2NhbnktY29udHJpYnV0aW9uLTIuMC1NNS4xLmphcgorIHR1c2NhbnktY29yZS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWNvcmUtZGF0YWJpbmRpbmctMi4wLU01LjEuamFyCisgdHVzY2FueS1jb3JlLXNwaS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWRhdGEtYXBpLTIuMC1NNS4xLmphcgorIHR1c2NhbnktZGF0YWJpbmRpbmctMi4wLU01LjEuamFyCisgdHVzY2FueS1kYXRhYmluZGluZy1qYXhiLTIuMC1NNS4xLmphcgorIHR1c2NhbnktZGF0YWJpbmRpbmctanNvbi0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWRlcGxveW1lbnQtMi4wLU01LjEuamFyCisgdHVzY2FueS1leHRlbnNpYmlsaXR5LTIuMC1NNS4xLmphcgorIHR1c2NhbnktaG9zdC1odHRwLTIuMC1NNS4xLmphcgorIHR1c2NhbnktaG9zdC13ZWJhcHAtMi4wLU01LjEuamFyCisgdHVzY2FueS1pbXBsZW1lbnRhdGlvbi1qYXZhLTIuMC1NNS4xLmphcgorIHR1c2NhbnktaW1wbGVtZW50YXRpb24tamF2YS1ydW50aW1lLTIuMC1NNS4xLmphcgorIHR1c2NhbnktaW50ZXJmYWNlLWphdmEtMi4wLU01LjEuamFyCisgdHVzY2FueS1pbnRlcmZhY2UtamF2YS1qYXh3cy0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LW1vbml0b3ItMi4wLU01LjEuamFyCisgdHVzY2FueS1ub2RlLWFwaS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LW5vZGUtaW1wbC0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LXNjYS1hcGktMi4wLU01LjEuamFyCisgdHVzY2FueS14c2QtMi4wLU01LjEuamFyCisgd3N0eC1hc2wtMy4yLjQuamFyCisgWG1sU2NoZW1hLTEuNC4zLmphcgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK0pQeXRob24gMS4xLnggU29mdHdhcmUgTGljZW5zZS4KKz09PT09PT09PT09PT09PT09PT09PT09PT0KKworX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXworCitJTVBPUlRBTlQ6IFBMRUFTRSBSRUFEIFRIRSBGT0xMT1dJTkcgQUdSRUVNRU5UIENBUkVGVUxMWS4KKworQlkgQ0xJQ0tJTkcgT04gVEhFICJBQ0NFUFQiIEJVVFRPTiBXSEVSRSBJTkRJQ0FURUQsIE9SIEJZIElOU1RBTExJTkcsCitDT1BZSU5HIE9SIE9USEVSV0lTRSBVU0lORyBUSEUgU09GVFdBUkUsIFlPVSBBUkUgREVFTUVEIFRPIEhBVkUgQUdSRUVEIFRPCitUSEUgVEVSTVMgQU5EIENPTkRJVElPTlMgT0YgVEhJUyBBR1JFRU1FTlQuCisKK19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KKworSlB5dGhvbiB2ZXJzaW9uIDEuMS54CisKKyAgMS4gVGhpcyBMSUNFTlNFIEFHUkVFTUVOVCBpcyBiZXR3ZWVuIHRoZSBDb3Jwb3JhdGlvbiBmb3IgTmF0aW9uYWwgUmVzZWFyY2gKKyAgICAgSW5pdGlhdGl2ZXMsIGhhdmluZyBhbiBvZmZpY2UgYXQgMTg5NSBQcmVzdG9uIFdoaXRlIERyaXZlLCBSZXN0b24sIFZBCisgICAgIDIwMTkxICgiQ05SSSIpLCBhbmQgdGhlIEluZGl2aWR1YWwgb3IgT3JnYW5pemF0aW9uICgiTGljZW5zZWUiKQorICAgICBhY2Nlc3NpbmcgYW5kIHVzaW5nIEpQeXRob24gdmVyc2lvbiAxLjEueCBpbiBzb3VyY2Ugb3IgYmluYXJ5IGZvcm0gYW5kCisgICAgIGl0cyBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gYXMgcHJvdmlkZWQgaGVyZWluICgiU29mdHdhcmUiKS4KKworICAyLiBTdWJqZWN0IHRvIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0aGlzIExpY2Vuc2UgQWdyZWVtZW50LCBDTlJJCisgICAgIGhlcmVieSBncmFudHMgTGljZW5zZWUgYSBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLCByb3lhbHR5LWZyZWUsCisgICAgIHdvcmxkLXdpZGUgbGljZW5zZSB0byByZXByb2R1Y2UsIGFuYWx5emUsIHRlc3QsIHBlcmZvcm0gYW5kL29yIGRpc3BsYXkKKyAgICAgcHVibGljbHksIHByZXBhcmUgZGVyaXZhdGl2ZSB3b3JrcywgZGlzdHJpYnV0ZSwgYW5kIG90aGVyd2lzZSB1c2UgdGhlCisgICAgIFNvZnR3YXJlIGFsb25lIG9yIGluIGFueSBkZXJpdmF0aXZlIHZlcnNpb24sIHByb3ZpZGVkLCBob3dldmVyLCB0aGF0CisgICAgIENOUkkncyBMaWNlbnNlIEFncmVlbWVudCBhbmQgQ05SSSdzIG5vdGljZSBvZiBjb3B5cmlnaHQsIGkuZS4sCisgICAgICJDb3B5cmlnaHQg77+9MTk5Ni0xOTk5IENvcnBvcmF0aW9uIGZvciBOYXRpb25hbCBSZXNlYXJjaCBJbml0aWF0aXZlczsKKyAgICAgQWxsIFJpZ2h0cyBSZXNlcnZlZCIgYXJlIGJvdGggcmV0YWluZWQgaW4gdGhlIFNvZnR3YXJlLCBhbG9uZSBvciBpbiBhbnkKKyAgICAgZGVyaXZhdGl2ZSB2ZXJzaW9uIHByZXBhcmVkIGJ5IExpY2Vuc2VlLgorCisgICAgIEFsdGVybmF0aXZlbHksIGluIGxpZXUgb2YgQ05SSSdzIExpY2Vuc2UgQWdyZWVtZW50LCBMaWNlbnNlZSBtYXkKKyAgICAgc3Vic3RpdHV0ZSB0aGUgZm9sbG93aW5nIHRleHQgKG9taXR0aW5nIHRoZSBxdW90ZXMpLCBwcm92aWRlZCwgaG93ZXZlciwKKyAgICAgdGhhdCBzdWNoIHRleHQgaXMgZGlzcGxheWVkIHByb21pbmVudGx5IGluIHRoZSBTb2Z0d2FyZSBhbG9uZSBvciBpbiBhbnkKKyAgICAgZGVyaXZhdGl2ZSB2ZXJzaW9uIHByZXBhcmVkIGJ5IExpY2Vuc2VlOiAiSlB5dGhvbiAoVmVyc2lvbiAxLjEueCkgaXMKKyAgICAgbWFkZSBhdmFpbGFibGUgc3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgaW4gQ05SSSdzIExpY2Vuc2UKKyAgICAgQWdyZWVtZW50LiBUaGlzIEFncmVlbWVudCBtYXkgYmUgbG9jYXRlZCBvbiB0aGUgSW50ZXJuZXQgdXNpbmcgdGhlCisgICAgIGZvbGxvd2luZyB1bmlxdWUsIHBlcnNpc3RlbnQgaWRlbnRpZmllciAoa25vd24gYXMgYSBoYW5kbGUpOgorICAgICAxODk1LjIyLzEwMDYuIFRoZSBMaWNlbnNlIG1heSBhbHNvIGJlIG9idGFpbmVkIGZyb20gYSBwcm94eSBzZXJ2ZXIgb24KKyAgICAgdGhlIFdlYiB1c2luZyB0aGUgZm9sbG93aW5nIFVSTDogaHR0cDovL2hkbC5oYW5kbGUubmV0LzE4OTUuMjIvMTAwNi4iCisKKyAgMy4gSW4gdGhlIGV2ZW50IExpY2Vuc2VlIHByZXBhcmVzIGEgZGVyaXZhdGl2ZSB3b3JrIHRoYXQgaXMgYmFzZWQgb24gb3IKKyAgICAgaW5jb3Jwb3JhdGVzIHRoZSBTb2Z0d2FyZSBvciBhbnkgcGFydCB0aGVyZW9mLCBhbmQgd2FudHMgdG8gbWFrZSB0aGUKKyAgICAgZGVyaXZhdGl2ZSB3b3JrIGF2YWlsYWJsZSB0byB0aGUgcHVibGljIGFzIHByb3ZpZGVkIGhlcmVpbiwgdGhlbgorICAgICBMaWNlbnNlZSBoZXJlYnkgYWdyZWVzIHRvIGluZGljYXRlIGluIGFueSBzdWNoIHdvcmssIGluIGEgcHJvbWluZW50bHkKKyAgICAgdmlzaWJsZSB3YXksIHRoZSBuYXR1cmUgb2YgdGhlIG1vZGlmaWNhdGlvbnMgbWFkZSB0byBDTlJJJ3MgU29mdHdhcmUuCisKKyAgNC4gTGljZW5zZWUgbWF5IG5vdCB1c2UgQ05SSSB0cmFkZW1hcmtzIG9yIHRyYWRlIG5hbWUsIGluY2x1ZGluZyBKUHl0aG9uCisgICAgIG9yIENOUkksIGluIGEgdHJhZGVtYXJrIHNlbnNlIHRvIGVuZG9yc2Ugb3IgcHJvbW90ZSBwcm9kdWN0cyBvcgorICAgICBzZXJ2aWNlcyBvZiBMaWNlbnNlZSwgb3IgYW55IHRoaXJkIHBhcnR5LiBMaWNlbnNlZSBtYXkgdXNlIHRoZSBtYXJrCisgICAgIEpQeXRob24gaW4gY29ubmVjdGlvbiB3aXRoIExpY2Vuc2VlJ3MgZGVyaXZhdGl2ZSB2ZXJzaW9ucyB0aGF0IGFyZQorICAgICBiYXNlZCBvbiBvciBpbmNvcnBvcmF0ZSB0aGUgU29mdHdhcmUsIGJ1dCBvbmx5IGluIHRoZSBmb3JtCisgICAgICJKUHl0aG9uLWJhc2VkIF9fX19fX19fX19fX19fX19fX18sIiBvciBlcXVpdmFsZW50LgorCisgIDUuIENOUkkgaXMgbWFraW5nIHRoZSBTb2Z0d2FyZSBhdmFpbGFibGUgdG8gTGljZW5zZWUgb24gYW4gIkFTIElTIiBiYXNpcy4KKyAgICAgQ05SSSBNQUtFUyBOTyBSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRVhQUkVTUyBPUiBJTVBMSUVELiBCWSBXQVkKKyAgICAgT0YgRVhBTVBMRSwgQlVUIE5PVCBMSU1JVEFUSU9OLCBDTlJJIE1BS0VTIE5PIEFORCBESVNDTEFJTVMgQU5ZCisgICAgIFJFUFJFU0VOVEFUSU9OIE9SIFdBUlJBTlRZIE9GIE1FUkNIQU5UQUJJTElUWSBPUiBGSVRORVNTIEZPUiBBTlkKKyAgICAgUEFSVElDVUxBUiBQVVJQT1NFIE9SIFRIQVQgVEhFIFVTRSBPRiBUSEUgU09GVFdBUkUgV0lMTCBOT1QgSU5GUklOR0UKKyAgICAgQU5ZIFRISVJEIFBBUlRZIFJJR0hUUy4KKworICA2LiBDTlJJIFNIQUxMIE5PVCBCRSBMSUFCTEUgVE8gTElDRU5TRUUgT1IgT1RIRVIgVVNFUlMgT0YgVEhFIFNPRlRXQVJFIEZPUgorICAgICBBTlkgSU5DSURFTlRBTCwgU1BFQ0lBTCBPUiBDT05TRVFVRU5USUFMIERBTUFHRVMgT1IgTE9TUyBBUyBBIFJFU1VMVCBPRgorICAgICBVU0lORywgTU9ESUZZSU5HIE9SIERJU1RSSUJVVElORyBUSEUgU09GVFdBUkUsIE9SIEFOWSBERVJJVkFUSVZFCisgICAgIFRIRVJFT0YsIEVWRU4gSUYgQURWSVNFRCBPRiBUSEUgUE9TU0lCSUxJVFkgVEhFUkVPRi4gU09NRSBTVEFURVMgRE8gTk9UCisgICAgIEFMTE9XIFRIRSBMSU1JVEFUSU9OIE9SIEVYQ0xVU0lPTiBPRiBMSUFCSUxJVFkgU08gVEhFIEFCT1ZFIERJU0NMQUlNRVIKKyAgICAgTUFZIE5PVCBBUFBMWSBUTyBMSUNFTlNFRS4KKworICA3LiBUaGlzIExpY2Vuc2UgQWdyZWVtZW50IG1heSBiZSB0ZXJtaW5hdGVkIGJ5IENOUkkgKGkpIGltbWVkaWF0ZWx5IHVwb24KKyAgICAgd3JpdHRlbiBub3RpY2UgZnJvbSBDTlJJIG9mIGFueSBtYXRlcmlhbCBicmVhY2ggYnkgdGhlIExpY2Vuc2VlLCBpZiB0aGUKKyAgICAgbmF0dXJlIG9mIHRoZSBicmVhY2ggaXMgc3VjaCB0aGF0IGl0IGNhbm5vdCBiZSBwcm9tcHRseSByZW1lZGllZDsgb3IKKyAgICAgKGlpKSBzaXh0eSAoNjApIGRheXMgZm9sbG93aW5nIG5vdGljZSBmcm9tIENOUkkgdG8gTGljZW5zZWUgb2YgYQorICAgICBtYXRlcmlhbCByZW1lZGlhYmxlIGJyZWFjaCwgaWYgTGljZW5zZWUgaGFzIG5vdCByZW1lZGllZCBzdWNoIGJyZWFjaAorICAgICB3aXRoaW4gdGhhdCBzaXh0eS1kYXkgcGVyaW9kLgorCisgIDguIFRoaXMgTGljZW5zZSBBZ3JlZW1lbnQgc2hhbGwgYmUgZ292ZXJuZWQgYnkgYW5kIGludGVycHJldGVkIGluIGFsbAorICAgICByZXNwZWN0cyBieSB0aGUgbGF3IG9mIHRoZSBTdGF0ZSBvZiBWaXJnaW5pYSwgZXhjbHVkaW5nIGNvbmZsaWN0IG9mIGxhdworICAgICBwcm92aXNpb25zLiBOb3RoaW5nIGluIHRoaXMgQWdyZWVtZW50IHNoYWxsIGJlIGRlZW1lZCB0byBjcmVhdGUgYW55CisgICAgIHJlbGF0aW9uc2hpcCBvZiBhZ2VuY3ksIHBhcnRuZXJzaGlwLCBvciBqb2ludCB2ZW50dXJlIGJldHdlZW4gQ05SSSBhbmQKKyAgICAgTGljZW5zZWUuCisKKyAgOS4gQnkgY2xpY2tpbmcgb24gdGhlICJBQ0NFUFQiIGJ1dHRvbiB3aGVyZSBpbmRpY2F0ZWQsIG9yIGJ5IGluc3RhbGxpbmcsCisgICAgIGNvcHlpbmcgb3Igb3RoZXJ3aXNlIHVzaW5nIHRoZSBTb2Z0d2FyZSwgTGljZW5zZWUgYWdyZWVzIHRvIGJlIGJvdW5kIGJ5CisgICAgIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0aGlzIExpY2Vuc2UgQWdyZWVtZW50LgorCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworVGhlIGphcnM7IAorYWN0aXZhdGlvbi0xLjEuamFyLCAKK2pheGItYXBpLTIuMS5qYXIsIAoramF4Yi1pbXBsLTIuMS4xMi5qYXIsIAoranNyMTgxLWFwaS0xLjAtTVIxLmphciwgCitqc3IyNTAtYXBpLTEuMC5qYXIsIAoramF4d3MtYXBpLTIuMS5qYXIKKworQ09NTU9OIERFVkVMT1BNRU5UIEFORCBESVNUUklCVVRJT04gTElDRU5TRSAoQ0RETCkgVmVyc2lvbiAxLjAKKworCisgICAgICAxLiBEZWZpbml0aW9ucy4KKworICAgICAgICAgICAgMS4xLiAiQ29udHJpYnV0b3IiIG1lYW5zIGVhY2ggaW5kaXZpZHVhbCBvciBlbnRpdHkgdGhhdAorICAgICAgICAgICAgY3JlYXRlcyBvciBjb250cmlidXRlcyB0byB0aGUgY3JlYXRpb24gb2YgTW9kaWZpY2F0aW9ucy4KKworICAgICAgICAgICAgMS4yLiAiQ29udHJpYnV0b3IgVmVyc2lvbiIgbWVhbnMgdGhlIGNvbWJpbmF0aW9uIG9mIHRoZQorICAgICAgICAgICAgT3JpZ2luYWwgU29mdHdhcmUsIHByaW9yIE1vZGlmaWNhdGlvbnMgdXNlZCBieSBhCisgICAgICAgICAgICBDb250cmlidXRvciAoaWYgYW55KSwgYW5kIHRoZSBNb2RpZmljYXRpb25zIG1hZGUgYnkgdGhhdAorICAgICAgICAgICAgcGFydGljdWxhciBDb250cmlidXRvci4KKworICAgICAgICAgICAgMS4zLiAiQ292ZXJlZCBTb2Z0d2FyZSIgbWVhbnMgKGEpIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSwgb3IKKyAgICAgICAgICAgIChiKSBNb2RpZmljYXRpb25zLCBvciAoYykgdGhlIGNvbWJpbmF0aW9uIG9mIGZpbGVzCisgICAgICAgICAgICBjb250YWluaW5nIE9yaWdpbmFsIFNvZnR3YXJlIHdpdGggZmlsZXMgY29udGFpbmluZworICAgICAgICAgICAgTW9kaWZpY2F0aW9ucywgaW4gZWFjaCBjYXNlIGluY2x1ZGluZyBwb3J0aW9ucyB0aGVyZW9mLgorCisgICAgICAgICAgICAxLjQuICJFeGVjdXRhYmxlIiBtZWFucyB0aGUgQ292ZXJlZCBTb2Z0d2FyZSBpbiBhbnkgZm9ybQorICAgICAgICAgICAgb3RoZXIgdGhhbiBTb3VyY2UgQ29kZS4gCisKKyAgICAgICAgICAgIDEuNS4gIkluaXRpYWwgRGV2ZWxvcGVyIiBtZWFucyB0aGUgaW5kaXZpZHVhbCBvciBlbnRpdHkKKyAgICAgICAgICAgIHRoYXQgZmlyc3QgbWFrZXMgT3JpZ2luYWwgU29mdHdhcmUgYXZhaWxhYmxlIHVuZGVyIHRoaXMKKyAgICAgICAgICAgIExpY2Vuc2UuIAorICAgICAgICAgICAgCisgICAgICAgICAgICAxLjYuICJMYXJnZXIgV29yayIgbWVhbnMgYSB3b3JrIHdoaWNoIGNvbWJpbmVzIENvdmVyZWQKKyAgICAgICAgICAgIFNvZnR3YXJlIG9yIHBvcnRpb25zIHRoZXJlb2Ygd2l0aCBjb2RlIG5vdCBnb3Zlcm5lZCBieSB0aGUKKyAgICAgICAgICAgIHRlcm1zIG9mIHRoaXMgTGljZW5zZS4KKworICAgICAgICAgICAgMS43LiAiTGljZW5zZSIgbWVhbnMgdGhpcyBkb2N1bWVudC4KKworICAgICAgICAgICAgMS44LiAiTGljZW5zYWJsZSIgbWVhbnMgaGF2aW5nIHRoZSByaWdodCB0byBncmFudCwgdG8gdGhlCisgICAgICAgICAgICBtYXhpbXVtIGV4dGVudCBwb3NzaWJsZSwgd2hldGhlciBhdCB0aGUgdGltZSBvZiB0aGUgaW5pdGlhbAorICAgICAgICAgICAgZ3JhbnQgb3Igc3Vic2VxdWVudGx5IGFjcXVpcmVkLCBhbnkgYW5kIGFsbCBvZiB0aGUgcmlnaHRzCisgICAgICAgICAgICBjb252ZXllZCBoZXJlaW4uCisgICAgICAgICAgICAKKyAgICAgICAgICAgIDEuOS4gIk1vZGlmaWNhdGlvbnMiIG1lYW5zIHRoZSBTb3VyY2UgQ29kZSBhbmQgRXhlY3V0YWJsZQorICAgICAgICAgICAgZm9ybSBvZiBhbnkgb2YgdGhlIGZvbGxvd2luZzogCisKKyAgICAgICAgICAgICAgICAgIEEuIEFueSBmaWxlIHRoYXQgcmVzdWx0cyBmcm9tIGFuIGFkZGl0aW9uIHRvLAorICAgICAgICAgICAgICAgICAgZGVsZXRpb24gZnJvbSBvciBtb2RpZmljYXRpb24gb2YgdGhlIGNvbnRlbnRzIG9mIGEKKyAgICAgICAgICAgICAgICAgIGZpbGUgY29udGFpbmluZyBPcmlnaW5hbCBTb2Z0d2FyZSBvciBwcmV2aW91cworICAgICAgICAgICAgICAgICAgTW9kaWZpY2F0aW9uczsgCisKKyAgICAgICAgICAgICAgICAgIEIuIEFueSBuZXcgZmlsZSB0aGF0IGNvbnRhaW5zIGFueSBwYXJ0IG9mIHRoZQorICAgICAgICAgICAgICAgICAgT3JpZ2luYWwgU29mdHdhcmUgb3IgcHJldmlvdXMgTW9kaWZpY2F0aW9uOyBvciAKKworICAgICAgICAgICAgICAgICAgQy4gQW55IG5ldyBmaWxlIHRoYXQgaXMgY29udHJpYnV0ZWQgb3Igb3RoZXJ3aXNlIG1hZGUKKyAgICAgICAgICAgICAgICAgIGF2YWlsYWJsZSB1bmRlciB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlLgorCisgICAgICAgICAgICAxLjEwLiAiT3JpZ2luYWwgU29mdHdhcmUiIG1lYW5zIHRoZSBTb3VyY2UgQ29kZSBhbmQKKyAgICAgICAgICAgIEV4ZWN1dGFibGUgZm9ybSBvZiBjb21wdXRlciBzb2Z0d2FyZSBjb2RlIHRoYXQgaXMKKyAgICAgICAgICAgIG9yaWdpbmFsbHkgcmVsZWFzZWQgdW5kZXIgdGhpcyBMaWNlbnNlLiAKKworICAgICAgICAgICAgMS4xMS4gIlBhdGVudCBDbGFpbXMiIG1lYW5zIGFueSBwYXRlbnQgY2xhaW0ocyksIG5vdyBvd25lZAorICAgICAgICAgICAgb3IgaGVyZWFmdGVyIGFjcXVpcmVkLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uLAorICAgICAgICAgICAgbWV0aG9kLCBwcm9jZXNzLCBhbmQgYXBwYXJhdHVzIGNsYWltcywgaW4gYW55IHBhdGVudAorICAgICAgICAgICAgTGljZW5zYWJsZSBieSBncmFudG9yLiAKKworICAgICAgICAgICAgMS4xMi4gIlNvdXJjZSBDb2RlIiBtZWFucyAoYSkgdGhlIGNvbW1vbiBmb3JtIG9mIGNvbXB1dGVyCisgICAgICAgICAgICBzb2Z0d2FyZSBjb2RlIGluIHdoaWNoIG1vZGlmaWNhdGlvbnMgYXJlIG1hZGUgYW5kIChiKQorICAgICAgICAgICAgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGluY2x1ZGVkIGluIG9yIHdpdGggc3VjaCBjb2RlLgorCisgICAgICAgICAgICAxLjEzLiAiWW91IiAob3IgIllvdXIiKSBtZWFucyBhbiBpbmRpdmlkdWFsIG9yIGEgbGVnYWwKKyAgICAgICAgICAgIGVudGl0eSBleGVyY2lzaW5nIHJpZ2h0cyB1bmRlciwgYW5kIGNvbXBseWluZyB3aXRoIGFsbCBvZgorICAgICAgICAgICAgdGhlIHRlcm1zIG9mLCB0aGlzIExpY2Vuc2UuIEZvciBsZWdhbCBlbnRpdGllcywgIllvdSIKKyAgICAgICAgICAgIGluY2x1ZGVzIGFueSBlbnRpdHkgd2hpY2ggY29udHJvbHMsIGlzIGNvbnRyb2xsZWQgYnksIG9yIGlzCisgICAgICAgICAgICB1bmRlciBjb21tb24gY29udHJvbCB3aXRoIFlvdS4gRm9yIHB1cnBvc2VzIG9mIHRoaXMKKyAgICAgICAgICAgIGRlZmluaXRpb24sICJjb250cm9sIiBtZWFucyAoYSkgdGhlIHBvd2VyLCBkaXJlY3Qgb3IKKyAgICAgICAgICAgIGluZGlyZWN0LCB0byBjYXVzZSB0aGUgZGlyZWN0aW9uIG9yIG1hbmFnZW1lbnQgb2Ygc3VjaAorICAgICAgICAgICAgZW50aXR5LCB3aGV0aGVyIGJ5IGNvbnRyYWN0IG9yIG90aGVyd2lzZSwgb3IgKGIpIG93bmVyc2hpcAorICAgICAgICAgICAgb2YgbW9yZSB0aGFuIGZpZnR5IHBlcmNlbnQgKDUwJSkgb2YgdGhlIG91dHN0YW5kaW5nIHNoYXJlcworICAgICAgICAgICAgb3IgYmVuZWZpY2lhbCBvd25lcnNoaXAgb2Ygc3VjaCBlbnRpdHkuCisKKyAgICAgIDIuIExpY2Vuc2UgR3JhbnRzLiAKKworICAgICAgICAgICAgMi4xLiBUaGUgSW5pdGlhbCBEZXZlbG9wZXIgR3JhbnQuCisKKyAgICAgICAgICAgIENvbmRpdGlvbmVkIHVwb24gWW91ciBjb21wbGlhbmNlIHdpdGggU2VjdGlvbiAzLjEgYmVsb3cgYW5kCisgICAgICAgICAgICBzdWJqZWN0IHRvIHRoaXJkIHBhcnR5IGludGVsbGVjdHVhbCBwcm9wZXJ0eSBjbGFpbXMsIHRoZQorICAgICAgICAgICAgSW5pdGlhbCBEZXZlbG9wZXIgaGVyZWJ5IGdyYW50cyBZb3UgYSB3b3JsZC13aWRlLAorICAgICAgICAgICAgcm95YWx0eS1mcmVlLCBub24tZXhjbHVzaXZlIGxpY2Vuc2U6IAorCisgICAgICAgICAgICAgICAgICAoYSkgdW5kZXIgaW50ZWxsZWN0dWFsIHByb3BlcnR5IHJpZ2h0cyAob3RoZXIgdGhhbgorICAgICAgICAgICAgICAgICAgcGF0ZW50IG9yIHRyYWRlbWFyaykgTGljZW5zYWJsZSBieSBJbml0aWFsIERldmVsb3BlciwKKyAgICAgICAgICAgICAgICAgIHRvIHVzZSwgcmVwcm9kdWNlLCBtb2RpZnksIGRpc3BsYXksIHBlcmZvcm0sCisgICAgICAgICAgICAgICAgICBzdWJsaWNlbnNlIGFuZCBkaXN0cmlidXRlIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSAob3IKKyAgICAgICAgICAgICAgICAgIHBvcnRpb25zIHRoZXJlb2YpLCB3aXRoIG9yIHdpdGhvdXQgTW9kaWZpY2F0aW9ucywKKyAgICAgICAgICAgICAgICAgIGFuZC9vciBhcyBwYXJ0IG9mIGEgTGFyZ2VyIFdvcms7IGFuZCAKKworICAgICAgICAgICAgICAgICAgKGIpIHVuZGVyIFBhdGVudCBDbGFpbXMgaW5mcmluZ2VkIGJ5IHRoZSBtYWtpbmcsCisgICAgICAgICAgICAgICAgICB1c2luZyBvciBzZWxsaW5nIG9mIE9yaWdpbmFsIFNvZnR3YXJlLCB0byBtYWtlLCBoYXZlCisgICAgICAgICAgICAgICAgICBtYWRlLCB1c2UsIHByYWN0aWNlLCBzZWxsLCBhbmQgb2ZmZXIgZm9yIHNhbGUsIGFuZC9vcgorICAgICAgICAgICAgICAgICAgb3RoZXJ3aXNlIGRpc3Bvc2Ugb2YgdGhlIE9yaWdpbmFsIFNvZnR3YXJlIChvcgorICAgICAgICAgICAgICAgICAgcG9ydGlvbnMgdGhlcmVvZikuIAorCisgICAgICAgICAgICAgICAgICAoYykgVGhlIGxpY2Vuc2VzIGdyYW50ZWQgaW4gU2VjdGlvbnMgMi4xKGEpIGFuZCAoYikKKyAgICAgICAgICAgICAgICAgIGFyZSBlZmZlY3RpdmUgb24gdGhlIGRhdGUgSW5pdGlhbCBEZXZlbG9wZXIgZmlyc3QKKyAgICAgICAgICAgICAgICAgIGRpc3RyaWJ1dGVzIG9yIG90aGVyd2lzZSBtYWtlcyB0aGUgT3JpZ2luYWwgU29mdHdhcmUKKyAgICAgICAgICAgICAgICAgIGF2YWlsYWJsZSB0byBhIHRoaXJkIHBhcnR5IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGlzCisgICAgICAgICAgICAgICAgICBMaWNlbnNlLiAKKworICAgICAgICAgICAgICAgICAgKGQpIE5vdHdpdGhzdGFuZGluZyBTZWN0aW9uIDIuMShiKSBhYm92ZSwgbm8gcGF0ZW50CisgICAgICAgICAgICAgICAgICBsaWNlbnNlIGlzIGdyYW50ZWQ6ICgxKSBmb3IgY29kZSB0aGF0IFlvdSBkZWxldGUgZnJvbQorICAgICAgICAgICAgICAgICAgdGhlIE9yaWdpbmFsIFNvZnR3YXJlLCBvciAoMikgZm9yIGluZnJpbmdlbWVudHMKKyAgICAgICAgICAgICAgICAgIGNhdXNlZCBieTogKGkpIHRoZSBtb2RpZmljYXRpb24gb2YgdGhlIE9yaWdpbmFsCisgICAgICAgICAgICAgICAgICBTb2Z0d2FyZSwgb3IgKGlpKSB0aGUgY29tYmluYXRpb24gb2YgdGhlIE9yaWdpbmFsCisgICAgICAgICAgICAgICAgICBTb2Z0d2FyZSB3aXRoIG90aGVyIHNvZnR3YXJlIG9yIGRldmljZXMuIAorCisgICAgICAgICAgICAyLjIuIENvbnRyaWJ1dG9yIEdyYW50LgorCisgICAgICAgICAgICBDb25kaXRpb25lZCB1cG9uIFlvdXIgY29tcGxpYW5jZSB3aXRoIFNlY3Rpb24gMy4xIGJlbG93IGFuZAorICAgICAgICAgICAgc3ViamVjdCB0byB0aGlyZCBwYXJ0eSBpbnRlbGxlY3R1YWwgcHJvcGVydHkgY2xhaW1zLCBlYWNoCisgICAgICAgICAgICBDb250cmlidXRvciBoZXJlYnkgZ3JhbnRzIFlvdSBhIHdvcmxkLXdpZGUsIHJveWFsdHktZnJlZSwKKyAgICAgICAgICAgIG5vbi1leGNsdXNpdmUgbGljZW5zZToKKworICAgICAgICAgICAgICAgICAgKGEpIHVuZGVyIGludGVsbGVjdHVhbCBwcm9wZXJ0eSByaWdodHMgKG90aGVyIHRoYW4KKyAgICAgICAgICAgICAgICAgIHBhdGVudCBvciB0cmFkZW1hcmspIExpY2Vuc2FibGUgYnkgQ29udHJpYnV0b3IgdG8KKyAgICAgICAgICAgICAgICAgIHVzZSwgcmVwcm9kdWNlLCBtb2RpZnksIGRpc3BsYXksIHBlcmZvcm0sIHN1YmxpY2Vuc2UKKyAgICAgICAgICAgICAgICAgIGFuZCBkaXN0cmlidXRlIHRoZSBNb2RpZmljYXRpb25zIGNyZWF0ZWQgYnkgc3VjaAorICAgICAgICAgICAgICAgICAgQ29udHJpYnV0b3IgKG9yIHBvcnRpb25zIHRoZXJlb2YpLCBlaXRoZXIgb24gYW4KKyAgICAgICAgICAgICAgICAgIHVubW9kaWZpZWQgYmFzaXMsIHdpdGggb3RoZXIgTW9kaWZpY2F0aW9ucywgYXMKKyAgICAgICAgICAgICAgICAgIENvdmVyZWQgU29mdHdhcmUgYW5kL29yIGFzIHBhcnQgb2YgYSBMYXJnZXIgV29yazsgYW5kCisgICAgICAgICAgICAgICAgICAKKworICAgICAgICAgICAgICAgICAgKGIpIHVuZGVyIFBhdGVudCBDbGFpbXMgaW5mcmluZ2VkIGJ5IHRoZSBtYWtpbmcsCisgICAgICAgICAgICAgICAgICB1c2luZywgb3Igc2VsbGluZyBvZiBNb2RpZmljYXRpb25zIG1hZGUgYnkgdGhhdAorICAgICAgICAgICAgICAgICAgQ29udHJpYnV0b3IgZWl0aGVyIGFsb25lIGFuZC9vciBpbiBjb21iaW5hdGlvbiB3aXRoCisgICAgICAgICAgICAgICAgICBpdHMgQ29udHJpYnV0b3IgVmVyc2lvbiAob3IgcG9ydGlvbnMgb2Ygc3VjaAorICAgICAgICAgICAgICAgICAgY29tYmluYXRpb24pLCB0byBtYWtlLCB1c2UsIHNlbGwsIG9mZmVyIGZvciBzYWxlLAorICAgICAgICAgICAgICAgICAgaGF2ZSBtYWRlLCBhbmQvb3Igb3RoZXJ3aXNlIGRpc3Bvc2Ugb2Y6ICgxKQorICAgICAgICAgICAgICAgICAgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQgQ29udHJpYnV0b3IgKG9yIHBvcnRpb25zCisgICAgICAgICAgICAgICAgICB0aGVyZW9mKTsgYW5kICgyKSB0aGUgY29tYmluYXRpb24gb2YgTW9kaWZpY2F0aW9ucworICAgICAgICAgICAgICAgICAgbWFkZSBieSB0aGF0IENvbnRyaWJ1dG9yIHdpdGggaXRzIENvbnRyaWJ1dG9yIFZlcnNpb24KKyAgICAgICAgICAgICAgICAgIChvciBwb3J0aW9ucyBvZiBzdWNoIGNvbWJpbmF0aW9uKS4gCisKKyAgICAgICAgICAgICAgICAgIChjKSBUaGUgbGljZW5zZXMgZ3JhbnRlZCBpbiBTZWN0aW9ucyAyLjIoYSkgYW5kCisgICAgICAgICAgICAgICAgICAyLjIoYikgYXJlIGVmZmVjdGl2ZSBvbiB0aGUgZGF0ZSBDb250cmlidXRvciBmaXJzdAorICAgICAgICAgICAgICAgICAgZGlzdHJpYnV0ZXMgb3Igb3RoZXJ3aXNlIG1ha2VzIHRoZSBNb2RpZmljYXRpb25zCisgICAgICAgICAgICAgICAgICBhdmFpbGFibGUgdG8gYSB0aGlyZCBwYXJ0eS4gCisKKyAgICAgICAgICAgICAgICAgIChkKSBOb3R3aXRoc3RhbmRpbmcgU2VjdGlvbiAyLjIoYikgYWJvdmUsIG5vIHBhdGVudAorICAgICAgICAgICAgICAgICAgbGljZW5zZSBpcyBncmFudGVkOiAoMSkgZm9yIGFueSBjb2RlIHRoYXQgQ29udHJpYnV0b3IKKyAgICAgICAgICAgICAgICAgIGhhcyBkZWxldGVkIGZyb20gdGhlIENvbnRyaWJ1dG9yIFZlcnNpb247ICgyKSBmb3IKKyAgICAgICAgICAgICAgICAgIGluZnJpbmdlbWVudHMgY2F1c2VkIGJ5OiAoaSkgdGhpcmQgcGFydHkKKyAgICAgICAgICAgICAgICAgIG1vZGlmaWNhdGlvbnMgb2YgQ29udHJpYnV0b3IgVmVyc2lvbiwgb3IgKGlpKSB0aGUKKyAgICAgICAgICAgICAgICAgIGNvbWJpbmF0aW9uIG9mIE1vZGlmaWNhdGlvbnMgbWFkZSBieSB0aGF0IENvbnRyaWJ1dG9yCisgICAgICAgICAgICAgICAgICB3aXRoIG90aGVyIHNvZnR3YXJlIChleGNlcHQgYXMgcGFydCBvZiB0aGUKKyAgICAgICAgICAgICAgICAgIENvbnRyaWJ1dG9yIFZlcnNpb24pIG9yIG90aGVyIGRldmljZXM7IG9yICgzKSB1bmRlcgorICAgICAgICAgICAgICAgICAgUGF0ZW50IENsYWltcyBpbmZyaW5nZWQgYnkgQ292ZXJlZCBTb2Z0d2FyZSBpbiB0aGUKKyAgICAgICAgICAgICAgICAgIGFic2VuY2Ugb2YgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQgQ29udHJpYnV0b3IuIAorCisgICAgICAzLiBEaXN0cmlidXRpb24gT2JsaWdhdGlvbnMuCisKKyAgICAgICAgICAgIDMuMS4gQXZhaWxhYmlsaXR5IG9mIFNvdXJjZSBDb2RlLgorCisgICAgICAgICAgICBBbnkgQ292ZXJlZCBTb2Z0d2FyZSB0aGF0IFlvdSBkaXN0cmlidXRlIG9yIG90aGVyd2lzZSBtYWtlCisgICAgICAgICAgICBhdmFpbGFibGUgaW4gRXhlY3V0YWJsZSBmb3JtIG11c3QgYWxzbyBiZSBtYWRlIGF2YWlsYWJsZSBpbgorICAgICAgICAgICAgU291cmNlIENvZGUgZm9ybSBhbmQgdGhhdCBTb3VyY2UgQ29kZSBmb3JtIG11c3QgYmUKKyAgICAgICAgICAgIGRpc3RyaWJ1dGVkIG9ubHkgdW5kZXIgdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZS4gWW91IG11c3QKKyAgICAgICAgICAgIGluY2x1ZGUgYSBjb3B5IG9mIHRoaXMgTGljZW5zZSB3aXRoIGV2ZXJ5IGNvcHkgb2YgdGhlCisgICAgICAgICAgICBTb3VyY2UgQ29kZSBmb3JtIG9mIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIFlvdSBkaXN0cmlidXRlIG9yCisgICAgICAgICAgICBvdGhlcndpc2UgbWFrZSBhdmFpbGFibGUuIFlvdSBtdXN0IGluZm9ybSByZWNpcGllbnRzIG9mIGFueQorICAgICAgICAgICAgc3VjaCBDb3ZlcmVkIFNvZnR3YXJlIGluIEV4ZWN1dGFibGUgZm9ybSBhcyB0byBob3cgdGhleSBjYW4KKyAgICAgICAgICAgIG9idGFpbiBzdWNoIENvdmVyZWQgU29mdHdhcmUgaW4gU291cmNlIENvZGUgZm9ybSBpbiBhCisgICAgICAgICAgICByZWFzb25hYmxlIG1hbm5lciBvbiBvciB0aHJvdWdoIGEgbWVkaXVtIGN1c3RvbWFyaWx5IHVzZWQKKyAgICAgICAgICAgIGZvciBzb2Z0d2FyZSBleGNoYW5nZS4KKworICAgICAgICAgICAgMy4yLiBNb2RpZmljYXRpb25zLgorCisgICAgICAgICAgICBUaGUgTW9kaWZpY2F0aW9ucyB0aGF0IFlvdSBjcmVhdGUgb3IgdG8gd2hpY2ggWW91CisgICAgICAgICAgICBjb250cmlidXRlIGFyZSBnb3Zlcm5lZCBieSB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlLiBZb3UKKyAgICAgICAgICAgIHJlcHJlc2VudCB0aGF0IFlvdSBiZWxpZXZlIFlvdXIgTW9kaWZpY2F0aW9ucyBhcmUgWW91cgorICAgICAgICAgICAgb3JpZ2luYWwgY3JlYXRpb24ocykgYW5kL29yIFlvdSBoYXZlIHN1ZmZpY2llbnQgcmlnaHRzIHRvCisgICAgICAgICAgICBncmFudCB0aGUgcmlnaHRzIGNvbnZleWVkIGJ5IHRoaXMgTGljZW5zZS4KKworICAgICAgICAgICAgMy4zLiBSZXF1aXJlZCBOb3RpY2VzLgorCisgICAgICAgICAgICBZb3UgbXVzdCBpbmNsdWRlIGEgbm90aWNlIGluIGVhY2ggb2YgWW91ciBNb2RpZmljYXRpb25zCisgICAgICAgICAgICB0aGF0IGlkZW50aWZpZXMgWW91IGFzIHRoZSBDb250cmlidXRvciBvZiB0aGUgTW9kaWZpY2F0aW9uLgorICAgICAgICAgICAgWW91IG1heSBub3QgcmVtb3ZlIG9yIGFsdGVyIGFueSBjb3B5cmlnaHQsIHBhdGVudCBvcgorICAgICAgICAgICAgdHJhZGVtYXJrIG5vdGljZXMgY29udGFpbmVkIHdpdGhpbiB0aGUgQ292ZXJlZCBTb2Z0d2FyZSwgb3IKKyAgICAgICAgICAgIGFueSBub3RpY2VzIG9mIGxpY2Vuc2luZyBvciBhbnkgZGVzY3JpcHRpdmUgdGV4dCBnaXZpbmcKKyAgICAgICAgICAgIGF0dHJpYnV0aW9uIHRvIGFueSBDb250cmlidXRvciBvciB0aGUgSW5pdGlhbCBEZXZlbG9wZXIuCisKKyAgICAgICAgICAgIDMuNC4gQXBwbGljYXRpb24gb2YgQWRkaXRpb25hbCBUZXJtcy4KKworICAgICAgICAgICAgWW91IG1heSBub3Qgb2ZmZXIgb3IgaW1wb3NlIGFueSB0ZXJtcyBvbiBhbnkgQ292ZXJlZAorICAgICAgICAgICAgU29mdHdhcmUgaW4gU291cmNlIENvZGUgZm9ybSB0aGF0IGFsdGVycyBvciByZXN0cmljdHMgdGhlCisgICAgICAgICAgICBhcHBsaWNhYmxlIHZlcnNpb24gb2YgdGhpcyBMaWNlbnNlIG9yIHRoZSByZWNpcGllbnRzJworICAgICAgICAgICAgcmlnaHRzIGhlcmV1bmRlci4gWW91IG1heSBjaG9vc2UgdG8gb2ZmZXIsIGFuZCB0byBjaGFyZ2UgYQorICAgICAgICAgICAgZmVlIGZvciwgd2FycmFudHksIHN1cHBvcnQsIGluZGVtbml0eSBvciBsaWFiaWxpdHkKKyAgICAgICAgICAgIG9ibGlnYXRpb25zIHRvIG9uZSBvciBtb3JlIHJlY2lwaWVudHMgb2YgQ292ZXJlZCBTb2Z0d2FyZS4KKyAgICAgICAgICAgIEhvd2V2ZXIsIHlvdSBtYXkgZG8gc28gb25seSBvbiBZb3VyIG93biBiZWhhbGYsIGFuZCBub3Qgb24KKyAgICAgICAgICAgIGJlaGFsZiBvZiB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3IgYW55IENvbnRyaWJ1dG9yLiBZb3UKKyAgICAgICAgICAgIG11c3QgbWFrZSBpdCBhYnNvbHV0ZWx5IGNsZWFyIHRoYXQgYW55IHN1Y2ggd2FycmFudHksCisgICAgICAgICAgICBzdXBwb3J0LCBpbmRlbW5pdHkgb3IgbGlhYmlsaXR5IG9ibGlnYXRpb24gaXMgb2ZmZXJlZCBieQorICAgICAgICAgICAgWW91IGFsb25lLCBhbmQgWW91IGhlcmVieSBhZ3JlZSB0byBpbmRlbW5pZnkgdGhlIEluaXRpYWwKKyAgICAgICAgICAgIERldmVsb3BlciBhbmQgZXZlcnkgQ29udHJpYnV0b3IgZm9yIGFueSBsaWFiaWxpdHkgaW5jdXJyZWQKKyAgICAgICAgICAgIGJ5IHRoZSBJbml0aWFsIERldmVsb3BlciBvciBzdWNoIENvbnRyaWJ1dG9yIGFzIGEgcmVzdWx0IG9mCisgICAgICAgICAgICB3YXJyYW50eSwgc3VwcG9ydCwgaW5kZW1uaXR5IG9yIGxpYWJpbGl0eSB0ZXJtcyBZb3Ugb2ZmZXIuCisgICAgICAgICAgCisKKyAgICAgICAgICAgIDMuNS4gRGlzdHJpYnV0aW9uIG9mIEV4ZWN1dGFibGUgVmVyc2lvbnMuCisKKyAgICAgICAgICAgIFlvdSBtYXkgZGlzdHJpYnV0ZSB0aGUgRXhlY3V0YWJsZSBmb3JtIG9mIHRoZSBDb3ZlcmVkCisgICAgICAgICAgICBTb2Z0d2FyZSB1bmRlciB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlIG9yIHVuZGVyIHRoZSB0ZXJtcworICAgICAgICAgICAgb2YgYSBsaWNlbnNlIG9mIFlvdXIgY2hvaWNlLCB3aGljaCBtYXkgY29udGFpbiB0ZXJtcworICAgICAgICAgICAgZGlmZmVyZW50IGZyb20gdGhpcyBMaWNlbnNlLCBwcm92aWRlZCB0aGF0IFlvdSBhcmUgaW4KKyAgICAgICAgICAgIGNvbXBsaWFuY2Ugd2l0aCB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlIGFuZCB0aGF0IHRoZQorICAgICAgICAgICAgbGljZW5zZSBmb3IgdGhlIEV4ZWN1dGFibGUgZm9ybSBkb2VzIG5vdCBhdHRlbXB0IHRvIGxpbWl0CisgICAgICAgICAgICBvciBhbHRlciB0aGUgcmVjaXBpZW50J3MgcmlnaHRzIGluIHRoZSBTb3VyY2UgQ29kZSBmb3JtCisgICAgICAgICAgICBmcm9tIHRoZSByaWdodHMgc2V0IGZvcnRoIGluIHRoaXMgTGljZW5zZS4gSWYgWW91CisgICAgICAgICAgICBkaXN0cmlidXRlIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIGluIEV4ZWN1dGFibGUgZm9ybSB1bmRlciBhCisgICAgICAgICAgICBkaWZmZXJlbnQgbGljZW5zZSwgWW91IG11c3QgbWFrZSBpdCBhYnNvbHV0ZWx5IGNsZWFyIHRoYXQKKyAgICAgICAgICAgIGFueSB0ZXJtcyB3aGljaCBkaWZmZXIgZnJvbSB0aGlzIExpY2Vuc2UgYXJlIG9mZmVyZWQgYnkgWW91CisgICAgICAgICAgICBhbG9uZSwgbm90IGJ5IHRoZSBJbml0aWFsIERldmVsb3BlciBvciBDb250cmlidXRvci4gWW91CisgICAgICAgICAgICBoZXJlYnkgYWdyZWUgdG8gaW5kZW1uaWZ5IHRoZSBJbml0aWFsIERldmVsb3BlciBhbmQgZXZlcnkKKyAgICAgICAgICAgIENvbnRyaWJ1dG9yIGZvciBhbnkgbGlhYmlsaXR5IGluY3VycmVkIGJ5IHRoZSBJbml0aWFsCisgICAgICAgICAgICBEZXZlbG9wZXIgb3Igc3VjaCBDb250cmlidXRvciBhcyBhIHJlc3VsdCBvZiBhbnkgc3VjaCB0ZXJtcworICAgICAgICAgICAgWW91IG9mZmVyLgorCisgICAgICAgICAgICAzLjYuIExhcmdlciBXb3Jrcy4KKworICAgICAgICAgICAgWW91IG1heSBjcmVhdGUgYSBMYXJnZXIgV29yayBieSBjb21iaW5pbmcgQ292ZXJlZCBTb2Z0d2FyZQorICAgICAgICAgICAgd2l0aCBvdGhlciBjb2RlIG5vdCBnb3Zlcm5lZCBieSB0aGUgdGVybXMgb2YgdGhpcyBMaWNlbnNlCisgICAgICAgICAgICBhbmQgZGlzdHJpYnV0ZSB0aGUgTGFyZ2VyIFdvcmsgYXMgYSBzaW5nbGUgcHJvZHVjdC4gSW4gc3VjaAorICAgICAgICAgICAgYSBjYXNlLCBZb3UgbXVzdCBtYWtlIHN1cmUgdGhlIHJlcXVpcmVtZW50cyBvZiB0aGlzIExpY2Vuc2UKKyAgICAgICAgICAgIGFyZSBmdWxmaWxsZWQgZm9yIHRoZSBDb3ZlcmVkIFNvZnR3YXJlLiAKKyAgICAgICAgICAgIAorICAgICAgNC4gVmVyc2lvbnMgb2YgdGhlIExpY2Vuc2UuIAorCisgICAgICAgICAgICA0LjEuIE5ldyBWZXJzaW9ucy4KKworICAgICAgICAgICAgU3VuIE1pY3Jvc3lzdGVtcywgSW5jLiBpcyB0aGUgaW5pdGlhbCBsaWNlbnNlIHN0ZXdhcmQgYW5kCisgICAgICAgICAgICBtYXkgcHVibGlzaCByZXZpc2VkIGFuZC9vciBuZXcgdmVyc2lvbnMgb2YgdGhpcyBMaWNlbnNlCisgICAgICAgICAgICBmcm9tIHRpbWUgdG8gdGltZS4gRWFjaCB2ZXJzaW9uIHdpbGwgYmUgZ2l2ZW4gYQorICAgICAgICAgICAgZGlzdGluZ3Vpc2hpbmcgdmVyc2lvbiBudW1iZXIuIEV4Y2VwdCBhcyBwcm92aWRlZCBpbgorICAgICAgICAgICAgU2VjdGlvbiA0LjMsIG5vIG9uZSBvdGhlciB0aGFuIHRoZSBsaWNlbnNlIHN0ZXdhcmQgaGFzIHRoZQorICAgICAgICAgICAgcmlnaHQgdG8gbW9kaWZ5IHRoaXMgTGljZW5zZS4gCisKKyAgICAgICAgICAgIDQuMi4gRWZmZWN0IG9mIE5ldyBWZXJzaW9ucy4KKworICAgICAgICAgICAgWW91IG1heSBhbHdheXMgY29udGludWUgdG8gdXNlLCBkaXN0cmlidXRlIG9yIG90aGVyd2lzZQorICAgICAgICAgICAgbWFrZSB0aGUgQ292ZXJlZCBTb2Z0d2FyZSBhdmFpbGFibGUgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZQorICAgICAgICAgICAgdmVyc2lvbiBvZiB0aGUgTGljZW5zZSB1bmRlciB3aGljaCBZb3Ugb3JpZ2luYWxseSByZWNlaXZlZAorICAgICAgICAgICAgdGhlIENvdmVyZWQgU29mdHdhcmUuIElmIHRoZSBJbml0aWFsIERldmVsb3BlciBpbmNsdWRlcyBhCisgICAgICAgICAgICBub3RpY2UgaW4gdGhlIE9yaWdpbmFsIFNvZnR3YXJlIHByb2hpYml0aW5nIGl0IGZyb20gYmVpbmcKKyAgICAgICAgICAgIGRpc3RyaWJ1dGVkIG9yIG90aGVyd2lzZSBtYWRlIGF2YWlsYWJsZSB1bmRlciBhbnkKKyAgICAgICAgICAgIHN1YnNlcXVlbnQgdmVyc2lvbiBvZiB0aGUgTGljZW5zZSwgWW91IG11c3QgZGlzdHJpYnV0ZSBhbmQKKyAgICAgICAgICAgIG1ha2UgdGhlIENvdmVyZWQgU29mdHdhcmUgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUKKyAgICAgICAgICAgIHZlcnNpb24gb2YgdGhlIExpY2Vuc2UgdW5kZXIgd2hpY2ggWW91IG9yaWdpbmFsbHkgcmVjZWl2ZWQKKyAgICAgICAgICAgIHRoZSBDb3ZlcmVkIFNvZnR3YXJlLiBPdGhlcndpc2UsIFlvdSBtYXkgYWxzbyBjaG9vc2UgdG8KKyAgICAgICAgICAgIHVzZSwgZGlzdHJpYnV0ZSBvciBvdGhlcndpc2UgbWFrZSB0aGUgQ292ZXJlZCBTb2Z0d2FyZQorICAgICAgICAgICAgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiBhbnkgc3Vic2VxdWVudCB2ZXJzaW9uIG9mIHRoZQorICAgICAgICAgICAgTGljZW5zZSBwdWJsaXNoZWQgYnkgdGhlIGxpY2Vuc2Ugc3Rld2FyZC4gCisKKyAgICAgICAgICAgIDQuMy4gTW9kaWZpZWQgVmVyc2lvbnMuCisKKyAgICAgICAgICAgIFdoZW4gWW91IGFyZSBhbiBJbml0aWFsIERldmVsb3BlciBhbmQgWW91IHdhbnQgdG8gY3JlYXRlIGEKKyAgICAgICAgICAgIG5ldyBsaWNlbnNlIGZvciBZb3VyIE9yaWdpbmFsIFNvZnR3YXJlLCBZb3UgbWF5IGNyZWF0ZSBhbmQKKyAgICAgICAgICAgIHVzZSBhIG1vZGlmaWVkIHZlcnNpb24gb2YgdGhpcyBMaWNlbnNlIGlmIFlvdTogKGEpIHJlbmFtZQorICAgICAgICAgICAgdGhlIGxpY2Vuc2UgYW5kIHJlbW92ZSBhbnkgcmVmZXJlbmNlcyB0byB0aGUgbmFtZSBvZiB0aGUKKyAgICAgICAgICAgIGxpY2Vuc2Ugc3Rld2FyZCAoZXhjZXB0IHRvIG5vdGUgdGhhdCB0aGUgbGljZW5zZSBkaWZmZXJzCisgICAgICAgICAgICBmcm9tIHRoaXMgTGljZW5zZSk7IGFuZCAoYikgb3RoZXJ3aXNlIG1ha2UgaXQgY2xlYXIgdGhhdAorICAgICAgICAgICAgdGhlIGxpY2Vuc2UgY29udGFpbnMgdGVybXMgd2hpY2ggZGlmZmVyIGZyb20gdGhpcyBMaWNlbnNlLgorICAgICAgICAgICAgCisKKyAgICAgIDUuIERJU0NMQUlNRVIgT0YgV0FSUkFOVFkuCisKKyAgICAgIENPVkVSRUQgU09GVFdBUkUgSVMgUFJPVklERUQgVU5ERVIgVEhJUyBMSUNFTlNFIE9OIEFOICJBUyBJUyIKKyAgICAgIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFSVRIRVIgRVhQUkVTU0VEIE9SIElNUExJRUQsCisgICAgICBJTkNMVURJTkcsIFdJVEhPVVQgTElNSVRBVElPTiwgV0FSUkFOVElFUyBUSEFUIFRIRSBDT1ZFUkVECisgICAgICBTT0ZUV0FSRSBJUyBGUkVFIE9GIERFRkVDVFMsIE1FUkNIQU5UQUJMRSwgRklUIEZPUiBBIFBBUlRJQ1VMQVIKKyAgICAgIFBVUlBPU0UgT1IgTk9OLUlORlJJTkdJTkcuIFRIRSBFTlRJUkUgUklTSyBBUyBUTyBUSEUgUVVBTElUWSBBTkQKKyAgICAgIFBFUkZPUk1BTkNFIE9GIFRIRSBDT1ZFUkVEIFNPRlRXQVJFIElTIFdJVEggWU9VLiBTSE9VTEQgQU5ZCisgICAgICBDT1ZFUkVEIFNPRlRXQVJFIFBST1ZFIERFRkVDVElWRSBJTiBBTlkgUkVTUEVDVCwgWU9VIChOT1QgVEhFCisgICAgICBJTklUSUFMIERFVkVMT1BFUiBPUiBBTlkgT1RIRVIgQ09OVFJJQlVUT1IpIEFTU1VNRSBUSEUgQ09TVCBPRgorICAgICAgQU5ZIE5FQ0VTU0FSWSBTRVJWSUNJTkcsIFJFUEFJUiBPUiBDT1JSRUNUSU9OLiBUSElTIERJU0NMQUlNRVIgT0YKKyAgICAgIFdBUlJBTlRZIENPTlNUSVRVVEVTIEFOIEVTU0VOVElBTCBQQVJUIE9GIFRISVMgTElDRU5TRS4gTk8gVVNFIE9GCisgICAgICBBTlkgQ09WRVJFRCBTT0ZUV0FSRSBJUyBBVVRIT1JJWkVEIEhFUkVVTkRFUiBFWENFUFQgVU5ERVIgVEhJUworICAgICAgRElTQ0xBSU1FUi4gCisKKyAgICAgIDYuIFRFUk1JTkFUSU9OLiAKKworICAgICAgICAgICAgNi4xLiBUaGlzIExpY2Vuc2UgYW5kIHRoZSByaWdodHMgZ3JhbnRlZCBoZXJldW5kZXIgd2lsbAorICAgICAgICAgICAgdGVybWluYXRlIGF1dG9tYXRpY2FsbHkgaWYgWW91IGZhaWwgdG8gY29tcGx5IHdpdGggdGVybXMKKyAgICAgICAgICAgIGhlcmVpbiBhbmQgZmFpbCB0byBjdXJlIHN1Y2ggYnJlYWNoIHdpdGhpbiAzMCBkYXlzIG9mCisgICAgICAgICAgICBiZWNvbWluZyBhd2FyZSBvZiB0aGUgYnJlYWNoLiBQcm92aXNpb25zIHdoaWNoLCBieSB0aGVpcgorICAgICAgICAgICAgbmF0dXJlLCBtdXN0IHJlbWFpbiBpbiBlZmZlY3QgYmV5b25kIHRoZSB0ZXJtaW5hdGlvbiBvZgorICAgICAgICAgICAgdGhpcyBMaWNlbnNlIHNoYWxsIHN1cnZpdmUuCisKKyAgICAgICAgICAgIDYuMi4gSWYgWW91IGFzc2VydCBhIHBhdGVudCBpbmZyaW5nZW1lbnQgY2xhaW0gKGV4Y2x1ZGluZworICAgICAgICAgICAgZGVjbGFyYXRvcnkganVkZ21lbnQgYWN0aW9ucykgYWdhaW5zdCBJbml0aWFsIERldmVsb3BlciBvcgorICAgICAgICAgICAgYSBDb250cmlidXRvciAodGhlIEluaXRpYWwgRGV2ZWxvcGVyIG9yIENvbnRyaWJ1dG9yIGFnYWluc3QKKyAgICAgICAgICAgIHdob20gWW91IGFzc2VydCBzdWNoIGNsYWltIGlzIHJlZmVycmVkIHRvIGFzICJQYXJ0aWNpcGFudCIpCisgICAgICAgICAgICBhbGxlZ2luZyB0aGF0IHRoZSBQYXJ0aWNpcGFudCBTb2Z0d2FyZSAobWVhbmluZyB0aGUKKyAgICAgICAgICAgIENvbnRyaWJ1dG9yIFZlcnNpb24gd2hlcmUgdGhlIFBhcnRpY2lwYW50IGlzIGEgQ29udHJpYnV0b3IKKyAgICAgICAgICAgIG9yIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSB3aGVyZSB0aGUgUGFydGljaXBhbnQgaXMgdGhlCisgICAgICAgICAgICBJbml0aWFsIERldmVsb3BlcikgZGlyZWN0bHkgb3IgaW5kaXJlY3RseSBpbmZyaW5nZXMgYW55CisgICAgICAgICAgICBwYXRlbnQsIHRoZW4gYW55IGFuZCBhbGwgcmlnaHRzIGdyYW50ZWQgZGlyZWN0bHkgb3IKKyAgICAgICAgICAgIGluZGlyZWN0bHkgdG8gWW91IGJ5IHN1Y2ggUGFydGljaXBhbnQsIHRoZSBJbml0aWFsCisgICAgICAgICAgICBEZXZlbG9wZXIgKGlmIHRoZSBJbml0aWFsIERldmVsb3BlciBpcyBub3QgdGhlIFBhcnRpY2lwYW50KQorICAgICAgICAgICAgYW5kIGFsbCBDb250cmlidXRvcnMgdW5kZXIgU2VjdGlvbnMgMi4xIGFuZC9vciAyLjIgb2YgdGhpcworICAgICAgICAgICAgTGljZW5zZSBzaGFsbCwgdXBvbiA2MCBkYXlzIG5vdGljZSBmcm9tIFBhcnRpY2lwYW50CisgICAgICAgICAgICB0ZXJtaW5hdGUgcHJvc3BlY3RpdmVseSBhbmQgYXV0b21hdGljYWxseSBhdCB0aGUgZXhwaXJhdGlvbgorICAgICAgICAgICAgb2Ygc3VjaCA2MCBkYXkgbm90aWNlIHBlcmlvZCwgdW5sZXNzIGlmIHdpdGhpbiBzdWNoIDYwIGRheQorICAgICAgICAgICAgcGVyaW9kIFlvdSB3aXRoZHJhdyBZb3VyIGNsYWltIHdpdGggcmVzcGVjdCB0byB0aGUKKyAgICAgICAgICAgIFBhcnRpY2lwYW50IFNvZnR3YXJlIGFnYWluc3Qgc3VjaCBQYXJ0aWNpcGFudCBlaXRoZXIKKyAgICAgICAgICAgIHVuaWxhdGVyYWxseSBvciBwdXJzdWFudCB0byBhIHdyaXR0ZW4gYWdyZWVtZW50IHdpdGgKKyAgICAgICAgICAgIFBhcnRpY2lwYW50LgorCisgICAgICAgICAgICA2LjMuIEluIHRoZSBldmVudCBvZiB0ZXJtaW5hdGlvbiB1bmRlciBTZWN0aW9ucyA2LjEgb3IgNi4yCisgICAgICAgICAgICBhYm92ZSwgYWxsIGVuZCB1c2VyIGxpY2Vuc2VzIHRoYXQgaGF2ZSBiZWVuIHZhbGlkbHkgZ3JhbnRlZAorICAgICAgICAgICAgYnkgWW91IG9yIGFueSBkaXN0cmlidXRvciBoZXJldW5kZXIgcHJpb3IgdG8gdGVybWluYXRpb24KKyAgICAgICAgICAgIChleGNsdWRpbmcgbGljZW5zZXMgZ3JhbnRlZCB0byBZb3UgYnkgYW55IGRpc3RyaWJ1dG9yKQorICAgICAgICAgICAgc2hhbGwgc3Vydml2ZSB0ZXJtaW5hdGlvbi4KKworICAgICAgNy4gTElNSVRBVElPTiBPRiBMSUFCSUxJVFkuCisKKyAgICAgIFVOREVSIE5PIENJUkNVTVNUQU5DRVMgQU5EIFVOREVSIE5PIExFR0FMIFRIRU9SWSwgV0hFVEhFUiBUT1JUCisgICAgICAoSU5DTFVESU5HIE5FR0xJR0VOQ0UpLCBDT05UUkFDVCwgT1IgT1RIRVJXSVNFLCBTSEFMTCBZT1UsIFRIRQorICAgICAgSU5JVElBTCBERVZFTE9QRVIsIEFOWSBPVEhFUiBDT05UUklCVVRPUiwgT1IgQU5ZIERJU1RSSUJVVE9SIE9GCisgICAgICBDT1ZFUkVEIFNPRlRXQVJFLCBPUiBBTlkgU1VQUExJRVIgT0YgQU5ZIE9GIFNVQ0ggUEFSVElFUywgQkUKKyAgICAgIExJQUJMRSBUTyBBTlkgUEVSU09OIEZPUiBBTlkgSU5ESVJFQ1QsIFNQRUNJQUwsIElOQ0lERU5UQUwsIE9SCisgICAgICBDT05TRVFVRU5USUFMIERBTUFHRVMgT0YgQU5ZIENIQVJBQ1RFUiBJTkNMVURJTkcsIFdJVEhPVVQKKyAgICAgIExJTUlUQVRJT04sIERBTUFHRVMgRk9SIExPU1QgUFJPRklUUywgTE9TUyBPRiBHT09EV0lMTCwgV09SSworICAgICAgU1RPUFBBR0UsIENPTVBVVEVSIEZBSUxVUkUgT1IgTUFMRlVOQ1RJT04sIE9SIEFOWSBBTkQgQUxMIE9USEVSCisgICAgICBDT01NRVJDSUFMIERBTUFHRVMgT1IgTE9TU0VTLCBFVkVOIElGIFNVQ0ggUEFSVFkgU0hBTEwgSEFWRSBCRUVOCisgICAgICBJTkZPUk1FRCBPRiBUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0VTLiBUSElTIExJTUlUQVRJT04gT0YKKyAgICAgIExJQUJJTElUWSBTSEFMTCBOT1QgQVBQTFkgVE8gTElBQklMSVRZIEZPUiBERUFUSCBPUiBQRVJTT05BTAorICAgICAgSU5KVVJZIFJFU1VMVElORyBGUk9NIFNVQ0ggUEFSVFknUyBORUdMSUdFTkNFIFRPIFRIRSBFWFRFTlQKKyAgICAgIEFQUExJQ0FCTEUgTEFXIFBST0hJQklUUyBTVUNIIExJTUlUQVRJT04uIFNPTUUgSlVSSVNESUNUSU9OUyBETworICAgICAgTk9UIEFMTE9XIFRIRSBFWENMVVNJT04gT1IgTElNSVRBVElPTiBPRiBJTkNJREVOVEFMIE9SCisgICAgICBDT05TRVFVRU5USUFMIERBTUFHRVMsIFNPIFRISVMgRVhDTFVTSU9OIEFORCBMSU1JVEFUSU9OIE1BWSBOT1QKKyAgICAgIEFQUExZIFRPIFlPVS4KKworICAgICAgOC4gVS5TLiBHT1ZFUk5NRU5UIEVORCBVU0VSUy4KKworICAgICAgVGhlIENvdmVyZWQgU29mdHdhcmUgaXMgYSAiY29tbWVyY2lhbCBpdGVtLCIgYXMgdGhhdCB0ZXJtIGlzCisgICAgICBkZWZpbmVkIGluIDQ4IEMuRi5SLiAyLjEwMSAoT2N0LiAxOTk1KSwgY29uc2lzdGluZyBvZiAiY29tbWVyY2lhbAorICAgICAgY29tcHV0ZXIgc29mdHdhcmUiIChhcyB0aGF0IHRlcm0gaXMgZGVmaW5lZCBhdCA0OCBDLkYuUi4gCisgICAgICAyNTIuMjI3LTcwMTQoYSkoMSkpIGFuZCAiY29tbWVyY2lhbCBjb21wdXRlciBzb2Z0d2FyZQorICAgICAgZG9jdW1lbnRhdGlvbiIgYXMgc3VjaCB0ZXJtcyBhcmUgdXNlZCBpbiA0OCBDLkYuUi4gMTIuMjEyIChTZXB0LgorICAgICAgMTk5NSkuIENvbnNpc3RlbnQgd2l0aCA0OCBDLkYuUi4gMTIuMjEyIGFuZCA0OCBDLkYuUi4gMjI3LjcyMDItMQorICAgICAgdGhyb3VnaCAyMjcuNzIwMi00IChKdW5lIDE5OTUpLCBhbGwgVS5TLiBHb3Zlcm5tZW50IEVuZCBVc2VycworICAgICAgYWNxdWlyZSBDb3ZlcmVkIFNvZnR3YXJlIHdpdGggb25seSB0aG9zZSByaWdodHMgc2V0IGZvcnRoIGhlcmVpbi4KKyAgICAgIFRoaXMgVS5TLiBHb3Zlcm5tZW50IFJpZ2h0cyBjbGF1c2UgaXMgaW4gbGlldSBvZiwgYW5kIHN1cGVyc2VkZXMsCisgICAgICBhbnkgb3RoZXIgRkFSLCBERkFSLCBvciBvdGhlciBjbGF1c2Ugb3IgcHJvdmlzaW9uIHRoYXQgYWRkcmVzc2VzCisgICAgICBHb3Zlcm5tZW50IHJpZ2h0cyBpbiBjb21wdXRlciBzb2Z0d2FyZSB1bmRlciB0aGlzIExpY2Vuc2UuCisKKyAgICAgIDkuIE1JU0NFTExBTkVPVVMuCisKKyAgICAgIFRoaXMgTGljZW5zZSByZXByZXNlbnRzIHRoZSBjb21wbGV0ZSBhZ3JlZW1lbnQgY29uY2VybmluZyBzdWJqZWN0CisgICAgICBtYXR0ZXIgaGVyZW9mLiBJZiBhbnkgcHJvdmlzaW9uIG9mIHRoaXMgTGljZW5zZSBpcyBoZWxkIHRvIGJlCisgICAgICB1bmVuZm9yY2VhYmxlLCBzdWNoIHByb3Zpc2lvbiBzaGFsbCBiZSByZWZvcm1lZCBvbmx5IHRvIHRoZQorICAgICAgZXh0ZW50IG5lY2Vzc2FyeSB0byBtYWtlIGl0IGVuZm9yY2VhYmxlLiBUaGlzIExpY2Vuc2Ugc2hhbGwgYmUKKyAgICAgIGdvdmVybmVkIGJ5IHRoZSBsYXcgb2YgdGhlIGp1cmlzZGljdGlvbiBzcGVjaWZpZWQgaW4gYSBub3RpY2UKKyAgICAgIGNvbnRhaW5lZCB3aXRoaW4gdGhlIE9yaWdpbmFsIFNvZnR3YXJlIChleGNlcHQgdG8gdGhlIGV4dGVudAorICAgICAgYXBwbGljYWJsZSBsYXcsIGlmIGFueSwgcHJvdmlkZXMgb3RoZXJ3aXNlKSwgZXhjbHVkaW5nIHN1Y2gKKyAgICAgIGp1cmlzZGljdGlvbidzIGNvbmZsaWN0LW9mLWxhdyBwcm92aXNpb25zLiBBbnkgbGl0aWdhdGlvbgorICAgICAgcmVsYXRpbmcgdG8gdGhpcyBMaWNlbnNlIHNoYWxsIGJlIHN1YmplY3QgdG8gdGhlIGp1cmlzZGljdGlvbiBvZgorICAgICAgdGhlIGNvdXJ0cyBsb2NhdGVkIGluIHRoZSBqdXJpc2RpY3Rpb24gYW5kIHZlbnVlIHNwZWNpZmllZCBpbiBhCisgICAgICBub3RpY2UgY29udGFpbmVkIHdpdGhpbiB0aGUgT3JpZ2luYWwgU29mdHdhcmUsIHdpdGggdGhlIGxvc2luZworICAgICAgcGFydHkgcmVzcG9uc2libGUgZm9yIGNvc3RzLCBpbmNsdWRpbmcsIHdpdGhvdXQgbGltaXRhdGlvbiwgY291cnQKKyAgICAgIGNvc3RzIGFuZCByZWFzb25hYmxlIGF0dG9ybmV5cycgZmVlcyBhbmQgZXhwZW5zZXMuIFRoZQorICAgICAgYXBwbGljYXRpb24gb2YgdGhlIFVuaXRlZCBOYXRpb25zIENvbnZlbnRpb24gb24gQ29udHJhY3RzIGZvciB0aGUKKyAgICAgIEludGVybmF0aW9uYWwgU2FsZSBvZiBHb29kcyBpcyBleHByZXNzbHkgZXhjbHVkZWQuIEFueSBsYXcgb3IKKyAgICAgIHJlZ3VsYXRpb24gd2hpY2ggcHJvdmlkZXMgdGhhdCB0aGUgbGFuZ3VhZ2Ugb2YgYSBjb250cmFjdCBzaGFsbAorICAgICAgYmUgY29uc3RydWVkIGFnYWluc3QgdGhlIGRyYWZ0ZXIgc2hhbGwgbm90IGFwcGx5IHRvIHRoaXMgTGljZW5zZS4KKyAgICAgIFlvdSBhZ3JlZSB0aGF0IFlvdSBhbG9uZSBhcmUgcmVzcG9uc2libGUgZm9yIGNvbXBsaWFuY2Ugd2l0aCB0aGUKKyAgICAgIFVuaXRlZCBTdGF0ZXMgZXhwb3J0IGFkbWluaXN0cmF0aW9uIHJlZ3VsYXRpb25zIChhbmQgdGhlIGV4cG9ydAorICAgICAgY29udHJvbCBsYXdzIGFuZCByZWd1bGF0aW9uIG9mIGFueSBvdGhlciBjb3VudHJpZXMpIHdoZW4gWW91IHVzZSwKKyAgICAgIGRpc3RyaWJ1dGUgb3Igb3RoZXJ3aXNlIG1ha2UgYXZhaWxhYmxlIGFueSBDb3ZlcmVkIFNvZnR3YXJlLgorCisgICAgICAxMC4gUkVTUE9OU0lCSUxJVFkgRk9SIENMQUlNUy4KKworICAgICAgQXMgYmV0d2VlbiBJbml0aWFsIERldmVsb3BlciBhbmQgdGhlIENvbnRyaWJ1dG9ycywgZWFjaCBwYXJ0eSBpcworICAgICAgcmVzcG9uc2libGUgZm9yIGNsYWltcyBhbmQgZGFtYWdlcyBhcmlzaW5nLCBkaXJlY3RseSBvcgorICAgICAgaW5kaXJlY3RseSwgb3V0IG9mIGl0cyB1dGlsaXphdGlvbiBvZiByaWdodHMgdW5kZXIgdGhpcyBMaWNlbnNlCisgICAgICBhbmQgWW91IGFncmVlIHRvIHdvcmsgd2l0aCBJbml0aWFsIERldmVsb3BlciBhbmQgQ29udHJpYnV0b3JzIHRvCisgICAgICBkaXN0cmlidXRlIHN1Y2ggcmVzcG9uc2liaWxpdHkgb24gYW4gZXF1aXRhYmxlIGJhc2lzLiBOb3RoaW5nCisgICAgICBoZXJlaW4gaXMgaW50ZW5kZWQgb3Igc2hhbGwgYmUgZGVlbWVkIHRvIGNvbnN0aXR1dGUgYW55IGFkbWlzc2lvbgorICAgICAgb2YgbGlhYmlsaXR5LgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitkb2pvdG9vbGtpdCBWMS40LjI6CisKK1RoZSAiTmV3IiBCU0QgTGljZW5zZToKKyoqKioqKioqKioqKioqKioqKioqKioKKworQ29weXJpZ2h0IChjKSAyMDA1LCBUaGUgRG9qbyBGb3VuZGF0aW9uCitBbGwgcmlnaHRzIHJlc2VydmVkLgorCitSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKK21vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCBwcm92aWRlZCB0aGF0IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9ucyBhcmUgbWV0OgorCisgICogUmVkaXN0cmlidXRpb25zIG9mIHNvdXJjZSBjb2RlIG11c3QgcmV0YWluIHRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlLCB0aGlzCisJbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIuCisgICogUmVkaXN0cmlidXRpb25zIGluIGJpbmFyeSBmb3JtIG11c3QgcmVwcm9kdWNlIHRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlLAorCXRoaXMgbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIgaW4gdGhlIGRvY3VtZW50YXRpb24KKwlhbmQvb3Igb3RoZXIgbWF0ZXJpYWxzIHByb3ZpZGVkIHdpdGggdGhlIGRpc3RyaWJ1dGlvbi4KKyAgKiBOZWl0aGVyIHRoZSBuYW1lIG9mIHRoZSBEb2pvIEZvdW5kYXRpb24gbm9yIHRoZSBuYW1lcyBvZiBpdHMgY29udHJpYnV0b3JzCisJbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIHNvZnR3YXJlCisJd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCisKK1RISVMgU09GVFdBUkUgSVMgUFJPVklERUQgQlkgVEhFIENPUFlSSUdIVCBIT0xERVJTIEFORCBDT05UUklCVVRPUlMgIkFTIElTIiBBTkQKK0FOWSBFWFBSRVNTIE9SIElNUExJRUQgV0FSUkFOVElFUywgSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFRIRSBJTVBMSUVECitXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSBBTkQgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQVJFCitESVNDTEFJTUVELiAgSU4gTk8gRVZFTlQgU0hBTEwgVEhFIENPUFlSSUdIVCBPV05FUiBPUiBDT05UUklCVVRPUlMgQkUgTElBQkxFCitGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIElOQ0lERU5UQUwsIFNQRUNJQUwsIEVYRU1QTEFSWSwgT1IgQ09OU0VRVUVOVElBTAorREFNQUdFUyAoSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GIFNVQlNUSVRVVEUgR09PRFMgT1IKK1NFUlZJQ0VTOyBMT1NTIE9GIFVTRSwgREFUQSwgT1IgUFJPRklUUzsgT1IgQlVTSU5FU1MgSU5URVJSVVBUSU9OKSBIT1dFVkVSCitDQVVTRUQgQU5EIE9OIEFOWSBUSEVPUlkgT0YgTElBQklMSVRZLCBXSEVUSEVSIElOIENPTlRSQUNULCBTVFJJQ1QgTElBQklMSVRZLAorT1IgVE9SVCAoSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKSBBUklTSU5HIElOIEFOWSBXQVkgT1VUIE9GIFRIRSBVU0UKK09GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRiBUSEUgUE9TU0lCSUxJVFkgT0YgU1VDSCBEQU1BR0UuCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK1RoZSB0dXNjYW55LWFzc2VtYmx5LXhzZCBqYXIgaW5jbHVkZXMgWFNEIGZpbGVzIHVuZGVyIHRoZSBmb2xsb3dpbmcgU0NBIENvbGxhYm9yYXRpb24gbGljZW5zZToKKworTGljZW5zZSBmb3IgdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBKYXZhRG9jLCBJbnRlcmZhY2UgCitEZWZpbml0aW9uIGZpbGVzIGFuZCBYU0QgZmlsZXMuCisKK1RoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgSmF2YURvYywgSW50ZXJmYWNlIERlZmluaXRpb24gZmlsZXMsIAorYW5kIFhTRCBmaWxlcyBhcmUgYmVpbmcgcHJvdmlkZWQgYnkgdGhlIGNvcHlyaWdodCBob2xkZXJzIHVuZGVyIHRoZSAKK2ZvbGxvd2luZyBsaWNlbnNlLiBCeSB1c2luZyBhbmQvb3IgY29weWluZyB0aGlzIHdvcmssIHlvdSBhZ3JlZSB0aGF0IAoreW91IGhhdmUgcmVhZCwgdW5kZXJzdG9vZCBhbmQgd2lsbCBjb21wbHkgd2l0aCB0aGUgZm9sbG93aW5nIHRlcm1zIGFuZCAKK2NvbmRpdGlvbnM6CisKK1Blcm1pc3Npb24gdG8gY29weSwgZGlzcGxheSwgbWFrZSBkZXJpdmF0aXZlIHdvcmtzIG9mLCBhbmQgZGlzdHJpYnV0ZSAKK3RoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgSmF2YURvYywgSW50ZXJmYWNlIERlZmluaXRpb24gRmlsZXMgCithbmQgWFNEIGZpbGVzICh0aGUgIkFydGlmYWN0cyIpIGluIGFueSBtZWRpdW0gd2l0aG91dCBmZWUgb3Igcm95YWx0eSBpcyAKK2hlcmVieSBncmFudGVkLCBwcm92aWRlZCB0aGF0IHlvdSBpbmNsdWRlIHRoZSBmb2xsb3dpbmcgb24gQUxMIGNvcGllcyAKK29mIHRoZSBBcnRpZmFjdHMsIG9yIHBvcnRpb25zIHRoZXJlb2YsIHRoYXQgeW91IG1ha2U6IAorCisxLiBBIGxpbmsgb3IgVVJMIHRvIHRoZSBBcnRpZmFjdHMgYXQgdGhpcyBsb2NhdGlvbjoKK2h0dHA6Ly93d3cub3NvYS5vcmcvZGlzcGxheS9NYWluL1NlcnZpY2UrQ29tcG9uZW50K0FyY2hpdGVjdHVyZStTcGVjaWZpY2F0aW9ucyAKKworMi4gVGhlIGZ1bGwgdGV4dCBvZiB0aGlzIGNvcHlyaWdodCBub3RpY2UgYXMgc2hvd24gaW4gdGhlIEFydGlmYWN0cy4KKworVEhFIEFSVElGQUNUUyBBUkUgUFJPVklERUQgIkFTIElTLCIgQU5EIFRIRSBBVVRIT1JTIE1BS0UgTk8gCitSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRVhQUkVTUyBPUiBJTVBMSUVELCBSRUdBUkRJTkcgVEhFIAorQVJUSUZBQ1RTIEFORCBUSEUgSU1QTEVNRU5UQVRJT04gT0YgVEhFSVIgQ09OVEVOVFMsIElOQ0xVRElORywgQlVUIE5PVCAKK0xJTUlURUQgVE8sIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgCitQVVJQT1NFLCBOT04tSU5GUklOR0VNRU5UIE9SIFRJVExFLiAgCisKK1RIRSBBVVRIT1JTIFdJTEwgTk9UIEJFIExJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIFNQRUNJQUwsIAorSU5DSURFTlRBTCBPUiBDT05TRVFVRU5USUFMIERBTUFHRVMgQVJJU0lORyBPVVQgT0YgT1IgUkVMQVRJTkcgVE8gQU5ZIAorVVNFIE9SIERJU1RSSUJVVElPTiBPRiBUSEUgQVJUSUZBQ1RTLgorCitUaGUgbmFtZSBhbmQgdHJhZGVtYXJrcyBvZiB0aGUgQXV0aG9ycyBtYXkgTk9UIGJlIHVzZWQgaW4gYW55IG1hbm5lciwgCitpbmNsdWRpbmcgYWR2ZXJ0aXNpbmcgb3IgcHVibGljaXR5IHBlcnRhaW5pbmcgdG8gdGhlIFNlcnZpY2UgQ29tcG9uZW50IAorQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gb3IgaXRzIGNvbnRlbnRzIHdpdGhvdXQgc3BlY2lmaWMsIHdyaXR0ZW4gCitwcmlvciBwZXJtaXNzaW9uLiBUaXRsZSB0byBjb3B5cmlnaHQgaW4gdGhlIFNlcnZpY2UgQ29tcG9uZW50IAorQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gYW5kIHRoZSBKYXZhRG9jLCBJbnRlcmZhY2UgRGVmaW5pdGlvbiBGaWxlcyAKK2FuZCBYU0QgRmlsZXMgd2lsbCBhdCBhbGwgdGltZXMgcmVtYWluIHdpdGggdGhlIEF1dGhvcnMuCisKK05vIG90aGVyIHJpZ2h0cyBhcmUgZ3JhbnRlZCBieSBpbXBsaWNhdGlvbiwgZXN0b3BwZWwgb3Igb3RoZXJ3aXNlLgorCitSZXZpc2lvbiBsZXZlbCAxLjEsIGxhc3QgdXBkYXRlZCBvbiAyMDA3LzExLzE5CisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK1RoZSBhc20tMy4xLmphcjoKKworQ29weXJpZ2h0IChjKSAyMDAwLTIwMDUgSU5SSUEsIEZyYW5jZSBUZWxlY29tCitBbGwgcmlnaHRzIHJlc2VydmVkLgorCitSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKK21vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCBwcm92aWRlZCB0aGF0IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9ucworYXJlIG1ldDoKKworMS4gUmVkaXN0cmlidXRpb25zIG9mIHNvdXJjZSBjb2RlIG11c3QgcmV0YWluIHRoZSBhYm92ZSBjb3B5cmlnaHQKKyAgIG5vdGljZSwgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lci4KKworMi4gUmVkaXN0cmlidXRpb25zIGluIGJpbmFyeSBmb3JtIG11c3QgcmVwcm9kdWNlIHRoZSBhYm92ZSBjb3B5cmlnaHQKKyAgIG5vdGljZSwgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lciBpbiB0aGUKKyAgIGRvY3VtZW50YXRpb24gYW5kL29yIG90aGVyIG1hdGVyaWFscyBwcm92aWRlZCB3aXRoIHRoZSBkaXN0cmlidXRpb24uCisKKzMuIE5laXRoZXIgdGhlIG5hbWUgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIG5vciB0aGUgbmFtZXMgb2YgaXRzCisgICBjb250cmlidXRvcnMgbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbQorICAgdGhpcyBzb2Z0d2FyZSB3aXRob3V0IHNwZWNpZmljIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbi4KKworVEhJUyBTT0ZUV0FSRSBJUyBQUk9WSURFRCBCWSBUSEUgQ09QWVJJR0hUIEhPTERFUlMgQU5EIENPTlRSSUJVVE9SUyAiQVMgSVMiCitBTkQgQU5ZIEVYUFJFU1MgT1IgSU1QTElFRCBXQVJSQU5USUVTLCBJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgVEhFCitJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQorQVJFIERJU0NMQUlNRUQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBDT1BZUklHSFQgT1dORVIgT1IgQ09OVFJJQlVUT1JTIEJFCitMSUFCTEUgRk9SIEFOWSBESVJFQ1QsIElORElSRUNULCBJTkNJREVOVEFMLCBTUEVDSUFMLCBFWEVNUExBUlksIE9SCitDT05TRVFVRU5USUFMIERBTUFHRVMgKElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBQUk9DVVJFTUVOVCBPRgorU1VCU1RJVFVURSBHT09EUyBPUiBTRVJWSUNFUzsgTE9TUyBPRiBVU0UsIERBVEEsIE9SIFBST0ZJVFM7IE9SIEJVU0lORVNTCitJTlRFUlJVUFRJT04pIEhPV0VWRVIgQ0FVU0VEIEFORCBPTiBBTlkgVEhFT1JZIE9GIExJQUJJTElUWSwgV0hFVEhFUiBJTgorQ09OVFJBQ1QsIFNUUklDVCBMSUFCSUxJVFksIE9SIFRPUlQgKElOQ0xVRElORyBORUdMSUdFTkNFIE9SIE9USEVSV0lTRSkKK0FSSVNJTkcgSU4gQU5ZIFdBWSBPVVQgT0YgVEhFIFVTRSBPRiBUSElTIFNPRlRXQVJFLCBFVkVOIElGIEFEVklTRUQgT0YKK1RIRSBQT1NTSUJJTElUWSBPRiBTVUNIIERBTUFHRS4KKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworVGhlIHNsZjRqLWFwaS0xLjUuMTEuamFyLCBzbGY0ai1qZGsxNC0xLjUuMTEuamFyLCBzbGY0ai1sb2c0ajEyLTEuNS4xMS5qYXIgYXJlIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBsaWNlbnNlOgorCisKK0NvcHlyaWdodCAoYykgMjAwNC0yMDA4IFFPUy5jaAorIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisKKyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlICBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nCisgYSAgY29weSAgb2YgdGhpcyAgc29mdHdhcmUgIGFuZCAgYXNzb2NpYXRlZCAgZG9jdW1lbnRhdGlvbiBmaWxlcyAgKHRoZQorICJTb2Z0d2FyZSIpLCB0byAgZGVhbCBpbiAgdGhlIFNvZnR3YXJlIHdpdGhvdXQgIHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcKKyB3aXRob3V0IGxpbWl0YXRpb24gIHRoZSByaWdodHMgdG8gIHVzZSwgY29weSwgbW9kaWZ5LCAgbWVyZ2UsIHB1Ymxpc2gsCisgZGlzdHJpYnV0ZSwgIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsICBjb3BpZXMgb2YgIHRoZSBTb2Z0d2FyZSwgIGFuZCB0bworIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlICBpcyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8KKyB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6CisgCisgVGhlICBhYm92ZSAgY29weXJpZ2h0ICBub3RpY2UgIGFuZCAgdGhpcyBwZXJtaXNzaW9uICBub3RpY2UgIHNoYWxsICBiZQorIGluY2x1ZGVkIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLgorIAorIFRIRSAgU09GVFdBUkUgSVMgIFBST1ZJREVEICAiQVMgIElTIiwgV0lUSE9VVCAgV0FSUkFOVFkgIE9GIEFOWSAgS0lORCwKKyBFWFBSRVNTIE9SICBJTVBMSUVELCBJTkNMVURJTkcgIEJVVCBOT1QgTElNSVRFRCAgVE8gVEhFICBXQVJSQU5USUVTIE9GCisgTUVSQ0hBTlRBQklMSVRZLCAgICBGSVRORVNTICAgIEZPUiAgICBBICAgUEFSVElDVUxBUiAgICBQVVJQT1NFICAgIEFORAorIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUKKyBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OCisgT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCAgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTgorIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitUaGUgdHVzY2FueS1ob3N0LXdlYmFwcCBhbmQgdHVzY2FueS1zY2EtYXBpIGphcnMgaW5jbHVkZSBmaWxlcyB1bmRlciB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6CisKK1Blcm1pc3Npb24gdG8gY29weSwgZGlzcGxheSBhbmQgZGlzdHJpYnV0ZSB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gYW5kL29yCitwb3J0aW9ucyB0aGVyZW9mLCB3aXRob3V0IG1vZGlmaWNhdGlvbiwgaW4gYW55IG1lZGl1bSB3aXRob3V0IGZlZSBvciByb3lhbHR5IGlzIGhlcmVieSBncmFudGVkLCBwcm92aWRlZAordGhhdCB5b3UgaW5jbHVkZSB0aGUgZm9sbG93aW5nIG9uIEFMTCBjb3BpZXMgb2YgdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uLCBvcgorcG9ydGlvbnMgdGhlcmVvZiwgdGhhdCB5b3UgbWFrZToKKworMS4gQSBsaW5rIG9yIFVSTCB0byB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gYXQgdGhpcyBsb2NhdGlvbjoKK++/vSBodHRwOi8vd3d3Lm9zb2Eub3JnL2Rpc3BsYXkvTWFpbi9TZXJ2aWNlK0NvbXBvbmVudCtBcmNoaXRlY3R1cmUrU3BlY2lmaWNhdGlvbnMKKworMi4gVGhlIGZ1bGwgdGV4dCBvZiB0aGUgY29weXJpZ2h0IG5vdGljZSBhcyBzaG93biBpbiB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24uCisKK0JFQSwgQ2FwZSBDbGVhciwgSUJNLCBJbnRlcmZhY2UyMSwgSU9OQSwgT3JhY2xlLCBQcmltZXRvbiwgUHJvZ3Jlc3MgU29mdHdhcmUsIFJlZCBIYXQsIFJvZ3VlIFdhdmUsCitTQVAsIFNpZW1lbnMsIFNvZnR3YXJlIEFHLiwgU3VuLCBTeWJhc2UsIFRJQkNPIChjb2xsZWN0aXZlbHksIHRoZSAiQXV0aG9ycyIpIGFncmVlIHRvIGdyYW50IHlvdSBhCityb3lhbHR5LWZyZWUgbGljZW5zZSwgdW5kZXIgcmVhc29uYWJsZSwgbm9uLWRpc2NyaW1pbmF0b3J5IHRlcm1zIGFuZCBjb25kaXRpb25zIHRvIHBhdGVudHMgdGhhdCB0aGV5IGRlZW0KK25lY2Vzc2FyeSB0byBpbXBsZW1lbnQgdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uLgorVEhFIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTUEVDSUZJQ0FUSU9OIElTIFBST1ZJREVEICJBUyBJUywiIEFORCBUSEUKK0FVVEhPUlMgTUFLRSBOTyBSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRVhQUkVTUyBPUiBJTVBMSUVELAorUkVHQVJESU5HIFRISVMgU1BFQ0lGSUNBVElPTiBBTkQgVEhFIElNUExFTUVOVEFUSU9OIE9GIElUUyBDT05URU5UUywKK0lOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQQorUEFSVElDVUxBUiBQVVJQT1NFLCBOT04tSU5GUklOR0VNRU5UIE9SIFRJVExFLgorVEhFIEFVVEhPUlMgV0lMTCBOT1QgQkUgTElBQkxFIEZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgU1BFQ0lBTCwgSU5DSURFTlRBTAorT1IgQ09OU0VRVUVOVElBTCBEQU1BR0VTIEFSSVNJTkcgT1VUIE9GIE9SIFJFTEFUSU5HIFRPIEFOWSBVU0UgT1IKK0RJU1RSSUJVVElPTiBPRiBUSEUgU2VydmljZSBDb21wb25lbnRzIEFyY2hpdGVjdHVyZSBTUEVDSUZJQ0FUSU9OLgorVGhlIG5hbWUgYW5kIHRyYWRlbWFya3Mgb2YgdGhlIEF1dGhvcnMgbWF5IE5PVCBiZSB1c2VkIGluIGFueSBtYW5uZXIsIGluY2x1ZGluZyBhZHZlcnRpc2luZyBvcgorcHVibGljaXR5IHBlcnRhaW5pbmcgdG8gdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uIG9yIGl0cyBjb250ZW50cyB3aXRob3V0IHNwZWNpZmljLAorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitUaGUgdHVzY2FueS1hc3NlbWJseS14c2QgamFyIGluY2x1ZGVzIGZpbGVzIHVuZGVyIHRoZSBmb2xsb3dpbmcgbGljZW5zZToKKworVzND77+9IFNPRlRXQVJFIE5PVElDRSBBTkQgTElDRU5TRQoraHR0cDovL3d3dy53My5vcmcvQ29uc29ydGl1bS9MZWdhbC8yMDAyL2NvcHlyaWdodC1zb2Z0d2FyZS0yMDAyMTIzMQorCitUaGlzIHdvcmsgKGFuZCBpbmNsdWRlZCBzb2Z0d2FyZSwgZG9jdW1lbnRhdGlvbiBzdWNoIGFzIFJFQURNRXMsIG9yIG90aGVyIHJlbGF0ZWQgaXRlbXMpIAoraXMgYmVpbmcgcHJvdmlkZWQgYnkgdGhlIGNvcHlyaWdodCBob2xkZXJzIHVuZGVyIHRoZSBmb2xsb3dpbmcgbGljZW5zZS4gQnkgb2J0YWluaW5nLCAKK3VzaW5nIGFuZC9vciBjb3B5aW5nIHRoaXMgd29yaywgeW91ICh0aGUgbGljZW5zZWUpIGFncmVlIHRoYXQgeW91IGhhdmUgcmVhZCwgdW5kZXJzdG9vZCwgCithbmQgd2lsbCBjb21wbHkgd2l0aCB0aGUgZm9sbG93aW5nIHRlcm1zIGFuZCBjb25kaXRpb25zLgorCitQZXJtaXNzaW9uIHRvIGNvcHksIG1vZGlmeSwgYW5kIGRpc3RyaWJ1dGUgdGhpcyBzb2Z0d2FyZSBhbmQgaXRzIGRvY3VtZW50YXRpb24sIHdpdGggb3IgCit3aXRob3V0IG1vZGlmaWNhdGlvbiwgZm9yIGFueSBwdXJwb3NlIGFuZCB3aXRob3V0IGZlZSBvciByb3lhbHR5IGlzIGhlcmVieSBncmFudGVkLCBwcm92aWRlZCAKK3RoYXQgeW91IGluY2x1ZGUgdGhlIGZvbGxvd2luZyBvbiBBTEwgY29waWVzIG9mIHRoZSBzb2Z0d2FyZSBhbmQgZG9jdW1lbnRhdGlvbiBvciBwb3J0aW9ucyAKK3RoZXJlb2YsIGluY2x1ZGluZyBtb2RpZmljYXRpb25zOgorCisgICAxLiBUaGUgZnVsbCB0ZXh0IG9mIHRoaXMgTk9USUNFIGluIGEgbG9jYXRpb24gdmlld2FibGUgdG8gdXNlcnMgb2YgdGhlIHJlZGlzdHJpYnV0ZWQgb3IgCisgICAgICBkZXJpdmF0aXZlIHdvcmsuCisgICAyLiBBbnkgcHJlLWV4aXN0aW5nIGludGVsbGVjdHVhbCBwcm9wZXJ0eSBkaXNjbGFpbWVycywgbm90aWNlcywgb3IgdGVybXMgYW5kIGNvbmRpdGlvbnMuIAorICAgICAgSWYgbm9uZSBleGlzdCwgdGhlIFczQyBTb2Z0d2FyZSBTaG9ydCBOb3RpY2Ugc2hvdWxkIGJlIGluY2x1ZGVkIChoeXBlcnRleHQgaXMgcHJlZmVycmVkLAorICAgICAgdGV4dCBpcyBwZXJtaXR0ZWQpIHdpdGhpbiB0aGUgYm9keSBvZiBhbnkgcmVkaXN0cmlidXRlZCBvciBkZXJpdmF0aXZlIGNvZGUuCisgICAzLiBOb3RpY2Ugb2YgYW55IGNoYW5nZXMgb3IgbW9kaWZpY2F0aW9ucyB0byB0aGUgZmlsZXMsIGluY2x1ZGluZyB0aGUgZGF0ZSBjaGFuZ2VzIHdlcmUgCisgICAgICBtYWRlLiAoV2UgcmVjb21tZW5kIHlvdSBwcm92aWRlIFVSSXMgdG8gdGhlIGxvY2F0aW9uIGZyb20gd2hpY2ggdGhlIGNvZGUgaXMgZGVyaXZlZC4pCisKK1RISVMgU09GVFdBUkUgQU5EIERPQ1VNRU5UQVRJT04gSVMgUFJPVklERUQgIkFTIElTLCIgQU5EIENPUFlSSUdIVCBIT0xERVJTIE1BS0UgTk8gCitSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPLCBXQVJSQU5USUVTIAorT0YgTUVSQ0hBTlRBQklMSVRZIE9SIEZJVE5FU1MgRk9SIEFOWSBQQVJUSUNVTEFSIFBVUlBPU0UgT1IgVEhBVCBUSEUgVVNFIE9GIFRIRSBTT0ZUV0FSRSBPUiAKK0RPQ1VNRU5UQVRJT04gV0lMTCBOT1QgSU5GUklOR0UgQU5ZIFRISVJEIFBBUlRZIFBBVEVOVFMsIENPUFlSSUdIVFMsIFRSQURFTUFSS1MgT1IgT1RIRVIgCitSSUdIVFMuCisKK0NPUFlSSUdIVCBIT0xERVJTIFdJTEwgTk9UIEJFIExJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIFNQRUNJQUwgT1IgQ09OU0VRVUVOVElBTCAKK0RBTUFHRVMgQVJJU0lORyBPVVQgT0YgQU5ZIFVTRSBPRiBUSEUgU09GVFdBUkUgT1IgRE9DVU1FTlRBVElPTi4KKworVGhlIG5hbWUgYW5kIHRyYWRlbWFya3Mgb2YgY29weXJpZ2h0IGhvbGRlcnMgbWF5IE5PVCBiZSB1c2VkIGluIGFkdmVydGlzaW5nIG9yIHB1YmxpY2l0eSAKK3BlcnRhaW5pbmcgdG8gdGhlIHNvZnR3YXJlIHdpdGhvdXQgc3BlY2lmaWMsIHdyaXR0ZW4gcHJpb3IgcGVybWlzc2lvbi4gVGl0bGUgdG8gY29weXJpZ2h0IAoraW4gdGhpcyBzb2Z0d2FyZSBhbmQgYW55IGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiB3aWxsIGF0IGFsbCB0aW1lcyByZW1haW4gd2l0aCBjb3B5cmlnaHQgCitob2xkZXJzLgorCmRpZmYgLS1naXQgYS9waG90YXJrLWFwcGVuZ2luZS13ZWJhcHAvd2FyL01FVEEtSU5GL05PVElDRSBiL3Bob3RhcmstYXBwZW5naW5lLXdlYmFwcC93YXIvTUVUQS1JTkYvTk9USUNFCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAuLmJlNzk5NzAKLS0tIC9kZXYvbnVsbAorKysgYi9waG90YXJrLWFwcGVuZ2luZS13ZWJhcHAvd2FyL01FVEEtSU5GL05PVElDRQpAQCAtMCwwICsxLDUyIEBACitBcGFjaGUgUGhvdEFyaworQ29weXJpZ2h0IChjKSAyMDA4IC0gMjAxMCBUaGUgQXBhY2hlIFNvZnR3YXJlIEZvdW5kYXRpb24KKworVGhpcyBwcm9kdWN0IGluY2x1ZGVzIHNvZnR3YXJlIGRldmVsb3BlZCBhdAorVGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChodHRwOi8vd3d3LmFwYWNoZS5vcmcvKS4KKworVGhpcyBwcm9kdWN0IGluY2x1ZGVzL3VzZXMgWG1sU2NoZW1hIGRldmVsb3BlZCBhdCAKK1RoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoaHR0cDovL3dzLmFwYWNoZS5vcmcvY29tbW9ucy9YbWxTY2hlbWEpCisgUG9ydGlvbnMgQ29weXJpZ2h0IDIwMDYgSW50ZXJuYXRpb25hbCBCdXNpbmVzcyBNYWNoaW5lcyBDb3JwLgorCitUaGlzIHNvZnR3YXJlIGNvbnRhaW5zIFNMRjRKIGxpYnJhcmllcy4gQ29weXJpZ2h0IChjKSAyMDA0LTIwMDggUU9TLmNoCisKK1RoaXMgcHJvZHVjdCBpbmNsdWRlcy91c2VzIHNvZnR3YXJlLCBBT1AgYWxsaWFuY2UgKGh0dHA6Ly9hb3BhbGxpYW5jZS5zb3VyY2Vmb3JnZS5uZXQpCitMaWNlbnNlOiBQdWJsaWMgRG9tYWluIAorCitUaGlzIHByb2R1Y3QgaW5jbHVkZXMvdXNlcyBKU09OLVJQQy1KYXZhIChodHRwOi8vb3NzLm1ldGFwYXJhZGlnbS5jb20vanNvbnJwYy8pCisKK1RoaXMgcHJvZHVjdCBpbmNsdWRlcyBzb2Z0d2FyZSBmcm9tIHRoZSBHbGFzc0Zpc2ggcHJvamVjdCAoaHR0cHM6Ly9nbGFzc2Zpc2guZGV2LmphdmEubmV0LykKKyAgICBDb3B5cmlnaHQgKGMpIDIwMDYsIFN1biBNaWNyb3N5c3RlbXMsIEluYy4KKyAgICAgIAorVGhpcyBwcm9kdWN0IGluY2x1ZGVzL3VzZXMgZG9qb3Rvb2xraXQgKGh0dHA6Ly9kb2pvdG9vbGtpdC5vcmcvKQorIENvcHlyaWdodCAoYykgMjAwNSwgVGhlIERvam8gRm91bmRhdGlvbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC4KKworVGhpcyBwcm9kdWN0IGFsc28gaW5jbHVkZXMgc29mdHdhcmUgdW5kZXIgdGhlIEJTRCBsaWNlbnNlCit3aXRoIHRoZSBmb2xsb3dpbmcgY29weXJpZ2h0OgorIENvcHlyaWdodCAoYykgMjAwNiwgU3VuIE1pY3Jvc3lzdGVtcywgSW5jLiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIHNwZWNpZmljYXRpb24gbGljZW5zZQorKHNlZSB0aGUgTElDRU5TRSBmaWxlIGNvbnRhaW5lZCBpbiB0aGlzIGRpc3RyaWJ1dGlvbikgd2l0aCB0aGUgZm9sbG93aW5nIGNvcHlyaWdodAorCisoQykgQ29weXJpZ2h0IEJFQSBTeXN0ZW1zLCBJbmMuLCBDYXBlIENsZWFyIFNvZnR3YXJlLCBJbnRlcm5hdGlvbmFsIEJ1c2luZXNzIE1hY2hpbmVzIENvcnAsIEludGVyZmFjZTIxLCBJT05BIFRlY2hub2xvZ2llcywKKzM3IE9yYWNsZSwgUHJpbWV0b24gVGVjaG5vbG9naWVzLCBQcm9ncmVzcyBTb2Z0d2FyZSwgUmVkIEhhdCwgUm9ndWUgV2F2ZSBTb2Z0d2FyZSwgU0FQIEFHLiwgU2llbWVucyBBRy4sIFNvZnR3YXJlIEFHLiwgU3liYXNlCiszOCBJbmMuLCBUSUJDTyBTb2Z0d2FyZSBJbmMuLCAyMDA1LCAyMDA3LiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIHNwZWNpZmljYXRpb24gbGljZW5zZQorKHNlZSB0aGUgTElDRU5TRSBmaWxlIGNvbnRhaW5lZCBpbiB0aGlzIGRpc3RyaWJ1dGlvbikgd2l0aCB0aGUgZm9sbG93aW5nIGNvcHlyaWdodAorCisoQykgQ29weXJpZ2h0IEJFQSBTeXN0ZW1zLCBJbmMuLCBDYXBlIENsZWFyIFNvZnR3YXJlLCBJbnRlcm5hdGlvbmFsIEJ1c2luZXNzIE1hY2hpbmVzIENvcnAsIEludGVyZmFjZTIxLCBJT05BCitUZWNobm9sb2dpZXMsIE9yYWNsZSwgUHJpbWV0b24gVGVjaG5vbG9naWVzLCBQcm9ncmVzcyBTb2Z0d2FyZSwgUmVkIEhhdCwgUm9ndWUgV2F2ZSBTb2Z0d2FyZSwgU0FQIEFHLiwgU2llbWVucworQUcuLCBTb2Z0d2FyZSBBRy4sIFN1biBNaWNyb3N5c3RlbXMsIEluYy4sIFN5YmFzZSBJbmMuLCBUSUJDTyBTb2Z0d2FyZSBJbmMuLCAyMDA1LCAyMDA4LiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgVzNDKHIpIFNvZnR3YXJlIExpY2Vuc2UKKyhzZWUgdGhlIExJQ0VOU0UgZmlsZSBjb250YWluZWQgaW4gdGhpcyBkaXN0cmlidXRpb24pLCB3aXRoIHRoZSBmb2xsb3dpbmcKK2NvcHlyaWdodDoKKworQ29weXJpZ2h0IChjKSAyMDA0IFdvcmxkIFdpZGUgV2ViIENvbnNvcnRpdW0gKE1hc3NhY2h1c2V0dHMgSW5zdGl0dXRlIG9mIFRlY2hub2xvZ3ksIAorRXVyb3BlYW4gUmVzZWFyY2ggQ29uc29ydGl1bSBmb3IgSW5mb3JtYXRpY3MgYW5kIE1hdGhlbWF0aWNzLCBLZWlvIFVuaXZlcnNpdHkpLiAKK0FsbCBSaWdodHMgUmVzZXJ2ZWQuIFRoaXMgd29yayBpcyBkaXN0cmlidXRlZCB1bmRlciB0aGUgVzNDKHIpIFNvZnR3YXJlIExpY2Vuc2UgWzFdIAoraW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwgYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgCit3YXJyYW50eSBvZiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCisKKyAgICBbMV0gaHR0cDovL3d3dy53My5vcmcvQ29uc29ydGl1bS9MZWdhbC8yMDAyL2NvcHlyaWdodC1zb2Z0d2FyZS0yMDAyMTIzMQpkaWZmIC0tZ2l0IGEvcGhvdGFyay13ZWJhcHAvc3JjL21haW4vd2ViYXBwL01FVEEtSU5GL0xJQ0VOU0UgYi9waG90YXJrLXdlYmFwcC9zcmMvbWFpbi93ZWJhcHAvTUVUQS1JTkYvTElDRU5TRQpuZXcgZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwLi5hNGE3MGM3Ci0tLSAvZGV2L251bGwKKysrIGIvcGhvdGFyay13ZWJhcHAvc3JjL21haW4vd2ViYXBwL01FVEEtSU5GL0xJQ0VOU0UKQEAgLTAsMCArMSwxMjU1IEBACisKKyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFwYWNoZSBMaWNlbnNlCisgICAgICAgICAgICAgICAgICAgICAgICAgICBWZXJzaW9uIDIuMCwgSmFudWFyeSAyMDA0CisgICAgICAgICAgICAgICAgICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvCisKKyAgIFRFUk1TIEFORCBDT05ESVRJT05TIEZPUiBVU0UsIFJFUFJPRFVDVElPTiwgQU5EIERJU1RSSUJVVElPTgorCisgICAxLiBEZWZpbml0aW9ucy4KKworICAgICAgIkxpY2Vuc2UiIHNoYWxsIG1lYW4gdGhlIHRlcm1zIGFuZCBjb25kaXRpb25zIGZvciB1c2UsIHJlcHJvZHVjdGlvbiwKKyAgICAgIGFuZCBkaXN0cmlidXRpb24gYXMgZGVmaW5lZCBieSBTZWN0aW9ucyAxIHRocm91Z2ggOSBvZiB0aGlzIGRvY3VtZW50LgorCisgICAgICAiTGljZW5zb3IiIHNoYWxsIG1lYW4gdGhlIGNvcHlyaWdodCBvd25lciBvciBlbnRpdHkgYXV0aG9yaXplZCBieQorICAgICAgdGhlIGNvcHlyaWdodCBvd25lciB0aGF0IGlzIGdyYW50aW5nIHRoZSBMaWNlbnNlLgorCisgICAgICAiTGVnYWwgRW50aXR5IiBzaGFsbCBtZWFuIHRoZSB1bmlvbiBvZiB0aGUgYWN0aW5nIGVudGl0eSBhbmQgYWxsCisgICAgICBvdGhlciBlbnRpdGllcyB0aGF0IGNvbnRyb2wsIGFyZSBjb250cm9sbGVkIGJ5LCBvciBhcmUgdW5kZXIgY29tbW9uCisgICAgICBjb250cm9sIHdpdGggdGhhdCBlbnRpdHkuIEZvciB0aGUgcHVycG9zZXMgb2YgdGhpcyBkZWZpbml0aW9uLAorICAgICAgImNvbnRyb2wiIG1lYW5zIChpKSB0aGUgcG93ZXIsIGRpcmVjdCBvciBpbmRpcmVjdCwgdG8gY2F1c2UgdGhlCisgICAgICBkaXJlY3Rpb24gb3IgbWFuYWdlbWVudCBvZiBzdWNoIGVudGl0eSwgd2hldGhlciBieSBjb250cmFjdCBvcgorICAgICAgb3RoZXJ3aXNlLCBvciAoaWkpIG93bmVyc2hpcCBvZiBmaWZ0eSBwZXJjZW50ICg1MCUpIG9yIG1vcmUgb2YgdGhlCisgICAgICBvdXRzdGFuZGluZyBzaGFyZXMsIG9yIChpaWkpIGJlbmVmaWNpYWwgb3duZXJzaGlwIG9mIHN1Y2ggZW50aXR5LgorCisgICAgICAiWW91IiAob3IgIllvdXIiKSBzaGFsbCBtZWFuIGFuIGluZGl2aWR1YWwgb3IgTGVnYWwgRW50aXR5CisgICAgICBleGVyY2lzaW5nIHBlcm1pc3Npb25zIGdyYW50ZWQgYnkgdGhpcyBMaWNlbnNlLgorCisgICAgICAiU291cmNlIiBmb3JtIHNoYWxsIG1lYW4gdGhlIHByZWZlcnJlZCBmb3JtIGZvciBtYWtpbmcgbW9kaWZpY2F0aW9ucywKKyAgICAgIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gc29mdHdhcmUgc291cmNlIGNvZGUsIGRvY3VtZW50YXRpb24KKyAgICAgIHNvdXJjZSwgYW5kIGNvbmZpZ3VyYXRpb24gZmlsZXMuCisKKyAgICAgICJPYmplY3QiIGZvcm0gc2hhbGwgbWVhbiBhbnkgZm9ybSByZXN1bHRpbmcgZnJvbSBtZWNoYW5pY2FsCisgICAgICB0cmFuc2Zvcm1hdGlvbiBvciB0cmFuc2xhdGlvbiBvZiBhIFNvdXJjZSBmb3JtLCBpbmNsdWRpbmcgYnV0CisgICAgICBub3QgbGltaXRlZCB0byBjb21waWxlZCBvYmplY3QgY29kZSwgZ2VuZXJhdGVkIGRvY3VtZW50YXRpb24sCisgICAgICBhbmQgY29udmVyc2lvbnMgdG8gb3RoZXIgbWVkaWEgdHlwZXMuCisKKyAgICAgICJXb3JrIiBzaGFsbCBtZWFuIHRoZSB3b3JrIG9mIGF1dGhvcnNoaXAsIHdoZXRoZXIgaW4gU291cmNlIG9yCisgICAgICBPYmplY3QgZm9ybSwgbWFkZSBhdmFpbGFibGUgdW5kZXIgdGhlIExpY2Vuc2UsIGFzIGluZGljYXRlZCBieSBhCisgICAgICBjb3B5cmlnaHQgbm90aWNlIHRoYXQgaXMgaW5jbHVkZWQgaW4gb3IgYXR0YWNoZWQgdG8gdGhlIHdvcmsKKyAgICAgIChhbiBleGFtcGxlIGlzIHByb3ZpZGVkIGluIHRoZSBBcHBlbmRpeCBiZWxvdykuCisKKyAgICAgICJEZXJpdmF0aXZlIFdvcmtzIiBzaGFsbCBtZWFuIGFueSB3b3JrLCB3aGV0aGVyIGluIFNvdXJjZSBvciBPYmplY3QKKyAgICAgIGZvcm0sIHRoYXQgaXMgYmFzZWQgb24gKG9yIGRlcml2ZWQgZnJvbSkgdGhlIFdvcmsgYW5kIGZvciB3aGljaCB0aGUKKyAgICAgIGVkaXRvcmlhbCByZXZpc2lvbnMsIGFubm90YXRpb25zLCBlbGFib3JhdGlvbnMsIG9yIG90aGVyIG1vZGlmaWNhdGlvbnMKKyAgICAgIHJlcHJlc2VudCwgYXMgYSB3aG9sZSwgYW4gb3JpZ2luYWwgd29yayBvZiBhdXRob3JzaGlwLiBGb3IgdGhlIHB1cnBvc2VzCisgICAgICBvZiB0aGlzIExpY2Vuc2UsIERlcml2YXRpdmUgV29ya3Mgc2hhbGwgbm90IGluY2x1ZGUgd29ya3MgdGhhdCByZW1haW4KKyAgICAgIHNlcGFyYWJsZSBmcm9tLCBvciBtZXJlbHkgbGluayAob3IgYmluZCBieSBuYW1lKSB0byB0aGUgaW50ZXJmYWNlcyBvZiwKKyAgICAgIHRoZSBXb3JrIGFuZCBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YuCisKKyAgICAgICJDb250cmlidXRpb24iIHNoYWxsIG1lYW4gYW55IHdvcmsgb2YgYXV0aG9yc2hpcCwgaW5jbHVkaW5nCisgICAgICB0aGUgb3JpZ2luYWwgdmVyc2lvbiBvZiB0aGUgV29yayBhbmQgYW55IG1vZGlmaWNhdGlvbnMgb3IgYWRkaXRpb25zCisgICAgICB0byB0aGF0IFdvcmsgb3IgRGVyaXZhdGl2ZSBXb3JrcyB0aGVyZW9mLCB0aGF0IGlzIGludGVudGlvbmFsbHkKKyAgICAgIHN1Ym1pdHRlZCB0byBMaWNlbnNvciBmb3IgaW5jbHVzaW9uIGluIHRoZSBXb3JrIGJ5IHRoZSBjb3B5cmlnaHQgb3duZXIKKyAgICAgIG9yIGJ5IGFuIGluZGl2aWR1YWwgb3IgTGVnYWwgRW50aXR5IGF1dGhvcml6ZWQgdG8gc3VibWl0IG9uIGJlaGFsZiBvZgorICAgICAgdGhlIGNvcHlyaWdodCBvd25lci4gRm9yIHRoZSBwdXJwb3NlcyBvZiB0aGlzIGRlZmluaXRpb24sICJzdWJtaXR0ZWQiCisgICAgICBtZWFucyBhbnkgZm9ybSBvZiBlbGVjdHJvbmljLCB2ZXJiYWwsIG9yIHdyaXR0ZW4gY29tbXVuaWNhdGlvbiBzZW50CisgICAgICB0byB0aGUgTGljZW5zb3Igb3IgaXRzIHJlcHJlc2VudGF0aXZlcywgaW5jbHVkaW5nIGJ1dCBub3QgbGltaXRlZCB0bworICAgICAgY29tbXVuaWNhdGlvbiBvbiBlbGVjdHJvbmljIG1haWxpbmcgbGlzdHMsIHNvdXJjZSBjb2RlIGNvbnRyb2wgc3lzdGVtcywKKyAgICAgIGFuZCBpc3N1ZSB0cmFja2luZyBzeXN0ZW1zIHRoYXQgYXJlIG1hbmFnZWQgYnksIG9yIG9uIGJlaGFsZiBvZiwgdGhlCisgICAgICBMaWNlbnNvciBmb3IgdGhlIHB1cnBvc2Ugb2YgZGlzY3Vzc2luZyBhbmQgaW1wcm92aW5nIHRoZSBXb3JrLCBidXQKKyAgICAgIGV4Y2x1ZGluZyBjb21tdW5pY2F0aW9uIHRoYXQgaXMgY29uc3BpY3VvdXNseSBtYXJrZWQgb3Igb3RoZXJ3aXNlCisgICAgICBkZXNpZ25hdGVkIGluIHdyaXRpbmcgYnkgdGhlIGNvcHlyaWdodCBvd25lciBhcyAiTm90IGEgQ29udHJpYnV0aW9uLiIKKworICAgICAgIkNvbnRyaWJ1dG9yIiBzaGFsbCBtZWFuIExpY2Vuc29yIGFuZCBhbnkgaW5kaXZpZHVhbCBvciBMZWdhbCBFbnRpdHkKKyAgICAgIG9uIGJlaGFsZiBvZiB3aG9tIGEgQ29udHJpYnV0aW9uIGhhcyBiZWVuIHJlY2VpdmVkIGJ5IExpY2Vuc29yIGFuZAorICAgICAgc3Vic2VxdWVudGx5IGluY29ycG9yYXRlZCB3aXRoaW4gdGhlIFdvcmsuCisKKyAgIDIuIEdyYW50IG9mIENvcHlyaWdodCBMaWNlbnNlLiBTdWJqZWN0IHRvIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZgorICAgICAgdGhpcyBMaWNlbnNlLCBlYWNoIENvbnRyaWJ1dG9yIGhlcmVieSBncmFudHMgdG8gWW91IGEgcGVycGV0dWFsLAorICAgICAgd29ybGR3aWRlLCBub24tZXhjbHVzaXZlLCBuby1jaGFyZ2UsIHJveWFsdHktZnJlZSwgaXJyZXZvY2FibGUKKyAgICAgIGNvcHlyaWdodCBsaWNlbnNlIHRvIHJlcHJvZHVjZSwgcHJlcGFyZSBEZXJpdmF0aXZlIFdvcmtzIG9mLAorICAgICAgcHVibGljbHkgZGlzcGxheSwgcHVibGljbHkgcGVyZm9ybSwgc3VibGljZW5zZSwgYW5kIGRpc3RyaWJ1dGUgdGhlCisgICAgICBXb3JrIGFuZCBzdWNoIERlcml2YXRpdmUgV29ya3MgaW4gU291cmNlIG9yIE9iamVjdCBmb3JtLgorCisgICAzLiBHcmFudCBvZiBQYXRlbnQgTGljZW5zZS4gU3ViamVjdCB0byB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YKKyAgICAgIHRoaXMgTGljZW5zZSwgZWFjaCBDb250cmlidXRvciBoZXJlYnkgZ3JhbnRzIHRvIFlvdSBhIHBlcnBldHVhbCwKKyAgICAgIHdvcmxkd2lkZSwgbm9uLWV4Y2x1c2l2ZSwgbm8tY2hhcmdlLCByb3lhbHR5LWZyZWUsIGlycmV2b2NhYmxlCisgICAgICAoZXhjZXB0IGFzIHN0YXRlZCBpbiB0aGlzIHNlY3Rpb24pIHBhdGVudCBsaWNlbnNlIHRvIG1ha2UsIGhhdmUgbWFkZSwKKyAgICAgIHVzZSwgb2ZmZXIgdG8gc2VsbCwgc2VsbCwgaW1wb3J0LCBhbmQgb3RoZXJ3aXNlIHRyYW5zZmVyIHRoZSBXb3JrLAorICAgICAgd2hlcmUgc3VjaCBsaWNlbnNlIGFwcGxpZXMgb25seSB0byB0aG9zZSBwYXRlbnQgY2xhaW1zIGxpY2Vuc2FibGUKKyAgICAgIGJ5IHN1Y2ggQ29udHJpYnV0b3IgdGhhdCBhcmUgbmVjZXNzYXJpbHkgaW5mcmluZ2VkIGJ5IHRoZWlyCisgICAgICBDb250cmlidXRpb24ocykgYWxvbmUgb3IgYnkgY29tYmluYXRpb24gb2YgdGhlaXIgQ29udHJpYnV0aW9uKHMpCisgICAgICB3aXRoIHRoZSBXb3JrIHRvIHdoaWNoIHN1Y2ggQ29udHJpYnV0aW9uKHMpIHdhcyBzdWJtaXR0ZWQuIElmIFlvdQorICAgICAgaW5zdGl0dXRlIHBhdGVudCBsaXRpZ2F0aW9uIGFnYWluc3QgYW55IGVudGl0eSAoaW5jbHVkaW5nIGEKKyAgICAgIGNyb3NzLWNsYWltIG9yIGNvdW50ZXJjbGFpbSBpbiBhIGxhd3N1aXQpIGFsbGVnaW5nIHRoYXQgdGhlIFdvcmsKKyAgICAgIG9yIGEgQ29udHJpYnV0aW9uIGluY29ycG9yYXRlZCB3aXRoaW4gdGhlIFdvcmsgY29uc3RpdHV0ZXMgZGlyZWN0CisgICAgICBvciBjb250cmlidXRvcnkgcGF0ZW50IGluZnJpbmdlbWVudCwgdGhlbiBhbnkgcGF0ZW50IGxpY2Vuc2VzCisgICAgICBncmFudGVkIHRvIFlvdSB1bmRlciB0aGlzIExpY2Vuc2UgZm9yIHRoYXQgV29yayBzaGFsbCB0ZXJtaW5hdGUKKyAgICAgIGFzIG9mIHRoZSBkYXRlIHN1Y2ggbGl0aWdhdGlvbiBpcyBmaWxlZC4KKworICAgNC4gUmVkaXN0cmlidXRpb24uIFlvdSBtYXkgcmVwcm9kdWNlIGFuZCBkaXN0cmlidXRlIGNvcGllcyBvZiB0aGUKKyAgICAgIFdvcmsgb3IgRGVyaXZhdGl2ZSBXb3JrcyB0aGVyZW9mIGluIGFueSBtZWRpdW0sIHdpdGggb3Igd2l0aG91dAorICAgICAgbW9kaWZpY2F0aW9ucywgYW5kIGluIFNvdXJjZSBvciBPYmplY3QgZm9ybSwgcHJvdmlkZWQgdGhhdCBZb3UKKyAgICAgIG1lZXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOgorCisgICAgICAoYSkgWW91IG11c3QgZ2l2ZSBhbnkgb3RoZXIgcmVjaXBpZW50cyBvZiB0aGUgV29yayBvcgorICAgICAgICAgIERlcml2YXRpdmUgV29ya3MgYSBjb3B5IG9mIHRoaXMgTGljZW5zZTsgYW5kCisKKyAgICAgIChiKSBZb3UgbXVzdCBjYXVzZSBhbnkgbW9kaWZpZWQgZmlsZXMgdG8gY2FycnkgcHJvbWluZW50IG5vdGljZXMKKyAgICAgICAgICBzdGF0aW5nIHRoYXQgWW91IGNoYW5nZWQgdGhlIGZpbGVzOyBhbmQKKworICAgICAgKGMpIFlvdSBtdXN0IHJldGFpbiwgaW4gdGhlIFNvdXJjZSBmb3JtIG9mIGFueSBEZXJpdmF0aXZlIFdvcmtzCisgICAgICAgICAgdGhhdCBZb3UgZGlzdHJpYnV0ZSwgYWxsIGNvcHlyaWdodCwgcGF0ZW50LCB0cmFkZW1hcmssIGFuZAorICAgICAgICAgIGF0dHJpYnV0aW9uIG5vdGljZXMgZnJvbSB0aGUgU291cmNlIGZvcm0gb2YgdGhlIFdvcmssCisgICAgICAgICAgZXhjbHVkaW5nIHRob3NlIG5vdGljZXMgdGhhdCBkbyBub3QgcGVydGFpbiB0byBhbnkgcGFydCBvZgorICAgICAgICAgIHRoZSBEZXJpdmF0aXZlIFdvcmtzOyBhbmQKKworICAgICAgKGQpIElmIHRoZSBXb3JrIGluY2x1ZGVzIGEgIk5PVElDRSIgdGV4dCBmaWxlIGFzIHBhcnQgb2YgaXRzCisgICAgICAgICAgZGlzdHJpYnV0aW9uLCB0aGVuIGFueSBEZXJpdmF0aXZlIFdvcmtzIHRoYXQgWW91IGRpc3RyaWJ1dGUgbXVzdAorICAgICAgICAgIGluY2x1ZGUgYSByZWFkYWJsZSBjb3B5IG9mIHRoZSBhdHRyaWJ1dGlvbiBub3RpY2VzIGNvbnRhaW5lZAorICAgICAgICAgIHdpdGhpbiBzdWNoIE5PVElDRSBmaWxlLCBleGNsdWRpbmcgdGhvc2Ugbm90aWNlcyB0aGF0IGRvIG5vdAorICAgICAgICAgIHBlcnRhaW4gdG8gYW55IHBhcnQgb2YgdGhlIERlcml2YXRpdmUgV29ya3MsIGluIGF0IGxlYXN0IG9uZQorICAgICAgICAgIG9mIHRoZSBmb2xsb3dpbmcgcGxhY2VzOiB3aXRoaW4gYSBOT1RJQ0UgdGV4dCBmaWxlIGRpc3RyaWJ1dGVkCisgICAgICAgICAgYXMgcGFydCBvZiB0aGUgRGVyaXZhdGl2ZSBXb3Jrczsgd2l0aGluIHRoZSBTb3VyY2UgZm9ybSBvcgorICAgICAgICAgIGRvY3VtZW50YXRpb24sIGlmIHByb3ZpZGVkIGFsb25nIHdpdGggdGhlIERlcml2YXRpdmUgV29ya3M7IG9yLAorICAgICAgICAgIHdpdGhpbiBhIGRpc3BsYXkgZ2VuZXJhdGVkIGJ5IHRoZSBEZXJpdmF0aXZlIFdvcmtzLCBpZiBhbmQKKyAgICAgICAgICB3aGVyZXZlciBzdWNoIHRoaXJkLXBhcnR5IG5vdGljZXMgbm9ybWFsbHkgYXBwZWFyLiBUaGUgY29udGVudHMKKyAgICAgICAgICBvZiB0aGUgTk9USUNFIGZpbGUgYXJlIGZvciBpbmZvcm1hdGlvbmFsIHB1cnBvc2VzIG9ubHkgYW5kCisgICAgICAgICAgZG8gbm90IG1vZGlmeSB0aGUgTGljZW5zZS4gWW91IG1heSBhZGQgWW91ciBvd24gYXR0cmlidXRpb24KKyAgICAgICAgICBub3RpY2VzIHdpdGhpbiBEZXJpdmF0aXZlIFdvcmtzIHRoYXQgWW91IGRpc3RyaWJ1dGUsIGFsb25nc2lkZQorICAgICAgICAgIG9yIGFzIGFuIGFkZGVuZHVtIHRvIHRoZSBOT1RJQ0UgdGV4dCBmcm9tIHRoZSBXb3JrLCBwcm92aWRlZAorICAgICAgICAgIHRoYXQgc3VjaCBhZGRpdGlvbmFsIGF0dHJpYnV0aW9uIG5vdGljZXMgY2Fubm90IGJlIGNvbnN0cnVlZAorICAgICAgICAgIGFzIG1vZGlmeWluZyB0aGUgTGljZW5zZS4KKworICAgICAgWW91IG1heSBhZGQgWW91ciBvd24gY29weXJpZ2h0IHN0YXRlbWVudCB0byBZb3VyIG1vZGlmaWNhdGlvbnMgYW5kCisgICAgICBtYXkgcHJvdmlkZSBhZGRpdGlvbmFsIG9yIGRpZmZlcmVudCBsaWNlbnNlIHRlcm1zIGFuZCBjb25kaXRpb25zCisgICAgICBmb3IgdXNlLCByZXByb2R1Y3Rpb24sIG9yIGRpc3RyaWJ1dGlvbiBvZiBZb3VyIG1vZGlmaWNhdGlvbnMsIG9yCisgICAgICBmb3IgYW55IHN1Y2ggRGVyaXZhdGl2ZSBXb3JrcyBhcyBhIHdob2xlLCBwcm92aWRlZCBZb3VyIHVzZSwKKyAgICAgIHJlcHJvZHVjdGlvbiwgYW5kIGRpc3RyaWJ1dGlvbiBvZiB0aGUgV29yayBvdGhlcndpc2UgY29tcGxpZXMgd2l0aAorICAgICAgdGhlIGNvbmRpdGlvbnMgc3RhdGVkIGluIHRoaXMgTGljZW5zZS4KKworICAgNS4gU3VibWlzc2lvbiBvZiBDb250cmlidXRpb25zLiBVbmxlc3MgWW91IGV4cGxpY2l0bHkgc3RhdGUgb3RoZXJ3aXNlLAorICAgICAgYW55IENvbnRyaWJ1dGlvbiBpbnRlbnRpb25hbGx5IHN1Ym1pdHRlZCBmb3IgaW5jbHVzaW9uIGluIHRoZSBXb3JrCisgICAgICBieSBZb3UgdG8gdGhlIExpY2Vuc29yIHNoYWxsIGJlIHVuZGVyIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZgorICAgICAgdGhpcyBMaWNlbnNlLCB3aXRob3V0IGFueSBhZGRpdGlvbmFsIHRlcm1zIG9yIGNvbmRpdGlvbnMuCisgICAgICBOb3R3aXRoc3RhbmRpbmcgdGhlIGFib3ZlLCBub3RoaW5nIGhlcmVpbiBzaGFsbCBzdXBlcnNlZGUgb3IgbW9kaWZ5CisgICAgICB0aGUgdGVybXMgb2YgYW55IHNlcGFyYXRlIGxpY2Vuc2UgYWdyZWVtZW50IHlvdSBtYXkgaGF2ZSBleGVjdXRlZAorICAgICAgd2l0aCBMaWNlbnNvciByZWdhcmRpbmcgc3VjaCBDb250cmlidXRpb25zLgorCisgICA2LiBUcmFkZW1hcmtzLiBUaGlzIExpY2Vuc2UgZG9lcyBub3QgZ3JhbnQgcGVybWlzc2lvbiB0byB1c2UgdGhlIHRyYWRlCisgICAgICBuYW1lcywgdHJhZGVtYXJrcywgc2VydmljZSBtYXJrcywgb3IgcHJvZHVjdCBuYW1lcyBvZiB0aGUgTGljZW5zb3IsCisgICAgICBleGNlcHQgYXMgcmVxdWlyZWQgZm9yIHJlYXNvbmFibGUgYW5kIGN1c3RvbWFyeSB1c2UgaW4gZGVzY3JpYmluZyB0aGUKKyAgICAgIG9yaWdpbiBvZiB0aGUgV29yayBhbmQgcmVwcm9kdWNpbmcgdGhlIGNvbnRlbnQgb2YgdGhlIE5PVElDRSBmaWxlLgorCisgICA3LiBEaXNjbGFpbWVyIG9mIFdhcnJhbnR5LiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IKKyAgICAgIGFncmVlZCB0byBpbiB3cml0aW5nLCBMaWNlbnNvciBwcm92aWRlcyB0aGUgV29yayAoYW5kIGVhY2gKKyAgICAgIENvbnRyaWJ1dG9yIHByb3ZpZGVzIGl0cyBDb250cmlidXRpb25zKSBvbiBhbiAiQVMgSVMiIEJBU0lTLAorICAgICAgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yCisgICAgICBpbXBsaWVkLCBpbmNsdWRpbmcsIHdpdGhvdXQgbGltaXRhdGlvbiwgYW55IHdhcnJhbnRpZXMgb3IgY29uZGl0aW9ucworICAgICAgb2YgVElUTEUsIE5PTi1JTkZSSU5HRU1FTlQsIE1FUkNIQU5UQUJJTElUWSwgb3IgRklUTkVTUyBGT1IgQQorICAgICAgUEFSVElDVUxBUiBQVVJQT1NFLiBZb3UgYXJlIHNvbGVseSByZXNwb25zaWJsZSBmb3IgZGV0ZXJtaW5pbmcgdGhlCisgICAgICBhcHByb3ByaWF0ZW5lc3Mgb2YgdXNpbmcgb3IgcmVkaXN0cmlidXRpbmcgdGhlIFdvcmsgYW5kIGFzc3VtZSBhbnkKKyAgICAgIHJpc2tzIGFzc29jaWF0ZWQgd2l0aCBZb3VyIGV4ZXJjaXNlIG9mIHBlcm1pc3Npb25zIHVuZGVyIHRoaXMgTGljZW5zZS4KKworICAgOC4gTGltaXRhdGlvbiBvZiBMaWFiaWxpdHkuIEluIG5vIGV2ZW50IGFuZCB1bmRlciBubyBsZWdhbCB0aGVvcnksCisgICAgICB3aGV0aGVyIGluIHRvcnQgKGluY2x1ZGluZyBuZWdsaWdlbmNlKSwgY29udHJhY3QsIG9yIG90aGVyd2lzZSwKKyAgICAgIHVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyAoc3VjaCBhcyBkZWxpYmVyYXRlIGFuZCBncm9zc2x5CisgICAgICBuZWdsaWdlbnQgYWN0cykgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNoYWxsIGFueSBDb250cmlidXRvciBiZQorICAgICAgbGlhYmxlIHRvIFlvdSBmb3IgZGFtYWdlcywgaW5jbHVkaW5nIGFueSBkaXJlY3QsIGluZGlyZWN0LCBzcGVjaWFsLAorICAgICAgaW5jaWRlbnRhbCwgb3IgY29uc2VxdWVudGlhbCBkYW1hZ2VzIG9mIGFueSBjaGFyYWN0ZXIgYXJpc2luZyBhcyBhCisgICAgICByZXN1bHQgb2YgdGhpcyBMaWNlbnNlIG9yIG91dCBvZiB0aGUgdXNlIG9yIGluYWJpbGl0eSB0byB1c2UgdGhlCisgICAgICBXb3JrIChpbmNsdWRpbmcgYnV0IG5vdCBsaW1pdGVkIHRvIGRhbWFnZXMgZm9yIGxvc3Mgb2YgZ29vZHdpbGwsCisgICAgICB3b3JrIHN0b3BwYWdlLCBjb21wdXRlciBmYWlsdXJlIG9yIG1hbGZ1bmN0aW9uLCBvciBhbnkgYW5kIGFsbAorICAgICAgb3RoZXIgY29tbWVyY2lhbCBkYW1hZ2VzIG9yIGxvc3NlcyksIGV2ZW4gaWYgc3VjaCBDb250cmlidXRvcgorICAgICAgaGFzIGJlZW4gYWR2aXNlZCBvZiB0aGUgcG9zc2liaWxpdHkgb2Ygc3VjaCBkYW1hZ2VzLgorCisgICA5LiBBY2NlcHRpbmcgV2FycmFudHkgb3IgQWRkaXRpb25hbCBMaWFiaWxpdHkuIFdoaWxlIHJlZGlzdHJpYnV0aW5nCisgICAgICB0aGUgV29yayBvciBEZXJpdmF0aXZlIFdvcmtzIHRoZXJlb2YsIFlvdSBtYXkgY2hvb3NlIHRvIG9mZmVyLAorICAgICAgYW5kIGNoYXJnZSBhIGZlZSBmb3IsIGFjY2VwdGFuY2Ugb2Ygc3VwcG9ydCwgd2FycmFudHksIGluZGVtbml0eSwKKyAgICAgIG9yIG90aGVyIGxpYWJpbGl0eSBvYmxpZ2F0aW9ucyBhbmQvb3IgcmlnaHRzIGNvbnNpc3RlbnQgd2l0aCB0aGlzCisgICAgICBMaWNlbnNlLiBIb3dldmVyLCBpbiBhY2NlcHRpbmcgc3VjaCBvYmxpZ2F0aW9ucywgWW91IG1heSBhY3Qgb25seQorICAgICAgb24gWW91ciBvd24gYmVoYWxmIGFuZCBvbiBZb3VyIHNvbGUgcmVzcG9uc2liaWxpdHksIG5vdCBvbiBiZWhhbGYKKyAgICAgIG9mIGFueSBvdGhlciBDb250cmlidXRvciwgYW5kIG9ubHkgaWYgWW91IGFncmVlIHRvIGluZGVtbmlmeSwKKyAgICAgIGRlZmVuZCwgYW5kIGhvbGQgZWFjaCBDb250cmlidXRvciBoYXJtbGVzcyBmb3IgYW55IGxpYWJpbGl0eQorICAgICAgaW5jdXJyZWQgYnksIG9yIGNsYWltcyBhc3NlcnRlZCBhZ2FpbnN0LCBzdWNoIENvbnRyaWJ1dG9yIGJ5IHJlYXNvbgorICAgICAgb2YgeW91ciBhY2NlcHRpbmcgYW55IHN1Y2ggd2FycmFudHkgb3IgYWRkaXRpb25hbCBsaWFiaWxpdHkuCisKKyAgIEVORCBPRiBURVJNUyBBTkQgQ09ORElUSU9OUworCisgICBBUFBFTkRJWDogSG93IHRvIGFwcGx5IHRoZSBBcGFjaGUgTGljZW5zZSB0byB5b3VyIHdvcmsuCisKKyAgICAgIFRvIGFwcGx5IHRoZSBBcGFjaGUgTGljZW5zZSB0byB5b3VyIHdvcmssIGF0dGFjaCB0aGUgZm9sbG93aW5nCisgICAgICBib2lsZXJwbGF0ZSBub3RpY2UsIHdpdGggdGhlIGZpZWxkcyBlbmNsb3NlZCBieSBicmFja2V0cyAiW10iCisgICAgICByZXBsYWNlZCB3aXRoIHlvdXIgb3duIGlkZW50aWZ5aW5nIGluZm9ybWF0aW9uLiAoRG9uJ3QgaW5jbHVkZQorICAgICAgdGhlIGJyYWNrZXRzISkgIFRoZSB0ZXh0IHNob3VsZCBiZSBlbmNsb3NlZCBpbiB0aGUgYXBwcm9wcmlhdGUKKyAgICAgIGNvbW1lbnQgc3ludGF4IGZvciB0aGUgZmlsZSBmb3JtYXQuIFdlIGFsc28gcmVjb21tZW5kIHRoYXQgYQorICAgICAgZmlsZSBvciBjbGFzcyBuYW1lIGFuZCBkZXNjcmlwdGlvbiBvZiBwdXJwb3NlIGJlIGluY2x1ZGVkIG9uIHRoZQorICAgICAgc2FtZSAicHJpbnRlZCBwYWdlIiBhcyB0aGUgY29weXJpZ2h0IG5vdGljZSBmb3IgZWFzaWVyCisgICAgICBpZGVudGlmaWNhdGlvbiB3aXRoaW4gdGhpcmQtcGFydHkgYXJjaGl2ZXMuCisKKyAgIENvcHlyaWdodCBbeXl5eV0gW25hbWUgb2YgY29weXJpZ2h0IG93bmVyXQorCisgICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgIkxpY2Vuc2UiKTsKKyAgIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS4KKyAgIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdAorCisgICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wCisKKyAgIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmUKKyAgIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICJBUyBJUyIgQkFTSVMsCisgICBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC4KKyAgIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQKKyAgIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLgorCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworQVBBQ0hFIFRVU0NBTlkgU1VCQ09NUE9ORU5UUzogCisKK1RoZSBBcGFjaGUgVHVzY2FueSBiaW5hcnkgZGlzdHJpYnV0aW9uIGluY2x1ZGVzIGEgbnVtYmVyIG9mIHN1YmNvbXBvbmVudHMKK3dpdGggc2VwYXJhdGUgY29weXJpZ2h0IG5vdGljZXMgYW5kIGxpY2Vuc2UgdGVybXMuIFlvdXIgdXNlIG9mIHRoZQorY29kZSBmb3IgdGhlIHRoZXNlIHN1YmNvbXBvbmVudHMgaXMgc3ViamVjdCB0byB0aGUgdGVybXMgYW5kCitjb25kaXRpb25zIG9mIHRoZSBmb2xsb3dpbmcgbGljZW5zZXMuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorVGhlIGZvbGxvd2luZyBjb21wb25lbnRzIGNvbWUgdW5kZXIgQXBhY2hlIFNvZnR3YXJlIExpY2Vuc2UgMi4wCisKKyBjZ2xpYi0yLjIuamFyCisgY29tbW9ucy1jb21wcmVzcy0xLjAuamFyCisgY29tbW9ucy1jb2xsZWN0aW9ucy0zLjEuamFyCisgY29tbW9ucy1jb2RlYy0xLjMuamFyCisgY29tbW9ucy1maWxldXBsb2FkLTEuMi4xLmphcgorIGNvbW1vbnMtaW8tMS40LmphcgorIGNvbW1vbnMtbGFuZy0yLjQuamFyCisgY29tbW9ucy1sb2dnaW5nLTEuMS4xLmphcgorIGRlcmJ5LTEwLjIuMS42LmphcgorIGdlcm9uaW1vLWNvbW1vbmpfMS4xX3NwZWMtMS4wLmphcgorIGdlcm9uaW1vLXN0YXgtYXBpXzEuMF9zcGVjLTEuMC4xLmphcgorIGh0dHBjbGllbnQtNC4wLmphcgorIGh0dHBjb3JlLTQuMC4xLmphcgorIGphYnNvcmItMS4zLjEuamFyCisgamFja3JhYmJpdC1hcGktMS42LjEuamFyCisgamFja3JhYmJpdC1jb3JlLTEuNi4xLmphcgorIGphY2tyYWJiaXQtamNyLWNvbW1vbnMtMS42LjEuamFyCisgamFja3JhYmJpdC1zcGktMS42LjEuamFyCisgamFja3JhYmJpdC1zcGktY29tbW9ucy0xLjYuMS5qYXIKKyBqYWNrcmFiYml0LXRleHQtZXh0cmFjdG9ycy0xLjYuMS5qYXIKKyBqZXR0aXNvbi0xLjIuamFyCisgbG9nNGotMS4yLjE2LmphcgorIGx1Y2VuZS1jb3JlLTIuNC4xLmphcgorIG5la29odG1sLTEuOS43LmphcgorIHBvaS0zLjItRklOQUwuamFyCisgcG9pLXNjcmF0Y2hwYWQtMy4yLUZJTkFMLmphcgorIHNhbnNlbGFuLTAuOTctaW5jdWJhdG9yLmphcgorIHR1c2NhbnktYXNzZW1ibHktMi4wLU01LjEuamFyCisgdHVzY2FueS1hc3NlbWJseS14bWwtMi4wLU01LjEuamFyCisgdHVzY2FueS1hc3NlbWJseS14c2QtMi4wLU01LjEuamFyCisgdHVzY2FueS1iaW5kaW5nLWh0dHAtMi4wLU01LjEuamFyCisgdHVzY2FueS1iaW5kaW5nLWh0dHAtcnVudGltZS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWJpbmRpbmctanNvbnJwYy0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWJpbmRpbmctanNvbnJwYy1ydW50aW1lLTIuMC1NNS4xLmphcgorIHR1c2NhbnktYmluZGluZy1zY2EtcnVudGltZS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWJ1aWxkZXItMi4wLU01LjEuamFyCisgdHVzY2FueS1jb21tb24taHR0cC0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWNvbW1vbi1qYXZhLTIuMC1NNS4xLmphcgorIHR1c2NhbnktY29tbW9uLXhtbC0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWNvbnRyaWJ1dGlvbi0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWNvcmUtMi4wLU01LjEuamFyCisgdHVzY2FueS1jb3JlLWRhdGFiaW5kaW5nLTIuMC1NNS4xLmphcgorIHR1c2NhbnktY29yZS1zcGktMi4wLU01LjEuamFyCisgdHVzY2FueS1kYXRhLWFwaS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWRhdGFiaW5kaW5nLTIuMC1NNS4xLmphcgorIHR1c2NhbnktZGF0YWJpbmRpbmctamF4Yi0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWRhdGFiaW5kaW5nLWpzb24tMi4wLU01LjEuamFyCisgdHVzY2FueS1kZXBsb3ltZW50LTIuMC1NNS4xLmphcgorIHR1c2NhbnktZXh0ZW5zaWJpbGl0eS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWhvc3QtaHR0cC0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWhvc3Qtd2ViYXBwLTIuMC1NNS4xLmphcgorIHR1c2NhbnktaW1wbGVtZW50YXRpb24tamF2YS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWltcGxlbWVudGF0aW9uLWphdmEtcnVudGltZS0yLjAtTTUuMS5qYXIKKyB0dXNjYW55LWludGVyZmFjZS1qYXZhLTIuMC1NNS4xLmphcgorIHR1c2NhbnktaW50ZXJmYWNlLWphdmEtamF4d3MtMi4wLU01LjEuamFyCisgdHVzY2FueS1tb25pdG9yLTIuMC1NNS4xLmphcgorIHR1c2Nhbnktbm9kZS1hcGktMi4wLU01LjEuamFyCisgdHVzY2FueS1ub2RlLWltcGwtMi4wLU01LjEuamFyCisgdHVzY2FueS1zY2EtYXBpLTIuMC1NNS4xLmphcgorIHR1c2NhbnkteHNkLTIuMC1NNS4xLmphcgorIHdzdHgtYXNsLTMuMi40LmphcgorIHhlcmNlc0ltcGwtMi44LjEuamFyCisgWG1sU2NoZW1hLTEuNC4zLmphcgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK0pQeXRob24gMS4xLnggU29mdHdhcmUgTGljZW5zZS4KKz09PT09PT09PT09PT09PT09PT09PT09PT0KKworX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXworCitJTVBPUlRBTlQ6IFBMRUFTRSBSRUFEIFRIRSBGT0xMT1dJTkcgQUdSRUVNRU5UIENBUkVGVUxMWS4KKworQlkgQ0xJQ0tJTkcgT04gVEhFICJBQ0NFUFQiIEJVVFRPTiBXSEVSRSBJTkRJQ0FURUQsIE9SIEJZIElOU1RBTExJTkcsCitDT1BZSU5HIE9SIE9USEVSV0lTRSBVU0lORyBUSEUgU09GVFdBUkUsIFlPVSBBUkUgREVFTUVEIFRPIEhBVkUgQUdSRUVEIFRPCitUSEUgVEVSTVMgQU5EIENPTkRJVElPTlMgT0YgVEhJUyBBR1JFRU1FTlQuCisKK19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KKworSlB5dGhvbiB2ZXJzaW9uIDEuMS54CisKKyAgMS4gVGhpcyBMSUNFTlNFIEFHUkVFTUVOVCBpcyBiZXR3ZWVuIHRoZSBDb3Jwb3JhdGlvbiBmb3IgTmF0aW9uYWwgUmVzZWFyY2gKKyAgICAgSW5pdGlhdGl2ZXMsIGhhdmluZyBhbiBvZmZpY2UgYXQgMTg5NSBQcmVzdG9uIFdoaXRlIERyaXZlLCBSZXN0b24sIFZBCisgICAgIDIwMTkxICgiQ05SSSIpLCBhbmQgdGhlIEluZGl2aWR1YWwgb3IgT3JnYW5pemF0aW9uICgiTGljZW5zZWUiKQorICAgICBhY2Nlc3NpbmcgYW5kIHVzaW5nIEpQeXRob24gdmVyc2lvbiAxLjEueCBpbiBzb3VyY2Ugb3IgYmluYXJ5IGZvcm0gYW5kCisgICAgIGl0cyBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gYXMgcHJvdmlkZWQgaGVyZWluICgiU29mdHdhcmUiKS4KKworICAyLiBTdWJqZWN0IHRvIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0aGlzIExpY2Vuc2UgQWdyZWVtZW50LCBDTlJJCisgICAgIGhlcmVieSBncmFudHMgTGljZW5zZWUgYSBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLCByb3lhbHR5LWZyZWUsCisgICAgIHdvcmxkLXdpZGUgbGljZW5zZSB0byByZXByb2R1Y2UsIGFuYWx5emUsIHRlc3QsIHBlcmZvcm0gYW5kL29yIGRpc3BsYXkKKyAgICAgcHVibGljbHksIHByZXBhcmUgZGVyaXZhdGl2ZSB3b3JrcywgZGlzdHJpYnV0ZSwgYW5kIG90aGVyd2lzZSB1c2UgdGhlCisgICAgIFNvZnR3YXJlIGFsb25lIG9yIGluIGFueSBkZXJpdmF0aXZlIHZlcnNpb24sIHByb3ZpZGVkLCBob3dldmVyLCB0aGF0CisgICAgIENOUkkncyBMaWNlbnNlIEFncmVlbWVudCBhbmQgQ05SSSdzIG5vdGljZSBvZiBjb3B5cmlnaHQsIGkuZS4sCisgICAgICJDb3B5cmlnaHQgqTE5OTYtMTk5OSBDb3Jwb3JhdGlvbiBmb3IgTmF0aW9uYWwgUmVzZWFyY2ggSW5pdGlhdGl2ZXM7CisgICAgIEFsbCBSaWdodHMgUmVzZXJ2ZWQiIGFyZSBib3RoIHJldGFpbmVkIGluIHRoZSBTb2Z0d2FyZSwgYWxvbmUgb3IgaW4gYW55CisgICAgIGRlcml2YXRpdmUgdmVyc2lvbiBwcmVwYXJlZCBieSBMaWNlbnNlZS4KKworICAgICBBbHRlcm5hdGl2ZWx5LCBpbiBsaWV1IG9mIENOUkkncyBMaWNlbnNlIEFncmVlbWVudCwgTGljZW5zZWUgbWF5CisgICAgIHN1YnN0aXR1dGUgdGhlIGZvbGxvd2luZyB0ZXh0IChvbWl0dGluZyB0aGUgcXVvdGVzKSwgcHJvdmlkZWQsIGhvd2V2ZXIsCisgICAgIHRoYXQgc3VjaCB0ZXh0IGlzIGRpc3BsYXllZCBwcm9taW5lbnRseSBpbiB0aGUgU29mdHdhcmUgYWxvbmUgb3IgaW4gYW55CisgICAgIGRlcml2YXRpdmUgdmVyc2lvbiBwcmVwYXJlZCBieSBMaWNlbnNlZTogIkpQeXRob24gKFZlcnNpb24gMS4xLngpIGlzCisgICAgIG1hZGUgYXZhaWxhYmxlIHN1YmplY3QgdG8gdGhlIHRlcm1zIGFuZCBjb25kaXRpb25zIGluIENOUkkncyBMaWNlbnNlCisgICAgIEFncmVlbWVudC4gVGhpcyBBZ3JlZW1lbnQgbWF5IGJlIGxvY2F0ZWQgb24gdGhlIEludGVybmV0IHVzaW5nIHRoZQorICAgICBmb2xsb3dpbmcgdW5pcXVlLCBwZXJzaXN0ZW50IGlkZW50aWZpZXIgKGtub3duIGFzIGEgaGFuZGxlKToKKyAgICAgMTg5NS4yMi8xMDA2LiBUaGUgTGljZW5zZSBtYXkgYWxzbyBiZSBvYnRhaW5lZCBmcm9tIGEgcHJveHkgc2VydmVyIG9uCisgICAgIHRoZSBXZWIgdXNpbmcgdGhlIGZvbGxvd2luZyBVUkw6IGh0dHA6Ly9oZGwuaGFuZGxlLm5ldC8xODk1LjIyLzEwMDYuIgorCisgIDMuIEluIHRoZSBldmVudCBMaWNlbnNlZSBwcmVwYXJlcyBhIGRlcml2YXRpdmUgd29yayB0aGF0IGlzIGJhc2VkIG9uIG9yCisgICAgIGluY29ycG9yYXRlcyB0aGUgU29mdHdhcmUgb3IgYW55IHBhcnQgdGhlcmVvZiwgYW5kIHdhbnRzIHRvIG1ha2UgdGhlCisgICAgIGRlcml2YXRpdmUgd29yayBhdmFpbGFibGUgdG8gdGhlIHB1YmxpYyBhcyBwcm92aWRlZCBoZXJlaW4sIHRoZW4KKyAgICAgTGljZW5zZWUgaGVyZWJ5IGFncmVlcyB0byBpbmRpY2F0ZSBpbiBhbnkgc3VjaCB3b3JrLCBpbiBhIHByb21pbmVudGx5CisgICAgIHZpc2libGUgd2F5LCB0aGUgbmF0dXJlIG9mIHRoZSBtb2RpZmljYXRpb25zIG1hZGUgdG8gQ05SSSdzIFNvZnR3YXJlLgorCisgIDQuIExpY2Vuc2VlIG1heSBub3QgdXNlIENOUkkgdHJhZGVtYXJrcyBvciB0cmFkZSBuYW1lLCBpbmNsdWRpbmcgSlB5dGhvbgorICAgICBvciBDTlJJLCBpbiBhIHRyYWRlbWFyayBzZW5zZSB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgb3IKKyAgICAgc2VydmljZXMgb2YgTGljZW5zZWUsIG9yIGFueSB0aGlyZCBwYXJ0eS4gTGljZW5zZWUgbWF5IHVzZSB0aGUgbWFyaworICAgICBKUHl0aG9uIGluIGNvbm5lY3Rpb24gd2l0aCBMaWNlbnNlZSdzIGRlcml2YXRpdmUgdmVyc2lvbnMgdGhhdCBhcmUKKyAgICAgYmFzZWQgb24gb3IgaW5jb3Jwb3JhdGUgdGhlIFNvZnR3YXJlLCBidXQgb25seSBpbiB0aGUgZm9ybQorICAgICAiSlB5dGhvbi1iYXNlZCBfX19fX19fX19fX19fX19fX19fLCIgb3IgZXF1aXZhbGVudC4KKworICA1LiBDTlJJIGlzIG1ha2luZyB0aGUgU29mdHdhcmUgYXZhaWxhYmxlIHRvIExpY2Vuc2VlIG9uIGFuICJBUyBJUyIgYmFzaXMuCisgICAgIENOUkkgTUFLRVMgTk8gUkVQUkVTRU5UQVRJT05TIE9SIFdBUlJBTlRJRVMsIEVYUFJFU1MgT1IgSU1QTElFRC4gQlkgV0FZCisgICAgIE9GIEVYQU1QTEUsIEJVVCBOT1QgTElNSVRBVElPTiwgQ05SSSBNQUtFUyBOTyBBTkQgRElTQ0xBSU1TIEFOWQorICAgICBSRVBSRVNFTlRBVElPTiBPUiBXQVJSQU5UWSBPRiBNRVJDSEFOVEFCSUxJVFkgT1IgRklUTkVTUyBGT1IgQU5ZCisgICAgIFBBUlRJQ1VMQVIgUFVSUE9TRSBPUiBUSEFUIFRIRSBVU0UgT0YgVEhFIFNPRlRXQVJFIFdJTEwgTk9UIElORlJJTkdFCisgICAgIEFOWSBUSElSRCBQQVJUWSBSSUdIVFMuCisKKyAgNi4gQ05SSSBTSEFMTCBOT1QgQkUgTElBQkxFIFRPIExJQ0VOU0VFIE9SIE9USEVSIFVTRVJTIE9GIFRIRSBTT0ZUV0FSRSBGT1IKKyAgICAgQU5ZIElOQ0lERU5UQUwsIFNQRUNJQUwgT1IgQ09OU0VRVUVOVElBTCBEQU1BR0VTIE9SIExPU1MgQVMgQSBSRVNVTFQgT0YKKyAgICAgVVNJTkcsIE1PRElGWUlORyBPUiBESVNUUklCVVRJTkcgVEhFIFNPRlRXQVJFLCBPUiBBTlkgREVSSVZBVElWRQorICAgICBUSEVSRU9GLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIFRIRVJFT0YuIFNPTUUgU1RBVEVTIERPIE5PVAorICAgICBBTExPVyBUSEUgTElNSVRBVElPTiBPUiBFWENMVVNJT04gT0YgTElBQklMSVRZIFNPIFRIRSBBQk9WRSBESVNDTEFJTUVSCisgICAgIE1BWSBOT1QgQVBQTFkgVE8gTElDRU5TRUUuCisKKyAgNy4gVGhpcyBMaWNlbnNlIEFncmVlbWVudCBtYXkgYmUgdGVybWluYXRlZCBieSBDTlJJIChpKSBpbW1lZGlhdGVseSB1cG9uCisgICAgIHdyaXR0ZW4gbm90aWNlIGZyb20gQ05SSSBvZiBhbnkgbWF0ZXJpYWwgYnJlYWNoIGJ5IHRoZSBMaWNlbnNlZSwgaWYgdGhlCisgICAgIG5hdHVyZSBvZiB0aGUgYnJlYWNoIGlzIHN1Y2ggdGhhdCBpdCBjYW5ub3QgYmUgcHJvbXB0bHkgcmVtZWRpZWQ7IG9yCisgICAgIChpaSkgc2l4dHkgKDYwKSBkYXlzIGZvbGxvd2luZyBub3RpY2UgZnJvbSBDTlJJIHRvIExpY2Vuc2VlIG9mIGEKKyAgICAgbWF0ZXJpYWwgcmVtZWRpYWJsZSBicmVhY2gsIGlmIExpY2Vuc2VlIGhhcyBub3QgcmVtZWRpZWQgc3VjaCBicmVhY2gKKyAgICAgd2l0aGluIHRoYXQgc2l4dHktZGF5IHBlcmlvZC4KKworICA4LiBUaGlzIExpY2Vuc2UgQWdyZWVtZW50IHNoYWxsIGJlIGdvdmVybmVkIGJ5IGFuZCBpbnRlcnByZXRlZCBpbiBhbGwKKyAgICAgcmVzcGVjdHMgYnkgdGhlIGxhdyBvZiB0aGUgU3RhdGUgb2YgVmlyZ2luaWEsIGV4Y2x1ZGluZyBjb25mbGljdCBvZiBsYXcKKyAgICAgcHJvdmlzaW9ucy4gTm90aGluZyBpbiB0aGlzIEFncmVlbWVudCBzaGFsbCBiZSBkZWVtZWQgdG8gY3JlYXRlIGFueQorICAgICByZWxhdGlvbnNoaXAgb2YgYWdlbmN5LCBwYXJ0bmVyc2hpcCwgb3Igam9pbnQgdmVudHVyZSBiZXR3ZWVuIENOUkkgYW5kCisgICAgIExpY2Vuc2VlLgorCisgIDkuIEJ5IGNsaWNraW5nIG9uIHRoZSAiQUNDRVBUIiBidXR0b24gd2hlcmUgaW5kaWNhdGVkLCBvciBieSBpbnN0YWxsaW5nLAorICAgICBjb3B5aW5nIG9yIG90aGVyd2lzZSB1c2luZyB0aGUgU29mdHdhcmUsIExpY2Vuc2VlIGFncmVlcyB0byBiZSBib3VuZCBieQorICAgICB0aGUgdGVybXMgYW5kIGNvbmRpdGlvbnMgb2YgdGhpcyBMaWNlbnNlIEFncmVlbWVudC4KKworCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK1RoZSBqYXJzOyAKK2FjdGl2YXRpb24tMS4xLmphciwgCitqYXhiLWFwaS0yLjEuamFyLCAKK2pheGItaW1wbC0yLjEuMTIuamFyLCAKK2pzcjE4MS1hcGktMS4wLU1SMS5qYXIsIAoranNyMjUwLWFwaS0xLjAuamFyLCAKK2pheHdzLWFwaS0yLjEuamFyCisKK0NPTU1PTiBERVZFTE9QTUVOVCBBTkQgRElTVFJJQlVUSU9OIExJQ0VOU0UgKENEREwpIFZlcnNpb24gMS4wCisKKworICAgICAgMS4gRGVmaW5pdGlvbnMuCisKKyAgICAgICAgICAgIDEuMS4gIkNvbnRyaWJ1dG9yIiBtZWFucyBlYWNoIGluZGl2aWR1YWwgb3IgZW50aXR5IHRoYXQKKyAgICAgICAgICAgIGNyZWF0ZXMgb3IgY29udHJpYnV0ZXMgdG8gdGhlIGNyZWF0aW9uIG9mIE1vZGlmaWNhdGlvbnMuCisKKyAgICAgICAgICAgIDEuMi4gIkNvbnRyaWJ1dG9yIFZlcnNpb24iIG1lYW5zIHRoZSBjb21iaW5hdGlvbiBvZiB0aGUKKyAgICAgICAgICAgIE9yaWdpbmFsIFNvZnR3YXJlLCBwcmlvciBNb2RpZmljYXRpb25zIHVzZWQgYnkgYQorICAgICAgICAgICAgQ29udHJpYnV0b3IgKGlmIGFueSksIGFuZCB0aGUgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQKKyAgICAgICAgICAgIHBhcnRpY3VsYXIgQ29udHJpYnV0b3IuCisKKyAgICAgICAgICAgIDEuMy4gIkNvdmVyZWQgU29mdHdhcmUiIG1lYW5zIChhKSB0aGUgT3JpZ2luYWwgU29mdHdhcmUsIG9yCisgICAgICAgICAgICAoYikgTW9kaWZpY2F0aW9ucywgb3IgKGMpIHRoZSBjb21iaW5hdGlvbiBvZiBmaWxlcworICAgICAgICAgICAgY29udGFpbmluZyBPcmlnaW5hbCBTb2Z0d2FyZSB3aXRoIGZpbGVzIGNvbnRhaW5pbmcKKyAgICAgICAgICAgIE1vZGlmaWNhdGlvbnMsIGluIGVhY2ggY2FzZSBpbmNsdWRpbmcgcG9ydGlvbnMgdGhlcmVvZi4KKworICAgICAgICAgICAgMS40LiAiRXhlY3V0YWJsZSIgbWVhbnMgdGhlIENvdmVyZWQgU29mdHdhcmUgaW4gYW55IGZvcm0KKyAgICAgICAgICAgIG90aGVyIHRoYW4gU291cmNlIENvZGUuIAorCisgICAgICAgICAgICAxLjUuICJJbml0aWFsIERldmVsb3BlciIgbWVhbnMgdGhlIGluZGl2aWR1YWwgb3IgZW50aXR5CisgICAgICAgICAgICB0aGF0IGZpcnN0IG1ha2VzIE9yaWdpbmFsIFNvZnR3YXJlIGF2YWlsYWJsZSB1bmRlciB0aGlzCisgICAgICAgICAgICBMaWNlbnNlLiAKKyAgICAgICAgICAgIAorICAgICAgICAgICAgMS42LiAiTGFyZ2VyIFdvcmsiIG1lYW5zIGEgd29yayB3aGljaCBjb21iaW5lcyBDb3ZlcmVkCisgICAgICAgICAgICBTb2Z0d2FyZSBvciBwb3J0aW9ucyB0aGVyZW9mIHdpdGggY29kZSBub3QgZ292ZXJuZWQgYnkgdGhlCisgICAgICAgICAgICB0ZXJtcyBvZiB0aGlzIExpY2Vuc2UuCisKKyAgICAgICAgICAgIDEuNy4gIkxpY2Vuc2UiIG1lYW5zIHRoaXMgZG9jdW1lbnQuCisKKyAgICAgICAgICAgIDEuOC4gIkxpY2Vuc2FibGUiIG1lYW5zIGhhdmluZyB0aGUgcmlnaHQgdG8gZ3JhbnQsIHRvIHRoZQorICAgICAgICAgICAgbWF4aW11bSBleHRlbnQgcG9zc2libGUsIHdoZXRoZXIgYXQgdGhlIHRpbWUgb2YgdGhlIGluaXRpYWwKKyAgICAgICAgICAgIGdyYW50IG9yIHN1YnNlcXVlbnRseSBhY3F1aXJlZCwgYW55IGFuZCBhbGwgb2YgdGhlIHJpZ2h0cworICAgICAgICAgICAgY29udmV5ZWQgaGVyZWluLgorICAgICAgICAgICAgCisgICAgICAgICAgICAxLjkuICJNb2RpZmljYXRpb25zIiBtZWFucyB0aGUgU291cmNlIENvZGUgYW5kIEV4ZWN1dGFibGUKKyAgICAgICAgICAgIGZvcm0gb2YgYW55IG9mIHRoZSBmb2xsb3dpbmc6IAorCisgICAgICAgICAgICAgICAgICBBLiBBbnkgZmlsZSB0aGF0IHJlc3VsdHMgZnJvbSBhbiBhZGRpdGlvbiB0bywKKyAgICAgICAgICAgICAgICAgIGRlbGV0aW9uIGZyb20gb3IgbW9kaWZpY2F0aW9uIG9mIHRoZSBjb250ZW50cyBvZiBhCisgICAgICAgICAgICAgICAgICBmaWxlIGNvbnRhaW5pbmcgT3JpZ2luYWwgU29mdHdhcmUgb3IgcHJldmlvdXMKKyAgICAgICAgICAgICAgICAgIE1vZGlmaWNhdGlvbnM7IAorCisgICAgICAgICAgICAgICAgICBCLiBBbnkgbmV3IGZpbGUgdGhhdCBjb250YWlucyBhbnkgcGFydCBvZiB0aGUKKyAgICAgICAgICAgICAgICAgIE9yaWdpbmFsIFNvZnR3YXJlIG9yIHByZXZpb3VzIE1vZGlmaWNhdGlvbjsgb3IgCisKKyAgICAgICAgICAgICAgICAgIEMuIEFueSBuZXcgZmlsZSB0aGF0IGlzIGNvbnRyaWJ1dGVkIG9yIG90aGVyd2lzZSBtYWRlCisgICAgICAgICAgICAgICAgICBhdmFpbGFibGUgdW5kZXIgdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZS4KKworICAgICAgICAgICAgMS4xMC4gIk9yaWdpbmFsIFNvZnR3YXJlIiBtZWFucyB0aGUgU291cmNlIENvZGUgYW5kCisgICAgICAgICAgICBFeGVjdXRhYmxlIGZvcm0gb2YgY29tcHV0ZXIgc29mdHdhcmUgY29kZSB0aGF0IGlzCisgICAgICAgICAgICBvcmlnaW5hbGx5IHJlbGVhc2VkIHVuZGVyIHRoaXMgTGljZW5zZS4gCisKKyAgICAgICAgICAgIDEuMTEuICJQYXRlbnQgQ2xhaW1zIiBtZWFucyBhbnkgcGF0ZW50IGNsYWltKHMpLCBub3cgb3duZWQKKyAgICAgICAgICAgIG9yIGhlcmVhZnRlciBhY3F1aXJlZCwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiwKKyAgICAgICAgICAgIG1ldGhvZCwgcHJvY2VzcywgYW5kIGFwcGFyYXR1cyBjbGFpbXMsIGluIGFueSBwYXRlbnQKKyAgICAgICAgICAgIExpY2Vuc2FibGUgYnkgZ3JhbnRvci4gCisKKyAgICAgICAgICAgIDEuMTIuICJTb3VyY2UgQ29kZSIgbWVhbnMgKGEpIHRoZSBjb21tb24gZm9ybSBvZiBjb21wdXRlcgorICAgICAgICAgICAgc29mdHdhcmUgY29kZSBpbiB3aGljaCBtb2RpZmljYXRpb25zIGFyZSBtYWRlIGFuZCAoYikKKyAgICAgICAgICAgIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBpbmNsdWRlZCBpbiBvciB3aXRoIHN1Y2ggY29kZS4KKworICAgICAgICAgICAgMS4xMy4gIllvdSIgKG9yICJZb3VyIikgbWVhbnMgYW4gaW5kaXZpZHVhbCBvciBhIGxlZ2FsCisgICAgICAgICAgICBlbnRpdHkgZXhlcmNpc2luZyByaWdodHMgdW5kZXIsIGFuZCBjb21wbHlpbmcgd2l0aCBhbGwgb2YKKyAgICAgICAgICAgIHRoZSB0ZXJtcyBvZiwgdGhpcyBMaWNlbnNlLiBGb3IgbGVnYWwgZW50aXRpZXMsICJZb3UiCisgICAgICAgICAgICBpbmNsdWRlcyBhbnkgZW50aXR5IHdoaWNoIGNvbnRyb2xzLCBpcyBjb250cm9sbGVkIGJ5LCBvciBpcworICAgICAgICAgICAgdW5kZXIgY29tbW9uIGNvbnRyb2wgd2l0aCBZb3UuIEZvciBwdXJwb3NlcyBvZiB0aGlzCisgICAgICAgICAgICBkZWZpbml0aW9uLCAiY29udHJvbCIgbWVhbnMgKGEpIHRoZSBwb3dlciwgZGlyZWN0IG9yCisgICAgICAgICAgICBpbmRpcmVjdCwgdG8gY2F1c2UgdGhlIGRpcmVjdGlvbiBvciBtYW5hZ2VtZW50IG9mIHN1Y2gKKyAgICAgICAgICAgIGVudGl0eSwgd2hldGhlciBieSBjb250cmFjdCBvciBvdGhlcndpc2UsIG9yIChiKSBvd25lcnNoaXAKKyAgICAgICAgICAgIG9mIG1vcmUgdGhhbiBmaWZ0eSBwZXJjZW50ICg1MCUpIG9mIHRoZSBvdXRzdGFuZGluZyBzaGFyZXMKKyAgICAgICAgICAgIG9yIGJlbmVmaWNpYWwgb3duZXJzaGlwIG9mIHN1Y2ggZW50aXR5LgorCisgICAgICAyLiBMaWNlbnNlIEdyYW50cy4gCisKKyAgICAgICAgICAgIDIuMS4gVGhlIEluaXRpYWwgRGV2ZWxvcGVyIEdyYW50LgorCisgICAgICAgICAgICBDb25kaXRpb25lZCB1cG9uIFlvdXIgY29tcGxpYW5jZSB3aXRoIFNlY3Rpb24gMy4xIGJlbG93IGFuZAorICAgICAgICAgICAgc3ViamVjdCB0byB0aGlyZCBwYXJ0eSBpbnRlbGxlY3R1YWwgcHJvcGVydHkgY2xhaW1zLCB0aGUKKyAgICAgICAgICAgIEluaXRpYWwgRGV2ZWxvcGVyIGhlcmVieSBncmFudHMgWW91IGEgd29ybGQtd2lkZSwKKyAgICAgICAgICAgIHJveWFsdHktZnJlZSwgbm9uLWV4Y2x1c2l2ZSBsaWNlbnNlOiAKKworICAgICAgICAgICAgICAgICAgKGEpIHVuZGVyIGludGVsbGVjdHVhbCBwcm9wZXJ0eSByaWdodHMgKG90aGVyIHRoYW4KKyAgICAgICAgICAgICAgICAgIHBhdGVudCBvciB0cmFkZW1hcmspIExpY2Vuc2FibGUgYnkgSW5pdGlhbCBEZXZlbG9wZXIsCisgICAgICAgICAgICAgICAgICB0byB1c2UsIHJlcHJvZHVjZSwgbW9kaWZ5LCBkaXNwbGF5LCBwZXJmb3JtLAorICAgICAgICAgICAgICAgICAgc3VibGljZW5zZSBhbmQgZGlzdHJpYnV0ZSB0aGUgT3JpZ2luYWwgU29mdHdhcmUgKG9yCisgICAgICAgICAgICAgICAgICBwb3J0aW9ucyB0aGVyZW9mKSwgd2l0aCBvciB3aXRob3V0IE1vZGlmaWNhdGlvbnMsCisgICAgICAgICAgICAgICAgICBhbmQvb3IgYXMgcGFydCBvZiBhIExhcmdlciBXb3JrOyBhbmQgCisKKyAgICAgICAgICAgICAgICAgIChiKSB1bmRlciBQYXRlbnQgQ2xhaW1zIGluZnJpbmdlZCBieSB0aGUgbWFraW5nLAorICAgICAgICAgICAgICAgICAgdXNpbmcgb3Igc2VsbGluZyBvZiBPcmlnaW5hbCBTb2Z0d2FyZSwgdG8gbWFrZSwgaGF2ZQorICAgICAgICAgICAgICAgICAgbWFkZSwgdXNlLCBwcmFjdGljZSwgc2VsbCwgYW5kIG9mZmVyIGZvciBzYWxlLCBhbmQvb3IKKyAgICAgICAgICAgICAgICAgIG90aGVyd2lzZSBkaXNwb3NlIG9mIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSAob3IKKyAgICAgICAgICAgICAgICAgIHBvcnRpb25zIHRoZXJlb2YpLiAKKworICAgICAgICAgICAgICAgICAgKGMpIFRoZSBsaWNlbnNlcyBncmFudGVkIGluIFNlY3Rpb25zIDIuMShhKSBhbmQgKGIpCisgICAgICAgICAgICAgICAgICBhcmUgZWZmZWN0aXZlIG9uIHRoZSBkYXRlIEluaXRpYWwgRGV2ZWxvcGVyIGZpcnN0CisgICAgICAgICAgICAgICAgICBkaXN0cmlidXRlcyBvciBvdGhlcndpc2UgbWFrZXMgdGhlIE9yaWdpbmFsIFNvZnR3YXJlCisgICAgICAgICAgICAgICAgICBhdmFpbGFibGUgdG8gYSB0aGlyZCBwYXJ0eSB1bmRlciB0aGUgdGVybXMgb2YgdGhpcworICAgICAgICAgICAgICAgICAgTGljZW5zZS4gCisKKyAgICAgICAgICAgICAgICAgIChkKSBOb3R3aXRoc3RhbmRpbmcgU2VjdGlvbiAyLjEoYikgYWJvdmUsIG5vIHBhdGVudAorICAgICAgICAgICAgICAgICAgbGljZW5zZSBpcyBncmFudGVkOiAoMSkgZm9yIGNvZGUgdGhhdCBZb3UgZGVsZXRlIGZyb20KKyAgICAgICAgICAgICAgICAgIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSwgb3IgKDIpIGZvciBpbmZyaW5nZW1lbnRzCisgICAgICAgICAgICAgICAgICBjYXVzZWQgYnk6IChpKSB0aGUgbW9kaWZpY2F0aW9uIG9mIHRoZSBPcmlnaW5hbAorICAgICAgICAgICAgICAgICAgU29mdHdhcmUsIG9yIChpaSkgdGhlIGNvbWJpbmF0aW9uIG9mIHRoZSBPcmlnaW5hbAorICAgICAgICAgICAgICAgICAgU29mdHdhcmUgd2l0aCBvdGhlciBzb2Z0d2FyZSBvciBkZXZpY2VzLiAKKworICAgICAgICAgICAgMi4yLiBDb250cmlidXRvciBHcmFudC4KKworICAgICAgICAgICAgQ29uZGl0aW9uZWQgdXBvbiBZb3VyIGNvbXBsaWFuY2Ugd2l0aCBTZWN0aW9uIDMuMSBiZWxvdyBhbmQKKyAgICAgICAgICAgIHN1YmplY3QgdG8gdGhpcmQgcGFydHkgaW50ZWxsZWN0dWFsIHByb3BlcnR5IGNsYWltcywgZWFjaAorICAgICAgICAgICAgQ29udHJpYnV0b3IgaGVyZWJ5IGdyYW50cyBZb3UgYSB3b3JsZC13aWRlLCByb3lhbHR5LWZyZWUsCisgICAgICAgICAgICBub24tZXhjbHVzaXZlIGxpY2Vuc2U6CisKKyAgICAgICAgICAgICAgICAgIChhKSB1bmRlciBpbnRlbGxlY3R1YWwgcHJvcGVydHkgcmlnaHRzIChvdGhlciB0aGFuCisgICAgICAgICAgICAgICAgICBwYXRlbnQgb3IgdHJhZGVtYXJrKSBMaWNlbnNhYmxlIGJ5IENvbnRyaWJ1dG9yIHRvCisgICAgICAgICAgICAgICAgICB1c2UsIHJlcHJvZHVjZSwgbW9kaWZ5LCBkaXNwbGF5LCBwZXJmb3JtLCBzdWJsaWNlbnNlCisgICAgICAgICAgICAgICAgICBhbmQgZGlzdHJpYnV0ZSB0aGUgTW9kaWZpY2F0aW9ucyBjcmVhdGVkIGJ5IHN1Y2gKKyAgICAgICAgICAgICAgICAgIENvbnRyaWJ1dG9yIChvciBwb3J0aW9ucyB0aGVyZW9mKSwgZWl0aGVyIG9uIGFuCisgICAgICAgICAgICAgICAgICB1bm1vZGlmaWVkIGJhc2lzLCB3aXRoIG90aGVyIE1vZGlmaWNhdGlvbnMsIGFzCisgICAgICAgICAgICAgICAgICBDb3ZlcmVkIFNvZnR3YXJlIGFuZC9vciBhcyBwYXJ0IG9mIGEgTGFyZ2VyIFdvcms7IGFuZAorICAgICAgICAgICAgICAgICAgCisKKyAgICAgICAgICAgICAgICAgIChiKSB1bmRlciBQYXRlbnQgQ2xhaW1zIGluZnJpbmdlZCBieSB0aGUgbWFraW5nLAorICAgICAgICAgICAgICAgICAgdXNpbmcsIG9yIHNlbGxpbmcgb2YgTW9kaWZpY2F0aW9ucyBtYWRlIGJ5IHRoYXQKKyAgICAgICAgICAgICAgICAgIENvbnRyaWJ1dG9yIGVpdGhlciBhbG9uZSBhbmQvb3IgaW4gY29tYmluYXRpb24gd2l0aAorICAgICAgICAgICAgICAgICAgaXRzIENvbnRyaWJ1dG9yIFZlcnNpb24gKG9yIHBvcnRpb25zIG9mIHN1Y2gKKyAgICAgICAgICAgICAgICAgIGNvbWJpbmF0aW9uKSwgdG8gbWFrZSwgdXNlLCBzZWxsLCBvZmZlciBmb3Igc2FsZSwKKyAgICAgICAgICAgICAgICAgIGhhdmUgbWFkZSwgYW5kL29yIG90aGVyd2lzZSBkaXNwb3NlIG9mOiAoMSkKKyAgICAgICAgICAgICAgICAgIE1vZGlmaWNhdGlvbnMgbWFkZSBieSB0aGF0IENvbnRyaWJ1dG9yIChvciBwb3J0aW9ucworICAgICAgICAgICAgICAgICAgdGhlcmVvZik7IGFuZCAoMikgdGhlIGNvbWJpbmF0aW9uIG9mIE1vZGlmaWNhdGlvbnMKKyAgICAgICAgICAgICAgICAgIG1hZGUgYnkgdGhhdCBDb250cmlidXRvciB3aXRoIGl0cyBDb250cmlidXRvciBWZXJzaW9uCisgICAgICAgICAgICAgICAgICAob3IgcG9ydGlvbnMgb2Ygc3VjaCBjb21iaW5hdGlvbikuIAorCisgICAgICAgICAgICAgICAgICAoYykgVGhlIGxpY2Vuc2VzIGdyYW50ZWQgaW4gU2VjdGlvbnMgMi4yKGEpIGFuZAorICAgICAgICAgICAgICAgICAgMi4yKGIpIGFyZSBlZmZlY3RpdmUgb24gdGhlIGRhdGUgQ29udHJpYnV0b3IgZmlyc3QKKyAgICAgICAgICAgICAgICAgIGRpc3RyaWJ1dGVzIG9yIG90aGVyd2lzZSBtYWtlcyB0aGUgTW9kaWZpY2F0aW9ucworICAgICAgICAgICAgICAgICAgYXZhaWxhYmxlIHRvIGEgdGhpcmQgcGFydHkuIAorCisgICAgICAgICAgICAgICAgICAoZCkgTm90d2l0aHN0YW5kaW5nIFNlY3Rpb24gMi4yKGIpIGFib3ZlLCBubyBwYXRlbnQKKyAgICAgICAgICAgICAgICAgIGxpY2Vuc2UgaXMgZ3JhbnRlZDogKDEpIGZvciBhbnkgY29kZSB0aGF0IENvbnRyaWJ1dG9yCisgICAgICAgICAgICAgICAgICBoYXMgZGVsZXRlZCBmcm9tIHRoZSBDb250cmlidXRvciBWZXJzaW9uOyAoMikgZm9yCisgICAgICAgICAgICAgICAgICBpbmZyaW5nZW1lbnRzIGNhdXNlZCBieTogKGkpIHRoaXJkIHBhcnR5CisgICAgICAgICAgICAgICAgICBtb2RpZmljYXRpb25zIG9mIENvbnRyaWJ1dG9yIFZlcnNpb24sIG9yIChpaSkgdGhlCisgICAgICAgICAgICAgICAgICBjb21iaW5hdGlvbiBvZiBNb2RpZmljYXRpb25zIG1hZGUgYnkgdGhhdCBDb250cmlidXRvcgorICAgICAgICAgICAgICAgICAgd2l0aCBvdGhlciBzb2Z0d2FyZSAoZXhjZXB0IGFzIHBhcnQgb2YgdGhlCisgICAgICAgICAgICAgICAgICBDb250cmlidXRvciBWZXJzaW9uKSBvciBvdGhlciBkZXZpY2VzOyBvciAoMykgdW5kZXIKKyAgICAgICAgICAgICAgICAgIFBhdGVudCBDbGFpbXMgaW5mcmluZ2VkIGJ5IENvdmVyZWQgU29mdHdhcmUgaW4gdGhlCisgICAgICAgICAgICAgICAgICBhYnNlbmNlIG9mIE1vZGlmaWNhdGlvbnMgbWFkZSBieSB0aGF0IENvbnRyaWJ1dG9yLiAKKworICAgICAgMy4gRGlzdHJpYnV0aW9uIE9ibGlnYXRpb25zLgorCisgICAgICAgICAgICAzLjEuIEF2YWlsYWJpbGl0eSBvZiBTb3VyY2UgQ29kZS4KKworICAgICAgICAgICAgQW55IENvdmVyZWQgU29mdHdhcmUgdGhhdCBZb3UgZGlzdHJpYnV0ZSBvciBvdGhlcndpc2UgbWFrZQorICAgICAgICAgICAgYXZhaWxhYmxlIGluIEV4ZWN1dGFibGUgZm9ybSBtdXN0IGFsc28gYmUgbWFkZSBhdmFpbGFibGUgaW4KKyAgICAgICAgICAgIFNvdXJjZSBDb2RlIGZvcm0gYW5kIHRoYXQgU291cmNlIENvZGUgZm9ybSBtdXN0IGJlCisgICAgICAgICAgICBkaXN0cmlidXRlZCBvbmx5IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGlzIExpY2Vuc2UuIFlvdSBtdXN0CisgICAgICAgICAgICBpbmNsdWRlIGEgY29weSBvZiB0aGlzIExpY2Vuc2Ugd2l0aCBldmVyeSBjb3B5IG9mIHRoZQorICAgICAgICAgICAgU291cmNlIENvZGUgZm9ybSBvZiB0aGUgQ292ZXJlZCBTb2Z0d2FyZSBZb3UgZGlzdHJpYnV0ZSBvcgorICAgICAgICAgICAgb3RoZXJ3aXNlIG1ha2UgYXZhaWxhYmxlLiBZb3UgbXVzdCBpbmZvcm0gcmVjaXBpZW50cyBvZiBhbnkKKyAgICAgICAgICAgIHN1Y2ggQ292ZXJlZCBTb2Z0d2FyZSBpbiBFeGVjdXRhYmxlIGZvcm0gYXMgdG8gaG93IHRoZXkgY2FuCisgICAgICAgICAgICBvYnRhaW4gc3VjaCBDb3ZlcmVkIFNvZnR3YXJlIGluIFNvdXJjZSBDb2RlIGZvcm0gaW4gYQorICAgICAgICAgICAgcmVhc29uYWJsZSBtYW5uZXIgb24gb3IgdGhyb3VnaCBhIG1lZGl1bSBjdXN0b21hcmlseSB1c2VkCisgICAgICAgICAgICBmb3Igc29mdHdhcmUgZXhjaGFuZ2UuCisKKyAgICAgICAgICAgIDMuMi4gTW9kaWZpY2F0aW9ucy4KKworICAgICAgICAgICAgVGhlIE1vZGlmaWNhdGlvbnMgdGhhdCBZb3UgY3JlYXRlIG9yIHRvIHdoaWNoIFlvdQorICAgICAgICAgICAgY29udHJpYnV0ZSBhcmUgZ292ZXJuZWQgYnkgdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZS4gWW91CisgICAgICAgICAgICByZXByZXNlbnQgdGhhdCBZb3UgYmVsaWV2ZSBZb3VyIE1vZGlmaWNhdGlvbnMgYXJlIFlvdXIKKyAgICAgICAgICAgIG9yaWdpbmFsIGNyZWF0aW9uKHMpIGFuZC9vciBZb3UgaGF2ZSBzdWZmaWNpZW50IHJpZ2h0cyB0bworICAgICAgICAgICAgZ3JhbnQgdGhlIHJpZ2h0cyBjb252ZXllZCBieSB0aGlzIExpY2Vuc2UuCisKKyAgICAgICAgICAgIDMuMy4gUmVxdWlyZWQgTm90aWNlcy4KKworICAgICAgICAgICAgWW91IG11c3QgaW5jbHVkZSBhIG5vdGljZSBpbiBlYWNoIG9mIFlvdXIgTW9kaWZpY2F0aW9ucworICAgICAgICAgICAgdGhhdCBpZGVudGlmaWVzIFlvdSBhcyB0aGUgQ29udHJpYnV0b3Igb2YgdGhlIE1vZGlmaWNhdGlvbi4KKyAgICAgICAgICAgIFlvdSBtYXkgbm90IHJlbW92ZSBvciBhbHRlciBhbnkgY29weXJpZ2h0LCBwYXRlbnQgb3IKKyAgICAgICAgICAgIHRyYWRlbWFyayBub3RpY2VzIGNvbnRhaW5lZCB3aXRoaW4gdGhlIENvdmVyZWQgU29mdHdhcmUsIG9yCisgICAgICAgICAgICBhbnkgbm90aWNlcyBvZiBsaWNlbnNpbmcgb3IgYW55IGRlc2NyaXB0aXZlIHRleHQgZ2l2aW5nCisgICAgICAgICAgICBhdHRyaWJ1dGlvbiB0byBhbnkgQ29udHJpYnV0b3Igb3IgdGhlIEluaXRpYWwgRGV2ZWxvcGVyLgorCisgICAgICAgICAgICAzLjQuIEFwcGxpY2F0aW9uIG9mIEFkZGl0aW9uYWwgVGVybXMuCisKKyAgICAgICAgICAgIFlvdSBtYXkgbm90IG9mZmVyIG9yIGltcG9zZSBhbnkgdGVybXMgb24gYW55IENvdmVyZWQKKyAgICAgICAgICAgIFNvZnR3YXJlIGluIFNvdXJjZSBDb2RlIGZvcm0gdGhhdCBhbHRlcnMgb3IgcmVzdHJpY3RzIHRoZQorICAgICAgICAgICAgYXBwbGljYWJsZSB2ZXJzaW9uIG9mIHRoaXMgTGljZW5zZSBvciB0aGUgcmVjaXBpZW50cycKKyAgICAgICAgICAgIHJpZ2h0cyBoZXJldW5kZXIuIFlvdSBtYXkgY2hvb3NlIHRvIG9mZmVyLCBhbmQgdG8gY2hhcmdlIGEKKyAgICAgICAgICAgIGZlZSBmb3IsIHdhcnJhbnR5LCBzdXBwb3J0LCBpbmRlbW5pdHkgb3IgbGlhYmlsaXR5CisgICAgICAgICAgICBvYmxpZ2F0aW9ucyB0byBvbmUgb3IgbW9yZSByZWNpcGllbnRzIG9mIENvdmVyZWQgU29mdHdhcmUuCisgICAgICAgICAgICBIb3dldmVyLCB5b3UgbWF5IGRvIHNvIG9ubHkgb24gWW91ciBvd24gYmVoYWxmLCBhbmQgbm90IG9uCisgICAgICAgICAgICBiZWhhbGYgb2YgdGhlIEluaXRpYWwgRGV2ZWxvcGVyIG9yIGFueSBDb250cmlidXRvci4gWW91CisgICAgICAgICAgICBtdXN0IG1ha2UgaXQgYWJzb2x1dGVseSBjbGVhciB0aGF0IGFueSBzdWNoIHdhcnJhbnR5LAorICAgICAgICAgICAgc3VwcG9ydCwgaW5kZW1uaXR5IG9yIGxpYWJpbGl0eSBvYmxpZ2F0aW9uIGlzIG9mZmVyZWQgYnkKKyAgICAgICAgICAgIFlvdSBhbG9uZSwgYW5kIFlvdSBoZXJlYnkgYWdyZWUgdG8gaW5kZW1uaWZ5IHRoZSBJbml0aWFsCisgICAgICAgICAgICBEZXZlbG9wZXIgYW5kIGV2ZXJ5IENvbnRyaWJ1dG9yIGZvciBhbnkgbGlhYmlsaXR5IGluY3VycmVkCisgICAgICAgICAgICBieSB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3Igc3VjaCBDb250cmlidXRvciBhcyBhIHJlc3VsdCBvZgorICAgICAgICAgICAgd2FycmFudHksIHN1cHBvcnQsIGluZGVtbml0eSBvciBsaWFiaWxpdHkgdGVybXMgWW91IG9mZmVyLgorICAgICAgICAgIAorCisgICAgICAgICAgICAzLjUuIERpc3RyaWJ1dGlvbiBvZiBFeGVjdXRhYmxlIFZlcnNpb25zLgorCisgICAgICAgICAgICBZb3UgbWF5IGRpc3RyaWJ1dGUgdGhlIEV4ZWN1dGFibGUgZm9ybSBvZiB0aGUgQ292ZXJlZAorICAgICAgICAgICAgU29mdHdhcmUgdW5kZXIgdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZSBvciB1bmRlciB0aGUgdGVybXMKKyAgICAgICAgICAgIG9mIGEgbGljZW5zZSBvZiBZb3VyIGNob2ljZSwgd2hpY2ggbWF5IGNvbnRhaW4gdGVybXMKKyAgICAgICAgICAgIGRpZmZlcmVudCBmcm9tIHRoaXMgTGljZW5zZSwgcHJvdmlkZWQgdGhhdCBZb3UgYXJlIGluCisgICAgICAgICAgICBjb21wbGlhbmNlIHdpdGggdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZSBhbmQgdGhhdCB0aGUKKyAgICAgICAgICAgIGxpY2Vuc2UgZm9yIHRoZSBFeGVjdXRhYmxlIGZvcm0gZG9lcyBub3QgYXR0ZW1wdCB0byBsaW1pdAorICAgICAgICAgICAgb3IgYWx0ZXIgdGhlIHJlY2lwaWVudCdzIHJpZ2h0cyBpbiB0aGUgU291cmNlIENvZGUgZm9ybQorICAgICAgICAgICAgZnJvbSB0aGUgcmlnaHRzIHNldCBmb3J0aCBpbiB0aGlzIExpY2Vuc2UuIElmIFlvdQorICAgICAgICAgICAgZGlzdHJpYnV0ZSB0aGUgQ292ZXJlZCBTb2Z0d2FyZSBpbiBFeGVjdXRhYmxlIGZvcm0gdW5kZXIgYQorICAgICAgICAgICAgZGlmZmVyZW50IGxpY2Vuc2UsIFlvdSBtdXN0IG1ha2UgaXQgYWJzb2x1dGVseSBjbGVhciB0aGF0CisgICAgICAgICAgICBhbnkgdGVybXMgd2hpY2ggZGlmZmVyIGZyb20gdGhpcyBMaWNlbnNlIGFyZSBvZmZlcmVkIGJ5IFlvdQorICAgICAgICAgICAgYWxvbmUsIG5vdCBieSB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgb3IgQ29udHJpYnV0b3IuIFlvdQorICAgICAgICAgICAgaGVyZWJ5IGFncmVlIHRvIGluZGVtbmlmeSB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgYW5kIGV2ZXJ5CisgICAgICAgICAgICBDb250cmlidXRvciBmb3IgYW55IGxpYWJpbGl0eSBpbmN1cnJlZCBieSB0aGUgSW5pdGlhbAorICAgICAgICAgICAgRGV2ZWxvcGVyIG9yIHN1Y2ggQ29udHJpYnV0b3IgYXMgYSByZXN1bHQgb2YgYW55IHN1Y2ggdGVybXMKKyAgICAgICAgICAgIFlvdSBvZmZlci4KKworICAgICAgICAgICAgMy42LiBMYXJnZXIgV29ya3MuCisKKyAgICAgICAgICAgIFlvdSBtYXkgY3JlYXRlIGEgTGFyZ2VyIFdvcmsgYnkgY29tYmluaW5nIENvdmVyZWQgU29mdHdhcmUKKyAgICAgICAgICAgIHdpdGggb3RoZXIgY29kZSBub3QgZ292ZXJuZWQgYnkgdGhlIHRlcm1zIG9mIHRoaXMgTGljZW5zZQorICAgICAgICAgICAgYW5kIGRpc3RyaWJ1dGUgdGhlIExhcmdlciBXb3JrIGFzIGEgc2luZ2xlIHByb2R1Y3QuIEluIHN1Y2gKKyAgICAgICAgICAgIGEgY2FzZSwgWW91IG11c3QgbWFrZSBzdXJlIHRoZSByZXF1aXJlbWVudHMgb2YgdGhpcyBMaWNlbnNlCisgICAgICAgICAgICBhcmUgZnVsZmlsbGVkIGZvciB0aGUgQ292ZXJlZCBTb2Z0d2FyZS4gCisgICAgICAgICAgICAKKyAgICAgIDQuIFZlcnNpb25zIG9mIHRoZSBMaWNlbnNlLiAKKworICAgICAgICAgICAgNC4xLiBOZXcgVmVyc2lvbnMuCisKKyAgICAgICAgICAgIFN1biBNaWNyb3N5c3RlbXMsIEluYy4gaXMgdGhlIGluaXRpYWwgbGljZW5zZSBzdGV3YXJkIGFuZAorICAgICAgICAgICAgbWF5IHB1Ymxpc2ggcmV2aXNlZCBhbmQvb3IgbmV3IHZlcnNpb25zIG9mIHRoaXMgTGljZW5zZQorICAgICAgICAgICAgZnJvbSB0aW1lIHRvIHRpbWUuIEVhY2ggdmVyc2lvbiB3aWxsIGJlIGdpdmVuIGEKKyAgICAgICAgICAgIGRpc3Rpbmd1aXNoaW5nIHZlcnNpb24gbnVtYmVyLiBFeGNlcHQgYXMgcHJvdmlkZWQgaW4KKyAgICAgICAgICAgIFNlY3Rpb24gNC4zLCBubyBvbmUgb3RoZXIgdGhhbiB0aGUgbGljZW5zZSBzdGV3YXJkIGhhcyB0aGUKKyAgICAgICAgICAgIHJpZ2h0IHRvIG1vZGlmeSB0aGlzIExpY2Vuc2UuIAorCisgICAgICAgICAgICA0LjIuIEVmZmVjdCBvZiBOZXcgVmVyc2lvbnMuCisKKyAgICAgICAgICAgIFlvdSBtYXkgYWx3YXlzIGNvbnRpbnVlIHRvIHVzZSwgZGlzdHJpYnV0ZSBvciBvdGhlcndpc2UKKyAgICAgICAgICAgIG1ha2UgdGhlIENvdmVyZWQgU29mdHdhcmUgYXZhaWxhYmxlIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUKKyAgICAgICAgICAgIHZlcnNpb24gb2YgdGhlIExpY2Vuc2UgdW5kZXIgd2hpY2ggWW91IG9yaWdpbmFsbHkgcmVjZWl2ZWQKKyAgICAgICAgICAgIHRoZSBDb3ZlcmVkIFNvZnR3YXJlLiBJZiB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgaW5jbHVkZXMgYQorICAgICAgICAgICAgbm90aWNlIGluIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSBwcm9oaWJpdGluZyBpdCBmcm9tIGJlaW5nCisgICAgICAgICAgICBkaXN0cmlidXRlZCBvciBvdGhlcndpc2UgbWFkZSBhdmFpbGFibGUgdW5kZXIgYW55CisgICAgICAgICAgICBzdWJzZXF1ZW50IHZlcnNpb24gb2YgdGhlIExpY2Vuc2UsIFlvdSBtdXN0IGRpc3RyaWJ1dGUgYW5kCisgICAgICAgICAgICBtYWtlIHRoZSBDb3ZlcmVkIFNvZnR3YXJlIGF2YWlsYWJsZSB1bmRlciB0aGUgdGVybXMgb2YgdGhlCisgICAgICAgICAgICB2ZXJzaW9uIG9mIHRoZSBMaWNlbnNlIHVuZGVyIHdoaWNoIFlvdSBvcmlnaW5hbGx5IHJlY2VpdmVkCisgICAgICAgICAgICB0aGUgQ292ZXJlZCBTb2Z0d2FyZS4gT3RoZXJ3aXNlLCBZb3UgbWF5IGFsc28gY2hvb3NlIHRvCisgICAgICAgICAgICB1c2UsIGRpc3RyaWJ1dGUgb3Igb3RoZXJ3aXNlIG1ha2UgdGhlIENvdmVyZWQgU29mdHdhcmUKKyAgICAgICAgICAgIGF2YWlsYWJsZSB1bmRlciB0aGUgdGVybXMgb2YgYW55IHN1YnNlcXVlbnQgdmVyc2lvbiBvZiB0aGUKKyAgICAgICAgICAgIExpY2Vuc2UgcHVibGlzaGVkIGJ5IHRoZSBsaWNlbnNlIHN0ZXdhcmQuIAorCisgICAgICAgICAgICA0LjMuIE1vZGlmaWVkIFZlcnNpb25zLgorCisgICAgICAgICAgICBXaGVuIFlvdSBhcmUgYW4gSW5pdGlhbCBEZXZlbG9wZXIgYW5kIFlvdSB3YW50IHRvIGNyZWF0ZSBhCisgICAgICAgICAgICBuZXcgbGljZW5zZSBmb3IgWW91ciBPcmlnaW5hbCBTb2Z0d2FyZSwgWW91IG1heSBjcmVhdGUgYW5kCisgICAgICAgICAgICB1c2UgYSBtb2RpZmllZCB2ZXJzaW9uIG9mIHRoaXMgTGljZW5zZSBpZiBZb3U6IChhKSByZW5hbWUKKyAgICAgICAgICAgIHRoZSBsaWNlbnNlIGFuZCByZW1vdmUgYW55IHJlZmVyZW5jZXMgdG8gdGhlIG5hbWUgb2YgdGhlCisgICAgICAgICAgICBsaWNlbnNlIHN0ZXdhcmQgKGV4Y2VwdCB0byBub3RlIHRoYXQgdGhlIGxpY2Vuc2UgZGlmZmVycworICAgICAgICAgICAgZnJvbSB0aGlzIExpY2Vuc2UpOyBhbmQgKGIpIG90aGVyd2lzZSBtYWtlIGl0IGNsZWFyIHRoYXQKKyAgICAgICAgICAgIHRoZSBsaWNlbnNlIGNvbnRhaW5zIHRlcm1zIHdoaWNoIGRpZmZlciBmcm9tIHRoaXMgTGljZW5zZS4KKyAgICAgICAgICAgIAorCisgICAgICA1LiBESVNDTEFJTUVSIE9GIFdBUlJBTlRZLgorCisgICAgICBDT1ZFUkVEIFNPRlRXQVJFIElTIFBST1ZJREVEIFVOREVSIFRISVMgTElDRU5TRSBPTiBBTiAiQVMgSVMiCisgICAgICBCQVNJUywgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRUlUSEVSIEVYUFJFU1NFRCBPUiBJTVBMSUVELAorICAgICAgSU5DTFVESU5HLCBXSVRIT1VUIExJTUlUQVRJT04sIFdBUlJBTlRJRVMgVEhBVCBUSEUgQ09WRVJFRAorICAgICAgU09GVFdBUkUgSVMgRlJFRSBPRiBERUZFQ1RTLCBNRVJDSEFOVEFCTEUsIEZJVCBGT1IgQSBQQVJUSUNVTEFSCisgICAgICBQVVJQT1NFIE9SIE5PTi1JTkZSSU5HSU5HLiBUSEUgRU5USVJFIFJJU0sgQVMgVE8gVEhFIFFVQUxJVFkgQU5ECisgICAgICBQRVJGT1JNQU5DRSBPRiBUSEUgQ09WRVJFRCBTT0ZUV0FSRSBJUyBXSVRIIFlPVS4gU0hPVUxEIEFOWQorICAgICAgQ09WRVJFRCBTT0ZUV0FSRSBQUk9WRSBERUZFQ1RJVkUgSU4gQU5ZIFJFU1BFQ1QsIFlPVSAoTk9UIFRIRQorICAgICAgSU5JVElBTCBERVZFTE9QRVIgT1IgQU5ZIE9USEVSIENPTlRSSUJVVE9SKSBBU1NVTUUgVEhFIENPU1QgT0YKKyAgICAgIEFOWSBORUNFU1NBUlkgU0VSVklDSU5HLCBSRVBBSVIgT1IgQ09SUkVDVElPTi4gVEhJUyBESVNDTEFJTUVSIE9GCisgICAgICBXQVJSQU5UWSBDT05TVElUVVRFUyBBTiBFU1NFTlRJQUwgUEFSVCBPRiBUSElTIExJQ0VOU0UuIE5PIFVTRSBPRgorICAgICAgQU5ZIENPVkVSRUQgU09GVFdBUkUgSVMgQVVUSE9SSVpFRCBIRVJFVU5ERVIgRVhDRVBUIFVOREVSIFRISVMKKyAgICAgIERJU0NMQUlNRVIuIAorCisgICAgICA2LiBURVJNSU5BVElPTi4gCisKKyAgICAgICAgICAgIDYuMS4gVGhpcyBMaWNlbnNlIGFuZCB0aGUgcmlnaHRzIGdyYW50ZWQgaGVyZXVuZGVyIHdpbGwKKyAgICAgICAgICAgIHRlcm1pbmF0ZSBhdXRvbWF0aWNhbGx5IGlmIFlvdSBmYWlsIHRvIGNvbXBseSB3aXRoIHRlcm1zCisgICAgICAgICAgICBoZXJlaW4gYW5kIGZhaWwgdG8gY3VyZSBzdWNoIGJyZWFjaCB3aXRoaW4gMzAgZGF5cyBvZgorICAgICAgICAgICAgYmVjb21pbmcgYXdhcmUgb2YgdGhlIGJyZWFjaC4gUHJvdmlzaW9ucyB3aGljaCwgYnkgdGhlaXIKKyAgICAgICAgICAgIG5hdHVyZSwgbXVzdCByZW1haW4gaW4gZWZmZWN0IGJleW9uZCB0aGUgdGVybWluYXRpb24gb2YKKyAgICAgICAgICAgIHRoaXMgTGljZW5zZSBzaGFsbCBzdXJ2aXZlLgorCisgICAgICAgICAgICA2LjIuIElmIFlvdSBhc3NlcnQgYSBwYXRlbnQgaW5mcmluZ2VtZW50IGNsYWltIChleGNsdWRpbmcKKyAgICAgICAgICAgIGRlY2xhcmF0b3J5IGp1ZGdtZW50IGFjdGlvbnMpIGFnYWluc3QgSW5pdGlhbCBEZXZlbG9wZXIgb3IKKyAgICAgICAgICAgIGEgQ29udHJpYnV0b3IgKHRoZSBJbml0aWFsIERldmVsb3BlciBvciBDb250cmlidXRvciBhZ2FpbnN0CisgICAgICAgICAgICB3aG9tIFlvdSBhc3NlcnQgc3VjaCBjbGFpbSBpcyByZWZlcnJlZCB0byBhcyAiUGFydGljaXBhbnQiKQorICAgICAgICAgICAgYWxsZWdpbmcgdGhhdCB0aGUgUGFydGljaXBhbnQgU29mdHdhcmUgKG1lYW5pbmcgdGhlCisgICAgICAgICAgICBDb250cmlidXRvciBWZXJzaW9uIHdoZXJlIHRoZSBQYXJ0aWNpcGFudCBpcyBhIENvbnRyaWJ1dG9yCisgICAgICAgICAgICBvciB0aGUgT3JpZ2luYWwgU29mdHdhcmUgd2hlcmUgdGhlIFBhcnRpY2lwYW50IGlzIHRoZQorICAgICAgICAgICAgSW5pdGlhbCBEZXZlbG9wZXIpIGRpcmVjdGx5IG9yIGluZGlyZWN0bHkgaW5mcmluZ2VzIGFueQorICAgICAgICAgICAgcGF0ZW50LCB0aGVuIGFueSBhbmQgYWxsIHJpZ2h0cyBncmFudGVkIGRpcmVjdGx5IG9yCisgICAgICAgICAgICBpbmRpcmVjdGx5IHRvIFlvdSBieSBzdWNoIFBhcnRpY2lwYW50LCB0aGUgSW5pdGlhbAorICAgICAgICAgICAgRGV2ZWxvcGVyIChpZiB0aGUgSW5pdGlhbCBEZXZlbG9wZXIgaXMgbm90IHRoZSBQYXJ0aWNpcGFudCkKKyAgICAgICAgICAgIGFuZCBhbGwgQ29udHJpYnV0b3JzIHVuZGVyIFNlY3Rpb25zIDIuMSBhbmQvb3IgMi4yIG9mIHRoaXMKKyAgICAgICAgICAgIExpY2Vuc2Ugc2hhbGwsIHVwb24gNjAgZGF5cyBub3RpY2UgZnJvbSBQYXJ0aWNpcGFudAorICAgICAgICAgICAgdGVybWluYXRlIHByb3NwZWN0aXZlbHkgYW5kIGF1dG9tYXRpY2FsbHkgYXQgdGhlIGV4cGlyYXRpb24KKyAgICAgICAgICAgIG9mIHN1Y2ggNjAgZGF5IG5vdGljZSBwZXJpb2QsIHVubGVzcyBpZiB3aXRoaW4gc3VjaCA2MCBkYXkKKyAgICAgICAgICAgIHBlcmlvZCBZb3Ugd2l0aGRyYXcgWW91ciBjbGFpbSB3aXRoIHJlc3BlY3QgdG8gdGhlCisgICAgICAgICAgICBQYXJ0aWNpcGFudCBTb2Z0d2FyZSBhZ2FpbnN0IHN1Y2ggUGFydGljaXBhbnQgZWl0aGVyCisgICAgICAgICAgICB1bmlsYXRlcmFsbHkgb3IgcHVyc3VhbnQgdG8gYSB3cml0dGVuIGFncmVlbWVudCB3aXRoCisgICAgICAgICAgICBQYXJ0aWNpcGFudC4KKworICAgICAgICAgICAgNi4zLiBJbiB0aGUgZXZlbnQgb2YgdGVybWluYXRpb24gdW5kZXIgU2VjdGlvbnMgNi4xIG9yIDYuMgorICAgICAgICAgICAgYWJvdmUsIGFsbCBlbmQgdXNlciBsaWNlbnNlcyB0aGF0IGhhdmUgYmVlbiB2YWxpZGx5IGdyYW50ZWQKKyAgICAgICAgICAgIGJ5IFlvdSBvciBhbnkgZGlzdHJpYnV0b3IgaGVyZXVuZGVyIHByaW9yIHRvIHRlcm1pbmF0aW9uCisgICAgICAgICAgICAoZXhjbHVkaW5nIGxpY2Vuc2VzIGdyYW50ZWQgdG8gWW91IGJ5IGFueSBkaXN0cmlidXRvcikKKyAgICAgICAgICAgIHNoYWxsIHN1cnZpdmUgdGVybWluYXRpb24uCisKKyAgICAgIDcuIExJTUlUQVRJT04gT0YgTElBQklMSVRZLgorCisgICAgICBVTkRFUiBOTyBDSVJDVU1TVEFOQ0VTIEFORCBVTkRFUiBOTyBMRUdBTCBUSEVPUlksIFdIRVRIRVIgVE9SVAorICAgICAgKElOQ0xVRElORyBORUdMSUdFTkNFKSwgQ09OVFJBQ1QsIE9SIE9USEVSV0lTRSwgU0hBTEwgWU9VLCBUSEUKKyAgICAgIElOSVRJQUwgREVWRUxPUEVSLCBBTlkgT1RIRVIgQ09OVFJJQlVUT1IsIE9SIEFOWSBESVNUUklCVVRPUiBPRgorICAgICAgQ09WRVJFRCBTT0ZUV0FSRSwgT1IgQU5ZIFNVUFBMSUVSIE9GIEFOWSBPRiBTVUNIIFBBUlRJRVMsIEJFCisgICAgICBMSUFCTEUgVE8gQU5ZIFBFUlNPTiBGT1IgQU5ZIElORElSRUNULCBTUEVDSUFMLCBJTkNJREVOVEFMLCBPUgorICAgICAgQ09OU0VRVUVOVElBTCBEQU1BR0VTIE9GIEFOWSBDSEFSQUNURVIgSU5DTFVESU5HLCBXSVRIT1VUCisgICAgICBMSU1JVEFUSU9OLCBEQU1BR0VTIEZPUiBMT1NUIFBST0ZJVFMsIExPU1MgT0YgR09PRFdJTEwsIFdPUksKKyAgICAgIFNUT1BQQUdFLCBDT01QVVRFUiBGQUlMVVJFIE9SIE1BTEZVTkNUSU9OLCBPUiBBTlkgQU5EIEFMTCBPVEhFUgorICAgICAgQ09NTUVSQ0lBTCBEQU1BR0VTIE9SIExPU1NFUywgRVZFTiBJRiBTVUNIIFBBUlRZIFNIQUxMIEhBVkUgQkVFTgorICAgICAgSU5GT1JNRUQgT0YgVEhFIFBPU1NJQklMSVRZIE9GIFNVQ0ggREFNQUdFUy4gVEhJUyBMSU1JVEFUSU9OIE9GCisgICAgICBMSUFCSUxJVFkgU0hBTEwgTk9UIEFQUExZIFRPIExJQUJJTElUWSBGT1IgREVBVEggT1IgUEVSU09OQUwKKyAgICAgIElOSlVSWSBSRVNVTFRJTkcgRlJPTSBTVUNIIFBBUlRZJ1MgTkVHTElHRU5DRSBUTyBUSEUgRVhURU5UCisgICAgICBBUFBMSUNBQkxFIExBVyBQUk9ISUJJVFMgU1VDSCBMSU1JVEFUSU9OLiBTT01FIEpVUklTRElDVElPTlMgRE8KKyAgICAgIE5PVCBBTExPVyBUSEUgRVhDTFVTSU9OIE9SIExJTUlUQVRJT04gT0YgSU5DSURFTlRBTCBPUgorICAgICAgQ09OU0VRVUVOVElBTCBEQU1BR0VTLCBTTyBUSElTIEVYQ0xVU0lPTiBBTkQgTElNSVRBVElPTiBNQVkgTk9UCisgICAgICBBUFBMWSBUTyBZT1UuCisKKyAgICAgIDguIFUuUy4gR09WRVJOTUVOVCBFTkQgVVNFUlMuCisKKyAgICAgIFRoZSBDb3ZlcmVkIFNvZnR3YXJlIGlzIGEgImNvbW1lcmNpYWwgaXRlbSwiIGFzIHRoYXQgdGVybSBpcworICAgICAgZGVmaW5lZCBpbiA0OCBDLkYuUi4gMi4xMDEgKE9jdC4gMTk5NSksIGNvbnNpc3Rpbmcgb2YgImNvbW1lcmNpYWwKKyAgICAgIGNvbXB1dGVyIHNvZnR3YXJlIiAoYXMgdGhhdCB0ZXJtIGlzIGRlZmluZWQgYXQgNDggQy5GLlIuIAorICAgICAgMjUyLjIyNy03MDE0KGEpKDEpKSBhbmQgImNvbW1lcmNpYWwgY29tcHV0ZXIgc29mdHdhcmUKKyAgICAgIGRvY3VtZW50YXRpb24iIGFzIHN1Y2ggdGVybXMgYXJlIHVzZWQgaW4gNDggQy5GLlIuIDEyLjIxMiAoU2VwdC4KKyAgICAgIDE5OTUpLiBDb25zaXN0ZW50IHdpdGggNDggQy5GLlIuIDEyLjIxMiBhbmQgNDggQy5GLlIuIDIyNy43MjAyLTEKKyAgICAgIHRocm91Z2ggMjI3LjcyMDItNCAoSnVuZSAxOTk1KSwgYWxsIFUuUy4gR292ZXJubWVudCBFbmQgVXNlcnMKKyAgICAgIGFjcXVpcmUgQ292ZXJlZCBTb2Z0d2FyZSB3aXRoIG9ubHkgdGhvc2UgcmlnaHRzIHNldCBmb3J0aCBoZXJlaW4uCisgICAgICBUaGlzIFUuUy4gR292ZXJubWVudCBSaWdodHMgY2xhdXNlIGlzIGluIGxpZXUgb2YsIGFuZCBzdXBlcnNlZGVzLAorICAgICAgYW55IG90aGVyIEZBUiwgREZBUiwgb3Igb3RoZXIgY2xhdXNlIG9yIHByb3Zpc2lvbiB0aGF0IGFkZHJlc3NlcworICAgICAgR292ZXJubWVudCByaWdodHMgaW4gY29tcHV0ZXIgc29mdHdhcmUgdW5kZXIgdGhpcyBMaWNlbnNlLgorCisgICAgICA5LiBNSVNDRUxMQU5FT1VTLgorCisgICAgICBUaGlzIExpY2Vuc2UgcmVwcmVzZW50cyB0aGUgY29tcGxldGUgYWdyZWVtZW50IGNvbmNlcm5pbmcgc3ViamVjdAorICAgICAgbWF0dGVyIGhlcmVvZi4gSWYgYW55IHByb3Zpc2lvbiBvZiB0aGlzIExpY2Vuc2UgaXMgaGVsZCB0byBiZQorICAgICAgdW5lbmZvcmNlYWJsZSwgc3VjaCBwcm92aXNpb24gc2hhbGwgYmUgcmVmb3JtZWQgb25seSB0byB0aGUKKyAgICAgIGV4dGVudCBuZWNlc3NhcnkgdG8gbWFrZSBpdCBlbmZvcmNlYWJsZS4gVGhpcyBMaWNlbnNlIHNoYWxsIGJlCisgICAgICBnb3Zlcm5lZCBieSB0aGUgbGF3IG9mIHRoZSBqdXJpc2RpY3Rpb24gc3BlY2lmaWVkIGluIGEgbm90aWNlCisgICAgICBjb250YWluZWQgd2l0aGluIHRoZSBPcmlnaW5hbCBTb2Z0d2FyZSAoZXhjZXB0IHRvIHRoZSBleHRlbnQKKyAgICAgIGFwcGxpY2FibGUgbGF3LCBpZiBhbnksIHByb3ZpZGVzIG90aGVyd2lzZSksIGV4Y2x1ZGluZyBzdWNoCisgICAgICBqdXJpc2RpY3Rpb24ncyBjb25mbGljdC1vZi1sYXcgcHJvdmlzaW9ucy4gQW55IGxpdGlnYXRpb24KKyAgICAgIHJlbGF0aW5nIHRvIHRoaXMgTGljZW5zZSBzaGFsbCBiZSBzdWJqZWN0IHRvIHRoZSBqdXJpc2RpY3Rpb24gb2YKKyAgICAgIHRoZSBjb3VydHMgbG9jYXRlZCBpbiB0aGUganVyaXNkaWN0aW9uIGFuZCB2ZW51ZSBzcGVjaWZpZWQgaW4gYQorICAgICAgbm90aWNlIGNvbnRhaW5lZCB3aXRoaW4gdGhlIE9yaWdpbmFsIFNvZnR3YXJlLCB3aXRoIHRoZSBsb3NpbmcKKyAgICAgIHBhcnR5IHJlc3BvbnNpYmxlIGZvciBjb3N0cywgaW5jbHVkaW5nLCB3aXRob3V0IGxpbWl0YXRpb24sIGNvdXJ0CisgICAgICBjb3N0cyBhbmQgcmVhc29uYWJsZSBhdHRvcm5leXMnIGZlZXMgYW5kIGV4cGVuc2VzLiBUaGUKKyAgICAgIGFwcGxpY2F0aW9uIG9mIHRoZSBVbml0ZWQgTmF0aW9ucyBDb252ZW50aW9uIG9uIENvbnRyYWN0cyBmb3IgdGhlCisgICAgICBJbnRlcm5hdGlvbmFsIFNhbGUgb2YgR29vZHMgaXMgZXhwcmVzc2x5IGV4Y2x1ZGVkLiBBbnkgbGF3IG9yCisgICAgICByZWd1bGF0aW9uIHdoaWNoIHByb3ZpZGVzIHRoYXQgdGhlIGxhbmd1YWdlIG9mIGEgY29udHJhY3Qgc2hhbGwKKyAgICAgIGJlIGNvbnN0cnVlZCBhZ2FpbnN0IHRoZSBkcmFmdGVyIHNoYWxsIG5vdCBhcHBseSB0byB0aGlzIExpY2Vuc2UuCisgICAgICBZb3UgYWdyZWUgdGhhdCBZb3UgYWxvbmUgYXJlIHJlc3BvbnNpYmxlIGZvciBjb21wbGlhbmNlIHdpdGggdGhlCisgICAgICBVbml0ZWQgU3RhdGVzIGV4cG9ydCBhZG1pbmlzdHJhdGlvbiByZWd1bGF0aW9ucyAoYW5kIHRoZSBleHBvcnQKKyAgICAgIGNvbnRyb2wgbGF3cyBhbmQgcmVndWxhdGlvbiBvZiBhbnkgb3RoZXIgY291bnRyaWVzKSB3aGVuIFlvdSB1c2UsCisgICAgICBkaXN0cmlidXRlIG9yIG90aGVyd2lzZSBtYWtlIGF2YWlsYWJsZSBhbnkgQ292ZXJlZCBTb2Z0d2FyZS4KKworICAgICAgMTAuIFJFU1BPTlNJQklMSVRZIEZPUiBDTEFJTVMuCisKKyAgICAgIEFzIGJldHdlZW4gSW5pdGlhbCBEZXZlbG9wZXIgYW5kIHRoZSBDb250cmlidXRvcnMsIGVhY2ggcGFydHkgaXMKKyAgICAgIHJlc3BvbnNpYmxlIGZvciBjbGFpbXMgYW5kIGRhbWFnZXMgYXJpc2luZywgZGlyZWN0bHkgb3IKKyAgICAgIGluZGlyZWN0bHksIG91dCBvZiBpdHMgdXRpbGl6YXRpb24gb2YgcmlnaHRzIHVuZGVyIHRoaXMgTGljZW5zZQorICAgICAgYW5kIFlvdSBhZ3JlZSB0byB3b3JrIHdpdGggSW5pdGlhbCBEZXZlbG9wZXIgYW5kIENvbnRyaWJ1dG9ycyB0bworICAgICAgZGlzdHJpYnV0ZSBzdWNoIHJlc3BvbnNpYmlsaXR5IG9uIGFuIGVxdWl0YWJsZSBiYXNpcy4gTm90aGluZworICAgICAgaGVyZWluIGlzIGludGVuZGVkIG9yIHNoYWxsIGJlIGRlZW1lZCB0byBjb25zdGl0dXRlIGFueSBhZG1pc3Npb24KKyAgICAgIG9mIGxpYWJpbGl0eS4KKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworZG9qb3Rvb2xraXQgVjEuNC4yOgorCitUaGUgIk5ldyIgQlNEIExpY2Vuc2U6CisqKioqKioqKioqKioqKioqKioqKioqCisKK0NvcHlyaWdodCAoYykgMjAwNSwgVGhlIERvam8gRm91bmRhdGlvbgorQWxsIHJpZ2h0cyByZXNlcnZlZC4KKworUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0Cittb2RpZmljYXRpb24sIGFyZSBwZXJtaXR0ZWQgcHJvdmlkZWQgdGhhdCB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnMgYXJlIG1ldDoKKworICAqIFJlZGlzdHJpYnV0aW9ucyBvZiBzb3VyY2UgY29kZSBtdXN0IHJldGFpbiB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwgdGhpcworCWxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyLgorICAqIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKKwl0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyIGluIHRoZSBkb2N1bWVudGF0aW9uCisJYW5kL29yIG90aGVyIG1hdGVyaWFscyBwcm92aWRlZCB3aXRoIHRoZSBkaXN0cmlidXRpb24uCisgICogTmVpdGhlciB0aGUgbmFtZSBvZiB0aGUgRG9qbyBGb3VuZGF0aW9uIG5vciB0aGUgbmFtZXMgb2YgaXRzIGNvbnRyaWJ1dG9ycworCW1heSBiZSB1c2VkIHRvIGVuZG9yc2Ugb3IgcHJvbW90ZSBwcm9kdWN0cyBkZXJpdmVkIGZyb20gdGhpcyBzb2Z0d2FyZQorCXdpdGhvdXQgc3BlY2lmaWMgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uLgorCitUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBDT1BZUklHSFQgSE9MREVSUyBBTkQgQ09OVFJJQlVUT1JTICJBUyBJUyIgQU5ECitBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBUSEUgSU1QTElFRAorV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFkgQU5EIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFSRQorRElTQ0xBSU1FRC4gIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBDT1BZUklHSFQgT1dORVIgT1IgQ09OVFJJQlVUT1JTIEJFIExJQUJMRQorRk9SIEFOWSBESVJFQ1QsIElORElSRUNULCBJTkNJREVOVEFMLCBTUEVDSUFMLCBFWEVNUExBUlksIE9SIENPTlNFUVVFTlRJQUwKK0RBTUFHRVMgKElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBQUk9DVVJFTUVOVCBPRiBTVUJTVElUVVRFIEdPT0RTIE9SCitTRVJWSUNFUzsgTE9TUyBPRiBVU0UsIERBVEEsIE9SIFBST0ZJVFM7IE9SIEJVU0lORVNTIElOVEVSUlVQVElPTikgSE9XRVZFUgorQ0FVU0VEIEFORCBPTiBBTlkgVEhFT1JZIE9GIExJQUJJTElUWSwgV0hFVEhFUiBJTiBDT05UUkFDVCwgU1RSSUNUIExJQUJJTElUWSwKK09SIFRPUlQgKElOQ0xVRElORyBORUdMSUdFTkNFIE9SIE9USEVSV0lTRSkgQVJJU0lORyBJTiBBTlkgV0FZIE9VVCBPRiBUSEUgVVNFCitPRiBUSElTIFNPRlRXQVJFLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIE9GIFNVQ0ggREFNQUdFLgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorcGRmYm94LTAuNy4zLmphcgorCitDb3B5cmlnaHQgKGMpIDIwMDMsIHd3dy5wZGZib3gub3JnCitBbGwgcmlnaHRzIHJlc2VydmVkLgorCitSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKK21vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCBwcm92aWRlZCB0aGF0IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9ucyBhcmUgbWV0OgorCisxLiBSZWRpc3RyaWJ1dGlvbnMgb2Ygc291cmNlIGNvZGUgbXVzdCByZXRhaW4gdGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UsCisgICB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyLgorMi4gUmVkaXN0cmlidXRpb25zIGluIGJpbmFyeSBmb3JtIG11c3QgcmVwcm9kdWNlIHRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlLAorICAgdGhpcyBsaXN0IG9mIGNvbmRpdGlvbnMgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lciBpbiB0aGUgZG9jdW1lbnRhdGlvbgorICAgYW5kL29yIG90aGVyIG1hdGVyaWFscyBwcm92aWRlZCB3aXRoIHRoZSBkaXN0cmlidXRpb24uCiszLiBOZWl0aGVyIHRoZSBuYW1lIG9mIHBkZmJveDsgbm9yIHRoZSBuYW1lcyBvZiBpdHMKKyAgIGNvbnRyaWJ1dG9ycyBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIHRoaXMKKyAgIHNvZnR3YXJlIHdpdGhvdXQgc3BlY2lmaWMgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uLgorCitUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBDT1BZUklHSFQgSE9MREVSUyBBTkQgQ09OVFJJQlVUT1JTICJBUyBJUyIKK0FORCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBUSEUKK0lNUExJRUQgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFkgQU5EIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFSRQorRElTQ0xBSU1FRC4gIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBSRUdFTlRTIE9SIENPTlRSSUJVVE9SUyBCRSBMSUFCTEUgRk9SIEFOWQorRElSRUNULCBJTkRJUkVDVCwgSU5DSURFTlRBTCwgU1BFQ0lBTCwgRVhFTVBMQVJZLCBPUiBDT05TRVFVRU5USUFMIERBTUFHRVMKKyhJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgUFJPQ1VSRU1FTlQgT0YgU1VCU1RJVFVURSBHT09EUyBPUiBTRVJWSUNFUzsKK0xPU1MgT0YgVVNFLCBEQVRBLCBPUiBQUk9GSVRTOyBPUiBCVVNJTkVTUyBJTlRFUlJVUFRJT04pIEhPV0VWRVIgQ0FVU0VEIEFORCBPTgorQU5ZIFRIRU9SWSBPRiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQ09OVFJBQ1QsIFNUUklDVCBMSUFCSUxJVFksIE9SIFRPUlQKKyhJTkNMVURJTkcgTkVHTElHRU5DRSBPUiBPVEhFUldJU0UpIEFSSVNJTkcgSU4gQU5ZIFdBWSBPVVQgT0YgVEhFIFVTRSBPRiBUSElTCitTT0ZUV0FSRSwgRVZFTiBJRiBBRFZJU0VEIE9GIFRIRSBQT1NTSUJJTElUWSBPRiBTVUNIIERBTUFHRS4KKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworVGhlIHR1c2NhbnktYXNzZW1ibHkteHNkIGphciBpbmNsdWRlcyBYU0QgZmlsZXMgdW5kZXIgdGhlIGZvbGxvd2luZyBTQ0EgQ29sbGFib3JhdGlvbiBsaWNlbnNlOgorCitMaWNlbnNlIGZvciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIEphdmFEb2MsIEludGVyZmFjZSAKK0RlZmluaXRpb24gZmlsZXMgYW5kIFhTRCBmaWxlcy4KKworVGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBKYXZhRG9jLCBJbnRlcmZhY2UgRGVmaW5pdGlvbiBmaWxlcywgCithbmQgWFNEIGZpbGVzIGFyZSBiZWluZyBwcm92aWRlZCBieSB0aGUgY29weXJpZ2h0IGhvbGRlcnMgdW5kZXIgdGhlIAorZm9sbG93aW5nIGxpY2Vuc2UuIEJ5IHVzaW5nIGFuZC9vciBjb3B5aW5nIHRoaXMgd29yaywgeW91IGFncmVlIHRoYXQgCit5b3UgaGF2ZSByZWFkLCB1bmRlcnN0b29kIGFuZCB3aWxsIGNvbXBseSB3aXRoIHRoZSBmb2xsb3dpbmcgdGVybXMgYW5kIAorY29uZGl0aW9uczoKKworUGVybWlzc2lvbiB0byBjb3B5LCBkaXNwbGF5LCBtYWtlIGRlcml2YXRpdmUgd29ya3Mgb2YsIGFuZCBkaXN0cmlidXRlIAordGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBKYXZhRG9jLCBJbnRlcmZhY2UgRGVmaW5pdGlvbiBGaWxlcyAKK2FuZCBYU0QgZmlsZXMgKHRoZSAiQXJ0aWZhY3RzIikgaW4gYW55IG1lZGl1bSB3aXRob3V0IGZlZSBvciByb3lhbHR5IGlzIAoraGVyZWJ5IGdyYW50ZWQsIHByb3ZpZGVkIHRoYXQgeW91IGluY2x1ZGUgdGhlIGZvbGxvd2luZyBvbiBBTEwgY29waWVzIAorb2YgdGhlIEFydGlmYWN0cywgb3IgcG9ydGlvbnMgdGhlcmVvZiwgdGhhdCB5b3UgbWFrZTogCisKKzEuIEEgbGluayBvciBVUkwgdG8gdGhlIEFydGlmYWN0cyBhdCB0aGlzIGxvY2F0aW9uOgoraHR0cDovL3d3dy5vc29hLm9yZy9kaXNwbGF5L01haW4vU2VydmljZStDb21wb25lbnQrQXJjaGl0ZWN0dXJlK1NwZWNpZmljYXRpb25zIAorCisyLiBUaGUgZnVsbCB0ZXh0IG9mIHRoaXMgY29weXJpZ2h0IG5vdGljZSBhcyBzaG93biBpbiB0aGUgQXJ0aWZhY3RzLgorCitUSEUgQVJUSUZBQ1RTIEFSRSBQUk9WSURFRCAiQVMgSVMsIiBBTkQgVEhFIEFVVEhPUlMgTUFLRSBOTyAKK1JFUFJFU0VOVEFUSU9OUyBPUiBXQVJSQU5USUVTLCBFWFBSRVNTIE9SIElNUExJRUQsIFJFR0FSRElORyBUSEUgCitBUlRJRkFDVFMgQU5EIFRIRSBJTVBMRU1FTlRBVElPTiBPRiBUSEVJUiBDT05URU5UUywgSU5DTFVESU5HLCBCVVQgTk9UIAorTElNSVRFRCBUTywgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiAKK1BVUlBPU0UsIE5PTi1JTkZSSU5HRU1FTlQgT1IgVElUTEUuICAKKworVEhFIEFVVEhPUlMgV0lMTCBOT1QgQkUgTElBQkxFIEZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgU1BFQ0lBTCwgCitJTkNJREVOVEFMIE9SIENPTlNFUVVFTlRJQUwgREFNQUdFUyBBUklTSU5HIE9VVCBPRiBPUiBSRUxBVElORyBUTyBBTlkgCitVU0UgT1IgRElTVFJJQlVUSU9OIE9GIFRIRSBBUlRJRkFDVFMuCisKK1RoZSBuYW1lIGFuZCB0cmFkZW1hcmtzIG9mIHRoZSBBdXRob3JzIG1heSBOT1QgYmUgdXNlZCBpbiBhbnkgbWFubmVyLCAKK2luY2x1ZGluZyBhZHZlcnRpc2luZyBvciBwdWJsaWNpdHkgcGVydGFpbmluZyB0byB0aGUgU2VydmljZSBDb21wb25lbnQgCitBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbiBvciBpdHMgY29udGVudHMgd2l0aG91dCBzcGVjaWZpYywgd3JpdHRlbiAKK3ByaW9yIHBlcm1pc3Npb24uIFRpdGxlIHRvIGNvcHlyaWdodCBpbiB0aGUgU2VydmljZSBDb21wb25lbnQgCitBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbiBhbmQgdGhlIEphdmFEb2MsIEludGVyZmFjZSBEZWZpbml0aW9uIEZpbGVzIAorYW5kIFhTRCBGaWxlcyB3aWxsIGF0IGFsbCB0aW1lcyByZW1haW4gd2l0aCB0aGUgQXV0aG9ycy4KKworTm8gb3RoZXIgcmlnaHRzIGFyZSBncmFudGVkIGJ5IGltcGxpY2F0aW9uLCBlc3RvcHBlbCBvciBvdGhlcndpc2UuCisKK1JldmlzaW9uIGxldmVsIDEuMSwgbGFzdCB1cGRhdGVkIG9uIDIwMDcvMTEvMTkKKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworVGhlIGFzbS0zLjEuamFyOgorCitDb3B5cmlnaHQgKGMpIDIwMDAtMjAwNSBJTlJJQSwgRnJhbmNlIFRlbGVjb20KK0FsbCByaWdodHMgcmVzZXJ2ZWQuCisKK1JlZGlzdHJpYnV0aW9uIGFuZCB1c2UgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMsIHdpdGggb3Igd2l0aG91dAorbW9kaWZpY2F0aW9uLCBhcmUgcGVybWl0dGVkIHByb3ZpZGVkIHRoYXQgdGhlIGZvbGxvd2luZyBjb25kaXRpb25zCithcmUgbWV0OgorCisxLiBSZWRpc3RyaWJ1dGlvbnMgb2Ygc291cmNlIGNvZGUgbXVzdCByZXRhaW4gdGhlIGFib3ZlIGNvcHlyaWdodAorICAgbm90aWNlLCB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyLgorCisyLiBSZWRpc3RyaWJ1dGlvbnMgaW4gYmluYXJ5IGZvcm0gbXVzdCByZXByb2R1Y2UgdGhlIGFib3ZlIGNvcHlyaWdodAorICAgbm90aWNlLCB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyIGluIHRoZQorICAgZG9jdW1lbnRhdGlvbiBhbmQvb3Igb3RoZXIgbWF0ZXJpYWxzIHByb3ZpZGVkIHdpdGggdGhlIGRpc3RyaWJ1dGlvbi4KKworMy4gTmVpdGhlciB0aGUgbmFtZSBvZiB0aGUgY29weXJpZ2h0IGhvbGRlcnMgbm9yIHRoZSBuYW1lcyBvZiBpdHMKKyAgIGNvbnRyaWJ1dG9ycyBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tCisgICB0aGlzIHNvZnR3YXJlIHdpdGhvdXQgc3BlY2lmaWMgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uLgorCitUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBDT1BZUklHSFQgSE9MREVSUyBBTkQgQ09OVFJJQlVUT1JTICJBUyBJUyIKK0FORCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBUSEUKK0lNUExJRUQgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFkgQU5EIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFCitBUkUgRElTQ0xBSU1FRC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFIENPUFlSSUdIVCBPV05FUiBPUiBDT05UUklCVVRPUlMgQkUKK0xJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIElOQ0lERU5UQUwsIFNQRUNJQUwsIEVYRU1QTEFSWSwgT1IKK0NPTlNFUVVFTlRJQUwgREFNQUdFUyAoSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GCitTVUJTVElUVVRFIEdPT0RTIE9SIFNFUlZJQ0VTOyBMT1NTIE9GIFVTRSwgREFUQSwgT1IgUFJPRklUUzsgT1IgQlVTSU5FU1MKK0lOVEVSUlVQVElPTikgSE9XRVZFUiBDQVVTRUQgQU5EIE9OIEFOWSBUSEVPUlkgT0YgTElBQklMSVRZLCBXSEVUSEVSIElOCitDT05UUkFDVCwgU1RSSUNUIExJQUJJTElUWSwgT1IgVE9SVCAoSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKQorQVJJU0lORyBJTiBBTlkgV0FZIE9VVCBPRiBUSEUgVVNFIE9GIFRISVMgU09GVFdBUkUsIEVWRU4gSUYgQURWSVNFRCBPRgorVEhFIFBPU1NJQklMSVRZIE9GIFNVQ0ggREFNQUdFLgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitGb250Qm94IGFuZCBKZW1wQm94IGxpYnJhcmllcyAoZm9udGJveC0wLjEuMC5qYXIsIGplbXBib3gtMC4yLjAuamFyKQorCisgICAgQ29weXJpZ2h0IChjKSAyMDAzLTIwMDUsIHd3dy5mb250Ym94Lm9yZworICAgIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisKKyAgICBSZWRpc3RyaWJ1dGlvbiBhbmQgdXNlIGluIHNvdXJjZSBhbmQgYmluYXJ5IGZvcm1zLCB3aXRoIG9yIHdpdGhvdXQKKyAgICBtb2RpZmljYXRpb24sIGFyZSBwZXJtaXR0ZWQgcHJvdmlkZWQgdGhhdCB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnMgYXJlIG1ldDoKKworICAgIDEuIFJlZGlzdHJpYnV0aW9ucyBvZiBzb3VyY2UgY29kZSBtdXN0IHJldGFpbiB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKKyAgICAgICB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyLgorICAgIDIuIFJlZGlzdHJpYnV0aW9ucyBpbiBiaW5hcnkgZm9ybSBtdXN0IHJlcHJvZHVjZSB0aGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSwKKyAgICAgICB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyIGluIHRoZSBkb2N1bWVudGF0aW9uCisgICAgICAgYW5kL29yIG90aGVyIG1hdGVyaWFscyBwcm92aWRlZCB3aXRoIHRoZSBkaXN0cmlidXRpb24uCisgICAgMy4gTmVpdGhlciB0aGUgbmFtZSBvZiBmb250Ym94OyBub3IgdGhlIG5hbWVzIG9mIGl0cworICAgICAgIGNvbnRyaWJ1dG9ycyBtYXkgYmUgdXNlZCB0byBlbmRvcnNlIG9yIHByb21vdGUgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIHRoaXMKKyAgICAgICBzb2Z0d2FyZSB3aXRob3V0IHNwZWNpZmljIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbi4KKworICAgIFRISVMgU09GVFdBUkUgSVMgUFJPVklERUQgQlkgVEhFIENPUFlSSUdIVCBIT0xERVJTIEFORCBDT05UUklCVVRPUlMgIkFTIElTIgorICAgIEFORCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIElOQ0xVRElORywgQlVUIE5PVCBMSU1JVEVEIFRPLCBUSEUKKyAgICBJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQorICAgIEFSRSBESVNDTEFJTUVELiAgSU4gTk8gRVZFTlQgU0hBTEwgVEhFIFJFR0VOVFMgT1IgQ09OVFJJQlVUT1JTIEJFIExJQUJMRQorICAgIEZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgSU5DSURFTlRBTCwgU1BFQ0lBTCwgRVhFTVBMQVJZLCBPUiBDT05TRVFVRU5USUFMCisgICAgREFNQUdFUyAoSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFBST0NVUkVNRU5UIE9GIFNVQlNUSVRVVEUgR09PRFMKKyAgICBPUiBTRVJWSUNFUzsgTE9TUyBPRiBVU0UsIERBVEEsIE9SIFBST0ZJVFM7IE9SIEJVU0lORVNTIElOVEVSUlVQVElPTikKKyAgICBIT1dFVkVSIENBVVNFRCBBTkQgT04gQU5ZIFRIRU9SWSBPRiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQ09OVFJBQ1QsIFNUUklDVAorICAgIExJQUJJTElUWSwgT1IgVE9SVCAoSU5DTFVESU5HIE5FR0xJR0VOQ0UgT1IgT1RIRVJXSVNFKSBBUklTSU5HIElOIEFOWSBXQVkKKyAgICBPVVQgT0YgVEhFIFVTRSBPRiBUSElTIFNPRlRXQVJFLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZCisgICAgT0YgU1VDSCBEQU1BR0UuCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitUaGUgc2xmNGotYXBpLTEuNS4xMS5qYXIsIHNsZjRqLWpkazE0LTEuNS4xMS5qYXIsIHNsZjRqLWxvZzRqMTItMS41LjExLmphciBhcmUgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIGxpY2Vuc2U6CisKKworQ29weXJpZ2h0IChjKSAyMDA0LTIwMDggUU9TLmNoCisgQWxsIHJpZ2h0cyByZXNlcnZlZC4KKworIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcKKyBhICBjb3B5ICBvZiB0aGlzICBzb2Z0d2FyZSAgYW5kICBhc3NvY2lhdGVkICBkb2N1bWVudGF0aW9uIGZpbGVzICAodGhlCisgIlNvZnR3YXJlIiksIHRvICBkZWFsIGluICB0aGUgU29mdHdhcmUgd2l0aG91dCAgcmVzdHJpY3Rpb24sIGluY2x1ZGluZworIHdpdGhvdXQgbGltaXRhdGlvbiAgdGhlIHJpZ2h0cyB0byAgdXNlLCBjb3B5LCBtb2RpZnksICBtZXJnZSwgcHVibGlzaCwKKyBkaXN0cmlidXRlLCAgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgIGNvcGllcyBvZiAgdGhlIFNvZnR3YXJlLCAgYW5kIHRvCisgcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgIGlzIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0bworIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKKyAKKyBUaGUgIGFib3ZlICBjb3B5cmlnaHQgIG5vdGljZSAgYW5kICB0aGlzIHBlcm1pc3Npb24gIG5vdGljZSAgc2hhbGwgIGJlCisgaW5jbHVkZWQgaW4gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuCisgCisgVEhFICBTT0ZUV0FSRSBJUyAgUFJPVklERUQgICJBUyAgSVMiLCBXSVRIT1VUICBXQVJSQU5UWSAgT0YgQU5ZICBLSU5ELAorIEVYUFJFU1MgT1IgIElNUExJRUQsIElOQ0xVRElORyAgQlVUIE5PVCBMSU1JVEVEICBUTyBUSEUgIFdBUlJBTlRJRVMgT0YKKyBNRVJDSEFOVEFCSUxJVFksICAgIEZJVE5FU1MgICAgRk9SICAgIEEgICBQQVJUSUNVTEFSICAgIFBVUlBPU0UgICAgQU5ECisgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRQorIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04KKyBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsICBBUklTSU5HIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OCisgV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEUgU09GVFdBUkUuCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK0pDUiAxLjAgQVBJIChqY3ItMS4wLmphcikKKworICAgIFtEYXkgU3BlY2lmaWNhdGlvbiBMaWNlbnNlXQorCisgICAgRGF5IE1hbmFnZW1lbnQgQUcgKCJMaWNlbnNvciIpIGlzIHdpbGxpbmcgdG8gbGljZW5zZSB0aGlzIHNwZWNpZmljYXRpb24KKyAgICB0byB5b3UgT05MWSBVUE9OIFRIRSBDT05ESVRJT04gVEhBVCBZT1UgQUNDRVBUIEFMTCBPRiBUSEUgVEVSTVMgQ09OVEFJTkVECisgICAgSU4gVEhJUyBMSUNFTlNFIEFHUkVFTUVOVCAoIkFncmVlbWVudCIpLiBQbGVhc2UgcmVhZCB0aGUgdGVybXMgYW5kCisgICAgY29uZGl0aW9ucyBvZiB0aGlzIEFncmVlbWVudCBjYXJlZnVsbHkuCisKKyAgICBDb250ZW50IFJlcG9zaXRvcnkgZm9yIEphdmFUTSBUZWNobm9sb2d5IEFQSSBTcGVjaWZpY2F0aW9uICgiU3BlY2lmaWNhdGlvbiIpCisgICAgVmVyc2lvbjogMS4wCisgICAgU3RhdHVzOiBGQ1MKKyAgICBSZWxlYXNlOiAxMSBNYXkgMjAwNQorCisgICAgQ29weXJpZ2h0IDIwMDUgRGF5IE1hbmFnZW1lbnQgQUcKKyAgICBCYXJmw7xzc2VycGxhdHogNiwgNDAwMSBCYXNlbCwgU3dpdHplcmxhbmQuCisgICAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KKworICAgIE5PVElDRTsgTElNSVRFRCBMSUNFTlNFIEdSQU5UUworCisgICAgMS4gTGljZW5zZSBmb3IgUHVycG9zZXMgb2YgRXZhbHVhdGlvbiBhbmQgRGV2ZWxvcGluZyBBcHBsaWNhdGlvbnMuCisgICAgTGljZW5zb3IgaGVyZWJ5IGdyYW50cyB5b3UgYSBmdWxseS1wYWlkLCBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLAorICAgIHdvcmxkd2lkZSwgbGltaXRlZCBsaWNlbnNlICh3aXRob3V0IHRoZSByaWdodCB0byBzdWJsaWNlbnNlKSwgdW5kZXIKKyAgICBMaWNlbnNvcidzIGFwcGxpY2FibGUgaW50ZWxsZWN0dWFsIHByb3BlcnR5IHJpZ2h0cyB0byB2aWV3LCBkb3dubG9hZCwKKyAgICB1c2UgYW5kIHJlcHJvZHVjZSB0aGUgU3BlY2lmaWNhdGlvbiBvbmx5IGZvciB0aGUgcHVycG9zZSBvZiBpbnRlcm5hbAorICAgIGV2YWx1YXRpb24uIFRoaXMgaW5jbHVkZXMgZGV2ZWxvcGluZyBhcHBsaWNhdGlvbnMgaW50ZW5kZWQgdG8gcnVuIG9uIGFuCisgICAgaW1wbGVtZW50YXRpb24gb2YgdGhlIFNwZWNpZmljYXRpb24gcHJvdmlkZWQgdGhhdCBzdWNoIGFwcGxpY2F0aW9ucyBkbworICAgIG5vdCB0aGVtc2VsdmVzIGltcGxlbWVudCBhbnkgcG9ydGlvbihzKSBvZiB0aGUgU3BlY2lmaWNhdGlvbi4KKworICAgIDIuIExpY2Vuc2UgZm9yIHRoZSBEaXN0cmlidXRpb24gb2YgQ29tcGxpYW50IEltcGxlbWVudGF0aW9ucy4gTGljZW5zb3IKKyAgICBhbHNvIGdyYW50cyB5b3UgYSBwZXJwZXR1YWwsIG5vbi1leGNsdXNpdmUsIG5vbi10cmFuc2ZlcmFibGUsIHdvcmxkd2lkZSwKKyAgICBmdWxseSBwYWlkLXVwLCByb3lhbHR5IGZyZWUsIGxpbWl0ZWQgbGljZW5zZSAod2l0aG91dCB0aGUgcmlnaHQgdG8KKyAgICBzdWJsaWNlbnNlKSB1bmRlciBhbnkgYXBwbGljYWJsZSBjb3B5cmlnaHRzIG9yLCBzdWJqZWN0IHRvIHRoZSBwcm92aXNpb25zCisgICAgb2Ygc3Vic2VjdGlvbiA0IGJlbG93LCBwYXRlbnQgcmlnaHRzIGl0IG1heSBoYXZlIGNvdmVyaW5nIHRoZQorICAgIFNwZWNpZmljYXRpb24gdG8gY3JlYXRlIGFuZC9vciBkaXN0cmlidXRlIGFuIEluZGVwZW5kZW50IEltcGxlbWVudGF0aW9uCisgICAgb2YgdGhlIFNwZWNpZmljYXRpb24gdGhhdDogKGEpIGZ1bGx5IGltcGxlbWVudHMgdGhlIFNwZWNpZmljYXRpb24KKyAgICBpbmNsdWRpbmcgYWxsIGl0cyByZXF1aXJlZCBpbnRlcmZhY2VzIGFuZCBmdW5jdGlvbmFsaXR5OyAoYikgZG9lcyBub3QKKyAgICBtb2RpZnksIHN1YnNldCwgc3VwZXJzZXQgb3Igb3RoZXJ3aXNlIGV4dGVuZCB0aGUgTGljZW5zb3IgTmFtZSBTcGFjZSwgb3IKKyAgICBpbmNsdWRlIGFueSBwdWJsaWMgb3IgcHJvdGVjdGVkIHBhY2thZ2VzLCBjbGFzc2VzLCBKYXZhIGludGVyZmFjZXMsIGZpZWxkcworICAgIG9yIG1ldGhvZHMgd2l0aGluIHRoZSBMaWNlbnNvciBOYW1lIFNwYWNlIG90aGVyIHRoYW4gdGhvc2UKKyAgICByZXF1aXJlZC9hdXRob3JpemVkIGJ5IHRoZSBTcGVjaWZpY2F0aW9uIG9yIFNwZWNpZmljYXRpb25zIGJlaW5nCisgICAgaW1wbGVtZW50ZWQ7IGFuZCAoYykgcGFzc2VzIHRoZSBUZWNobm9sb2d5IENvbXBhdGliaWxpdHkgS2l0IChpbmNsdWRpbmcKKyAgICBzYXRpc2Z5aW5nIHRoZSByZXF1aXJlbWVudHMgb2YgdGhlIGFwcGxpY2FibGUgVENLIFVzZXJzIEd1aWRlKSBmb3Igc3VjaAorICAgIFNwZWNpZmljYXRpb24gKCJDb21wbGlhbnQgSW1wbGVtZW50YXRpb24iKS4gSW4gYWRkaXRpb24sIHRoZSBmb3JlZ29pbmcKKyAgICBsaWNlbnNlIGlzIGV4cHJlc3NseSBjb25kaXRpb25lZCBvbiB5b3VyIG5vdCBhY3Rpbmcgb3V0c2lkZSBpdHMgc2NvcGUuCisgICAgTm8gbGljZW5zZSBpcyBncmFudGVkIGhlcmV1bmRlciBmb3IgYW55IG90aGVyIHB1cnBvc2UgKGluY2x1ZGluZywgZm9yCisgICAgZXhhbXBsZSwgbW9kaWZ5aW5nIHRoZSBTcGVjaWZpY2F0aW9uLCBvdGhlciB0aGFuIHRvIHRoZSBleHRlbnQgb2YgeW91cgorICAgIGZhaXIgdXNlIHJpZ2h0cywgb3IgZGlzdHJpYnV0aW5nIHRoZSBTcGVjaWZpY2F0aW9uIHRvIHRoaXJkIHBhcnRpZXMpLgorCisgICAgMy4gUGFzcy10aHJvdWdoIENvbmRpdGlvbnMuIFlvdSBuZWVkIG5vdCBpbmNsdWRlIGxpbWl0YXRpb25zIChhKS0oYykgZnJvbQorICAgIHRoZSBwcmV2aW91cyBwYXJhZ3JhcGggb3IgYW55IG90aGVyIHBhcnRpY3VsYXIgInBhc3MgdGhyb3VnaCIgcmVxdWlyZW1lbnRzCisgICAgaW4gYW55IGxpY2Vuc2UgWW91IGdyYW50IGNvbmNlcm5pbmcgdGhlIHVzZSBvZiB5b3VyIEluZGVwZW5kZW50CisgICAgSW1wbGVtZW50YXRpb24gb3IgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIGl0LiBIb3dldmVyLCBleGNlcHQgd2l0aCByZXNwZWN0CisgICAgdG8gSW5kZXBlbmRlbnQgSW1wbGVtZW50YXRpb25zIChhbmQgcHJvZHVjdHMgZGVyaXZlZCBmcm9tIHRoZW0pIHRoYXQKKyAgICBzYXRpc2Z5IGxpbWl0YXRpb25zIChhKS0oYykgZnJvbSB0aGUgcHJldmlvdXMgcGFyYWdyYXBoLCBZb3UgbWF5IG5laXRoZXI6CisgICAgKGEpIGdyYW50IG9yIG90aGVyd2lzZSBwYXNzIHRocm91Z2ggdG8geW91ciBsaWNlbnNlZXMgYW55IGxpY2Vuc2VzIHVuZGVyCisgICAgTGljZW5zb3IncyBhcHBsaWNhYmxlIGludGVsbGVjdHVhbCBwcm9wZXJ0eSByaWdodHM7IG5vciAoYikgYXV0aG9yaXplIHlvdXIKKyAgICBsaWNlbnNlZXMgdG8gbWFrZSBhbnkgY2xhaW1zIGNvbmNlcm5pbmcgdGhlaXIgaW1wbGVtZW50YXRpb24ncyBjb21wbGlhbmNlCisgICAgd2l0aCB0aGUgU3BlY2lmaWNhdGlvbi4KKworICAgIDQuIFJlY2lwcm9jaXR5IENvbmNlcm5pbmcgUGF0ZW50IExpY2Vuc2VzLiBXaXRoIHJlc3BlY3QgdG8gYW55IHBhdGVudAorICAgIGNsYWltcyBjb3ZlcmVkIGJ5IHRoZSBsaWNlbnNlIGdyYW50ZWQgdW5kZXIgc3VicGFyYWdyYXBoIDIgYWJvdmUgdGhhdAorICAgIHdvdWxkIGJlIGluZnJpbmdlZCBieSBhbGwgdGVjaG5pY2FsbHkgZmVhc2libGUgaW1wbGVtZW50YXRpb25zIG9mIHRoZQorICAgIFNwZWNpZmljYXRpb24sIHN1Y2ggbGljZW5zZSBpcyBjb25kaXRpb25lZCB1cG9uIHlvdXIgb2ZmZXJpbmcgb24gZmFpciwKKyAgICByZWFzb25hYmxlIGFuZCBub24tZGlzY3JpbWluYXRvcnkgdGVybXMsIHRvIGFueSBwYXJ0eSBzZWVraW5nIGl0IGZyb20KKyAgICBZb3UsIGEgcGVycGV0dWFsLCBub24tZXhjbHVzaXZlLCBub24tdHJhbnNmZXJhYmxlLCB3b3JsZHdpZGUgbGljZW5zZQorICAgIHVuZGVyIFlvdXIgcGF0ZW50IHJpZ2h0cyB0aGF0IGFyZSBvciB3b3VsZCBiZSBpbmZyaW5nZWQgYnkgYWxsIHRlY2huaWNhbGx5CisgICAgZmVhc2libGUgaW1wbGVtZW50YXRpb25zIG9mIHRoZSBTcGVjaWZpY2F0aW9uIHRvIGRldmVsb3AsIGRpc3RyaWJ1dGUgYW5kCisgICAgdXNlIGEgQ29tcGxpYW50IEltcGxlbWVudGF0aW9uLgorCisgICAgNS4gRGVmaW5pdGlvbnMuIEZvciB0aGUgcHVycG9zZXMgb2YgdGhpcyBBZ3JlZW1lbnQ6ICJJbmRlcGVuZGVudAorICAgIEltcGxlbWVudGF0aW9uIiBzaGFsbCBtZWFuIGFuIGltcGxlbWVudGF0aW9uIG9mIHRoZSBTcGVjaWZpY2F0aW9uIHRoYXQKKyAgICBuZWl0aGVyIGRlcml2ZXMgZnJvbSBhbnkgb2YgTGljZW5zb3IncyBzb3VyY2UgY29kZSBvciBiaW5hcnkgY29kZQorICAgIG1hdGVyaWFscyBub3IsIGV4Y2VwdCB3aXRoIGFuIGFwcHJvcHJpYXRlIGFuZCBzZXBhcmF0ZSBsaWNlbnNlIGZyb20KKyAgICBMaWNlbnNvciwgaW5jbHVkZXMgYW55IG9mIExpY2Vuc29yJ3Mgc291cmNlIGNvZGUgb3IgYmluYXJ5IGNvZGUgbWF0ZXJpYWxzOworICAgICJMaWNlbnNvciBOYW1lIFNwYWNlIiBzaGFsbCBtZWFuIHRoZSBwdWJsaWMgY2xhc3Mgb3IgaW50ZXJmYWNlCisgICAgZGVjbGFyYXRpb25zIHdob3NlIG5hbWVzIGJlZ2luIHdpdGggImphdmEiLCAiamF2YXgiLCAiamF2YXguamNyIiBvciB0aGVpcgorICAgIGVxdWl2YWxlbnRzIGluIGFueSBzdWJzZXF1ZW50IG5hbWluZyBjb252ZW50aW9uIGFkb3B0ZWQgYnkgTGljZW5zb3IKKyAgICB0aHJvdWdoIHRoZSBKYXZhIENvbW11bml0eSBQcm9jZXNzLCBvciBhbnkgcmVjb2duaXplZCBzdWNjZXNzb3JzIG9yCisgICAgcmVwbGFjZW1lbnRzIHRoZXJlb2Y7IGFuZCAiVGVjaG5vbG9neSBDb21wYXRpYmlsaXR5IEtpdCIgb3IgIlRDSyIgc2hhbGwKKyAgICBtZWFuIHRoZSB0ZXN0IHN1aXRlIGFuZCBhY2NvbXBhbnlpbmcgVENLIFVzZXIncyBHdWlkZSBwcm92aWRlZCBieQorICAgIExpY2Vuc29yIHdoaWNoIGNvcnJlc3BvbmRzIHRvIHRoZSBwYXJ0aWN1bGFyIHZlcnNpb24gb2YgdGhlIFNwZWNpZmljYXRpb24KKyAgICBiZWluZyB0ZXN0ZWQuCisKKyAgICA2LiBUZXJtaW5hdGlvbi4gVGhpcyBBZ3JlZW1lbnQgd2lsbCB0ZXJtaW5hdGUgaW1tZWRpYXRlbHkgd2l0aG91dCBub3RpY2UKKyAgICBmcm9tIExpY2Vuc29yIGlmIHlvdSBmYWlsIHRvIGNvbXBseSB3aXRoIGFueSBtYXRlcmlhbCBwcm92aXNpb24gb2Ygb3IgYWN0CisgICAgb3V0c2lkZSB0aGUgc2NvcGUgb2YgdGhlIGxpY2Vuc2VzIGdyYW50ZWQgYWJvdmUuCisKKyAgICA3LiBUcmFkZW1hcmtzLiBObyByaWdodCwgdGl0bGUsIG9yIGludGVyZXN0IGluIG9yIHRvIGFueSB0cmFkZW1hcmtzLAorICAgIHNlcnZpY2UgbWFya3MsIG9yIHRyYWRlIG5hbWVzIG9mIExpY2Vuc29yIGlzIGdyYW50ZWQgaGVyZXVuZGVyLiBKYXZhIGlzCisgICAgYSByZWdpc3RlcmVkIHRyYWRlbWFyayBvZiBTdW4gTWljcm9zeXN0ZW1zLCBJbmMuIGluIHRoZSBVbml0ZWQgU3RhdGVzIGFuZAorICAgIG90aGVyIGNvdW50cmllcy4KKworICAgIDguIERpc2NsYWltZXIgb2YgV2FycmFudGllcy4gVGhlIFNwZWNpZmljYXRpb24gaXMgcHJvdmlkZWQgIkFTIElTIi4KKyAgICBMSUNFTlNPUiBNQUtFUyBOTyBSRVBSRVNFTlRBVElPTlMgT1IgV0FSUkFOVElFUywgRUlUSEVSIEVYUFJFU1MgT1IKKyAgICBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPLCBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwKKyAgICBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSwgTk9OLUlORlJJTkdFTUVOVCAoSU5DTFVESU5HIEFTIEEKKyAgICBDT05TRVFVRU5DRSBPRiBBTlkgUFJBQ1RJQ0UgT1IgSU1QTEVNRU5UQVRJT04gT0YgVEhFIFNQRUNJRklDQVRJT04pLCBPUgorICAgIFRIQVQgVEhFIENPTlRFTlRTIE9GIFRIRSBTUEVDSUZJQ0FUSU9OIEFSRSBTVUlUQUJMRSBGT1IgQU5ZIFBVUlBPU0UuCisgICAgVGhpcyBkb2N1bWVudCBkb2VzIG5vdCByZXByZXNlbnQgYW55IGNvbW1pdG1lbnQgdG8gcmVsZWFzZSBvciBpbXBsZW1lbnQKKyAgICBhbnkgcG9ydGlvbiBvZiB0aGUgU3BlY2lmaWNhdGlvbiBpbiBhbnkgcHJvZHVjdC4KKworICAgIFRoZSBTcGVjaWZpY2F0aW9uIGNvdWxkIGluY2x1ZGUgdGVjaG5pY2FsIGluYWNjdXJhY2llcyBvciB0eXBvZ3JhcGhpY2FsCisgICAgZXJyb3JzLiBDaGFuZ2VzIGFyZSBwZXJpb2RpY2FsbHkgYWRkZWQgdG8gdGhlIGluZm9ybWF0aW9uIHRoZXJlaW47IHRoZXNlCisgICAgY2hhbmdlcyB3aWxsIGJlIGluY29ycG9yYXRlZCBpbnRvIG5ldyB2ZXJzaW9ucyBvZiB0aGUgU3BlY2lmaWNhdGlvbiwgaWYKKyAgICBhbnkuIExpY2Vuc29yIG1heSBtYWtlIGltcHJvdmVtZW50cyBhbmQvb3IgY2hhbmdlcyB0byB0aGUgcHJvZHVjdChzKQorICAgIGFuZC9vciB0aGUgcHJvZ3JhbShzKSBkZXNjcmliZWQgaW4gdGhlIFNwZWNpZmljYXRpb24gYXQgYW55IHRpbWUuIEFueQorICAgIHVzZSBvZiBzdWNoIGNoYW5nZXMgaW4gdGhlIFNwZWNpZmljYXRpb24gd2lsbCBiZSBnb3Zlcm5lZCBieSB0aGUKKyAgICB0aGVuLWN1cnJlbnQgbGljZW5zZSBmb3IgdGhlIGFwcGxpY2FibGUgdmVyc2lvbiBvZiB0aGUgU3BlY2lmaWNhdGlvbi4KKworICAgIDkuIExpbWl0YXRpb24gb2YgTGlhYmlsaXR5LiBUTyBUSEUgRVhURU5UIE5PVCBQUk9ISUJJVEVEIEJZIExBVywgSU4gTk8KKyAgICBFVkVOVCBXSUxMIExJQ0VOU09SIEJFIExJQUJMRSBGT1IgQU5ZIERBTUFHRVMsIElOQ0xVRElORyBXSVRIT1VUCisgICAgTElNSVRBVElPTiwgTE9TVCBSRVZFTlVFLCBQUk9GSVRTIE9SIERBVEEsIE9SIEZPUiBTUEVDSUFMLCBJTkRJUkVDVCwKKyAgICBDT05TRVFVRU5USUFMLCBJTkNJREVOVEFMIE9SIFBVTklUSVZFIERBTUFHRVMsIEhPV0VWRVIgQ0FVU0VEIEFORAorICAgIFJFR0FSRExFU1MgT0YgVEhFIFRIRU9SWSBPRiBMSUFCSUxJVFksIEFSSVNJTkcgT1VUIE9GIE9SIFJFTEFURUQgVE8gQU5ZCisgICAgRlVSTklTSElORywgUFJBQ1RJQ0lORywgTU9ESUZZSU5HIE9SIEFOWSBVU0UgT0YgVEhFIFNQRUNJRklDQVRJT04sIEVWRU4KKyAgICBJRiBMSUNFTlNPUiBIQVMgQkVFTiBBRFZJU0VEIE9GIFRIRSBQT1NTSUJJTElUWSBPRiBTVUNIIERBTUFHRVMuCisKKyAgICAxMC4gUmVwb3J0LiBJZiB5b3UgcHJvdmlkZSBMaWNlbnNvciB3aXRoIGFueSBjb21tZW50cyBvciBzdWdnZXN0aW9ucyBpbgorICAgIGNvbm5lY3Rpb24gd2l0aCB5b3VyIHVzZSBvZiB0aGUgU3BlY2lmaWNhdGlvbiAoIkZlZWRiYWNrIiksIHlvdSBoZXJlYnk6CisgICAgKGkpIGFncmVlIHRoYXQgc3VjaCBGZWVkYmFjayBpcyBwcm92aWRlZCBvbiBhIG5vbi1wcm9wcmlldGFyeSBhbmQKKyAgICBub24tY29uZmlkZW50aWFsIGJhc2lzLCBhbmQgKGlpKSBncmFudCBMaWNlbnNvciBhIHBlcnBldHVhbCwKKyAgICBub24tZXhjbHVzaXZlLCB3b3JsZHdpZGUsIGZ1bGx5IHBhaWQtdXAsIGlycmV2b2NhYmxlIGxpY2Vuc2UsIHdpdGggdGhlCisgICAgcmlnaHQgdG8gc3VibGljZW5zZSB0aHJvdWdoIG11bHRpcGxlIGxldmVscyBvZiBzdWJsaWNlbnNlZXMsIHRvCisgICAgaW5jb3Jwb3JhdGUsIGRpc2Nsb3NlLCBhbmQgdXNlIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgRmVlZGJhY2sgZm9yIGFueQorICAgIHB1cnBvc2UgcmVsYXRlZCB0byB0aGUgU3BlY2lmaWNhdGlvbiBhbmQgZnV0dXJlIHZlcnNpb25zLAorICAgIGltcGxlbWVudGF0aW9ucywgYW5kIHRlc3Qgc3VpdGVzIHRoZXJlb2YuCisKKyAgICBbQWRkZW5kdW0gdG8gdGhlIERheSBTcGVjaWZpY2F0aW9uIExpY2Vuc2VdCisKKyAgICBJbiBhZGRpdGlvbiB0byB0aGUgcGVybWlzc2lvbnMgZ3JhbnRlZCB1bmRlciB0aGUgU3BlY2lmaWNhdGlvbgorICAgIExpY2Vuc2UsIERheSBNYW5hZ2VtZW50IEFHIGhlcmVieSBncmFudHMgdG8gWW91IGEgcGVycGV0dWFsLAorICAgIHdvcmxkd2lkZSwgbm9uLWV4Y2x1c2l2ZSwgbm8tY2hhcmdlLCByb3lhbHR5LWZyZWUsIGlycmV2b2NhYmxlCisgICAgbGljZW5zZSB0byByZXByb2R1Y2UsIHB1YmxpY2x5IGRpc3BsYXksIHB1YmxpY2x5IHBlcmZvcm0sCisgICAgc3VibGljZW5zZSwgYW5kIGRpc3RyaWJ1dGUgdW5tb2RpZmllZCBjb3BpZXMgb2YgdGhlIENvbnRlbnQKKyAgICBSZXBvc2l0b3J5IGZvciBKYXZhIFRlY2hub2xvZ3kgQVBJIChKQ1IgMS4wKSBKYXZhIEFyY2hpdmUgKEpBUikKKyAgICBmaWxlICgiamNyLTEuMC5qYXIiKSBhbmQgdG8gbWFrZSwgaGF2ZSBtYWRlLCB1c2UsIG9mZmVyIHRvIHNlbGwsCisgICAgc2VsbCwgaW1wb3J0LCBhbmQgb3RoZXJ3aXNlIHRyYW5zZmVyIHNhaWQgZmlsZSBvbiBpdHMgb3duIG9yCisgICAgYXMgcGFydCBvZiBhIGxhcmdlciB3b3JrIHRoYXQgbWFrZXMgdXNlIG9mIHRoZSBKQ1IgQVBJLgorCisgICAgV2l0aCByZXNwZWN0IHRvIGFueSBwYXRlbnQgY2xhaW1zIGNvdmVyZWQgYnkgdGhpcyBsaWNlbnNlCisgICAgdGhhdCB3b3VsZCBiZSBpbmZyaW5nZWQgYnkgYWxsIHRlY2huaWNhbGx5IGZlYXNpYmxlIGltcGxlbWVudGF0aW9ucworICAgIG9mIHRoZSBTcGVjaWZpY2F0aW9uLCBzdWNoIGxpY2Vuc2UgaXMgY29uZGl0aW9uZWQgdXBvbiB5b3VyCisgICAgb2ZmZXJpbmcgb24gZmFpciwgcmVhc29uYWJsZSBhbmQgbm9uLWRpc2NyaW1pbmF0b3J5IHRlcm1zLAorICAgIHRvIGFueSBwYXJ0eSBzZWVraW5nIGl0IGZyb20gWW91LCBhIHBlcnBldHVhbCwgbm9uLWV4Y2x1c2l2ZSwKKyAgICBub24tdHJhbnNmZXJhYmxlLCB3b3JsZHdpZGUgbGljZW5zZSB1bmRlciBZb3VyIHBhdGVudCByaWdodHMKKyAgICB0aGF0IGFyZSBvciB3b3VsZCBiZSBpbmZyaW5nZWQgYnkgYWxsIHRlY2huaWNhbGx5IGZlYXNpYmxlCisgICAgaW1wbGVtZW50YXRpb25zIG9mIHRoZSBTcGVjaWZpY2F0aW9uIHRvIGRldmVsb3AsIGRpc3RyaWJ1dGUKKyAgICBhbmQgdXNlIGEgQ29tcGxpYW50IEltcGxlbWVudGF0aW9uLgorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitDb25jdXJyZW50IGxpYnJhcnkgKGNvbmN1cnJlbnQtMS4zLjQuamFyKQorCisgICAgaHR0cDovL2cub3N3ZWdvLmVkdS9kbC9jbGFzc2VzL0VEVS9vc3dlZ28vY3MvZGwvdXRpbC9jb25jdXJyZW50L2ludHJvLmh0bWwKKworICAgIEFsbCBjbGFzc2VzIGFyZSByZWxlYXNlZCB0byB0aGUgcHVibGljIGRvbWFpbiBhbmQgbWF5IGJlIHVzZWQgZm9yIGFueQorICAgIHB1cnBvc2Ugd2hhdHNvZXZlciB3aXRob3V0IHBlcm1pc3Npb24gb3IgYWNrbm93bGVkZ21lbnQuIFBvcnRpb25zIG9mCisgICAgdGhlIENvcHlPbldyaXRlQXJyYXlMaXN0IGFuZCBDb25jdXJyZW50UmVhZGVySGFzaE1hcCBjbGFzc2VzIGFyZSBhZGFwdGVkCisgICAgZnJvbSBTdW4gSkRLIHNvdXJjZSBjb2RlLiBUaGVzZSBhcmUgY29weXJpZ2h0IG9mIFN1biBNaWNyb3N5c3RlbXMsIEluYywKKyAgICBhbmQgYXJlIHVzZWQgd2l0aCB0aGVpciBraW5kIHBlcm1pc3Npb24sIGFzIGRlc2NyaWJlZCBpbiB0aGlzIGxpY2Vuc2U6CisKKyAgICBURUNITk9MT0dZIExJQ0VOU0UgRlJPTSBTVU4gTUlDUk9TWVNURU1TLCBJTkMuIFRPIERPVUcgTEVBCisKKyAgICBXaGVyZWFzIERvdWcgTGVhIGRlc2lyZXMgdG8gdXRsaXplZCBjZXJ0YWluIEphdmEgU29mdHdhcmUgdGVjaG5vbG9naWVzCisgICAgaW4gdGhlIHV0aWwuY29uY3VycmVudCB0ZWNobm9sb2d5OyBhbmQgV2hlcmVhcyBTdW4gTWljcm9zeXN0ZW1zLCBJbmMuCisgICAgKCJTdW4iKSBkZXNpcmVzIHRoYXQgRG91ZyBMZWEgdXRpbGl6ZSBjZXJ0YWluIEphdmEgU29mdHdhcmUgdGVjaG5vbG9naWVzCisgICAgaW4gdGhlIHV0aWwuY29uY3VycmVudCB0ZWNobm9sb2d5OworCisgICAgVGhlcmVmb3JlIHRoZSBwYXJ0aWVzIGFncmVlIGFzIGZvbGxvd3MsIGVmZmVjdGl2ZSBNYXkgMzEsIDIwMDI6CisKKyAgICAiSmF2YSBTb2Z0d2FyZSB0ZWNobm9sb2dpZXMiIG1lYW5zCisKKyAgICAgICAgY2xhc3Nlcy9qYXZhL3V0aWwvQXJyYXlMaXN0LmphdmEsIGFuZAorICAgICAgICBjbGFzc2VzL2phdmEvdXRpbC9IYXNoTWFwLmphdmEuCisKKyAgICBUaGUgSmF2YSBTb2Z0d2FyZSB0ZWNobm9sb2dpZXMgYXJlIENvcHlyaWdodCAoYykgMTk5NC0yMDAwIFN1bgorICAgIE1pY3Jvc3lzdGVtcywgSW5jLiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCisgICAgU3VuIGhlcmVieSBncmFudHMgRG91ZyBMZWEgYSBub24tZXhjbHVzaXZlLCB3b3JsZHdpZGUsIG5vbi10cmFuc2ZlcnJhYmxlCisgICAgbGljZW5zZSB0byB1c2UsIHJlcHJvZHVjZSwgY3JlYXRlIGRlcml2YXRlIHdvcmtzIG9mLCBhbmQgZGlzdHJpYnV0ZSB0aGUKKyAgICBKYXZhIFNvZnR3YXJlIGFuZCBkZXJpdmF0aXZlIHdvcmtzIHRoZXJlb2YgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMKKyAgICBhcyBwYXJ0IG9mIGEgbGFyZ2VyIHdvcmssIGFuZCB0byBzdWJsaWNlbnNlIHRoZSByaWdodCB0byB1c2UsIHJlcHJvZHVjZQorICAgIGFuZCBkaXN0cmlidXRlIHRoZSBKYXZhIFNvZnR3YXJlIGFuZCBEb3VnIExlYSdzIGRlcml2YXRpdmUgd29ya3MgYXMgdGhlCisgICAgcGFydCBvZiBsYXJnZXIgd29ya3MgdGhyb3VnaCBtdWx0aXBsZSB0aWVycyBvZiBzdWJsaWNlbnNlZXMgcHJvdmlkZWQgdGhhdAorICAgIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9ucyBhcmUgbWV0OgorCisgICAgLU5laXRoZXIgdGhlIG5hbWUgb2Ygb3IgdHJhZGVtYXJrcyBvZiBTdW4gbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvcgorICAgIHByb21vdGUgcHJvZHVjdHMgaW5jbHVkaW5nIG9yIGRlcml2ZWQgZnJvbSB0aGUgSmF2YSBTb2Z0d2FyZSB0ZWNobm9sb2d5CisgICAgd2l0aG91dCBzcGVjaWZpYyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb247IGFuZAorICAgIC1SZWRpc3RyaWJ1dGlvbnMgb2Ygc291cmNlIG9yIGJpbmFyeSBjb2RlIG11c3QgY29udGFpbiB0aGUgYWJvdmUKKyAgICBjb3B5cmlnaHQgbm90aWNlLCB0aGlzIG5vdGljZSBhbmQgYW5kIHRoZSBmb2xsb3dpbmcgZGlzY2xhaW1lcnM6CisKKyAgICBUaGlzIHNvZnR3YXJlIGlzIHByb3ZpZGVkICJBUyBJUywiIHdpdGhvdXQgYSB3YXJyYW50eSBvZiBhbnkga2luZC4KKyAgICBBTEwgRVhQUkVTUyBPUiBJTVBMSUVEIENPTkRJVElPTlMsIFJFUFJFU0VOVEFUSU9OUyBBTkQgV0FSUkFOVElFUywKKyAgICBJTkNMVURJTkcgQU5ZIElNUExJRUQgV0FSUkFOVFkgT0YgTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBCisgICAgUEFSVElDVUxBUiBQVVJQT1NFIE9SIE5PTi1JTkZSSU5HRU1FTlQsIEFSRSBIRVJFQlkgRVhDTFVERUQuIFNVTgorICAgIE1JQ1JPU1lTVEVNUywgSU5DLiBBTkQgSVRTIExJQ0VOU09SUyBTSEFMTCBOT1QgQkUgTElBQkxFIEZPUiBBTlkgREFNQUdFUworICAgIFNVRkZFUkVEIEJZIExJQ0VOU0VFIEFTIEEgUkVTVUxUIE9GIFVTSU5HLCBNT0RJRllJTkcgT1IgRElTVFJJQlVUSU5HCisgICAgVEhFIFNPRlRXQVJFIE9SIElUUyBERVJJVkFUSVZFUy4gSU4gTk8gRVZFTlQgV0lMTCBTVU4gTUlDUk9TWVNURU1TLCBJTkMuCisgICAgT1IgSVRTIExJQ0VOU09SUyBCRSBMSUFCTEUgRk9SIEFOWSBMT1NUIFJFVkVOVUUsIFBST0ZJVCBPUiBEQVRBLCBPUiBGT1IKKyAgICBESVJFQ1QsIElORElSRUNULCBTUEVDSUFMLCBDT05TRVFVRU5USUFMLCBJTkNJREVOVEFMIE9SIFBVTklUSVZFIERBTUFHRVMsCisgICAgSE9XRVZFUiBDQVVTRUQgQU5EIFJFR0FSRExFU1MgT0YgVEhFIFRIRU9SWSBPRiBMSUFCSUxJVFksIEFSSVNJTkcgT1VUIE9GCisgICAgVEhFIFVTRSBPRiBPUiBJTkFCSUxJVFkgVE8gVVNFIFNPRlRXQVJFLCBFVkVOIElGIFNVTiBNSUNST1NZU1RFTVMsIElOQy4KKyAgICBIQVMgQkVFTiBBRFZJU0VEIE9GIFRIRSBQT1NTSUJJTElUWSBPRiBTVUNIIERBTUFHRVMuCisKKyAgICBZb3UgYWNrbm93bGVkZ2UgdGhhdCBTb2Z0d2FyZSBpcyBub3QgZGVzaWduZWQsbGljZW5zZWQgb3IgaW50ZW5kZWQgZm9yCisgICAgdXNlIGluIHRoZSBkZXNpZ24sIGNvbnN0cnVjdGlvbiwgb3BlcmF0aW9uIG9yIG1haW50ZW5hbmNlIG9mIGFueSBudWNsZWFyCisgICAgZmFjaWxpdHkuCisKKz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CisKK1hNTCBBUEkgbGlicmFyeSwgb3JnLnhtbC5zYXggY2xhc3NlcyAoeG1sLWFwaXMtMS4zLjAzLmphcikKKworICAgIFNBWDIgaXMgRnJlZSEKKworICAgIEkgaGVyZWJ5IGFiYW5kb24gYW55IHByb3BlcnR5IHJpZ2h0cyB0byBTQVggMi4wICh0aGUgU2ltcGxlIEFQSSBmb3IKKyAgICBYTUwpLCBhbmQgcmVsZWFzZSBhbGwgb2YgdGhlIFNBWCAyLjAgc291cmNlIGNvZGUsIGNvbXBpbGVkIGNvZGUsIGFuZAorICAgIGRvY3VtZW50YXRpb24gY29udGFpbmVkIGluIHRoaXMgZGlzdHJpYnV0aW9uIGludG8gdGhlIFB1YmxpYyBEb21haW4uCisgICAgU0FYIGNvbWVzIHdpdGggTk8gV0FSUkFOVFkgb3IgZ3VhcmFudGVlIG9mIGZpdG5lc3MgZm9yIGFueSBwdXJwb3NlLgorCisgICAgRGF2aWQgTWVnZ2luc29uLCBkYXZpZEBtZWdnaW5zb24uY29tCisgICAgMjAwMC0wNS0wNQorCis9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQorCitUaGUgdHVzY2FueS1ob3N0LXdlYmFwcCBhbmQgdHVzY2FueS1zY2EtYXBpIGphcnMgaW5jbHVkZSBmaWxlcyB1bmRlciB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6CisKK1Blcm1pc3Npb24gdG8gY29weSwgZGlzcGxheSBhbmQgZGlzdHJpYnV0ZSB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gYW5kL29yCitwb3J0aW9ucyB0aGVyZW9mLCB3aXRob3V0IG1vZGlmaWNhdGlvbiwgaW4gYW55IG1lZGl1bSB3aXRob3V0IGZlZSBvciByb3lhbHR5IGlzIGhlcmVieSBncmFudGVkLCBwcm92aWRlZAordGhhdCB5b3UgaW5jbHVkZSB0aGUgZm9sbG93aW5nIG9uIEFMTCBjb3BpZXMgb2YgdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uLCBvcgorcG9ydGlvbnMgdGhlcmVvZiwgdGhhdCB5b3UgbWFrZToKKworMS4gQSBsaW5rIG9yIFVSTCB0byB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIFNwZWNpZmljYXRpb24gYXQgdGhpcyBsb2NhdGlvbjoKK7cgaHR0cDovL3d3dy5vc29hLm9yZy9kaXNwbGF5L01haW4vU2VydmljZStDb21wb25lbnQrQXJjaGl0ZWN0dXJlK1NwZWNpZmljYXRpb25zCisKKzIuIFRoZSBmdWxsIHRleHQgb2YgdGhlIGNvcHlyaWdodCBub3RpY2UgYXMgc2hvd24gaW4gdGhlIFNlcnZpY2UgQ29tcG9uZW50IEFyY2hpdGVjdHVyZSBTcGVjaWZpY2F0aW9uLgorCitCRUEsIENhcGUgQ2xlYXIsIElCTSwgSW50ZXJmYWNlMjEsIElPTkEsIE9yYWNsZSwgUHJpbWV0b24sIFByb2dyZXNzIFNvZnR3YXJlLCBSZWQgSGF0LCBSb2d1ZSBXYXZlLAorU0FQLCBTaWVtZW5zLCBTb2Z0d2FyZSBBRy4sIFN1biwgU3liYXNlLCBUSUJDTyAoY29sbGVjdGl2ZWx5LCB0aGUgIkF1dGhvcnMiKSBhZ3JlZSB0byBncmFudCB5b3UgYQorcm95YWx0eS1mcmVlIGxpY2Vuc2UsIHVuZGVyIHJlYXNvbmFibGUsIG5vbi1kaXNjcmltaW5hdG9yeSB0ZXJtcyBhbmQgY29uZGl0aW9ucyB0byBwYXRlbnRzIHRoYXQgdGhleSBkZWVtCituZWNlc3NhcnkgdG8gaW1wbGVtZW50IHRoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbi4KK1RIRSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgU1BFQ0lGSUNBVElPTiBJUyBQUk9WSURFRCAiQVMgSVMsIiBBTkQgVEhFCitBVVRIT1JTIE1BS0UgTk8gUkVQUkVTRU5UQVRJT05TIE9SIFdBUlJBTlRJRVMsIEVYUFJFU1MgT1IgSU1QTElFRCwKK1JFR0FSRElORyBUSElTIFNQRUNJRklDQVRJT04gQU5EIFRIRSBJTVBMRU1FTlRBVElPTiBPRiBJVFMgQ09OVEVOVFMsCitJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksIEZJVE5FU1MgRk9SIEEKK1BBUlRJQ1VMQVIgUFVSUE9TRSwgTk9OLUlORlJJTkdFTUVOVCBPUiBUSVRMRS4KK1RIRSBBVVRIT1JTIFdJTEwgTk9UIEJFIExJQUJMRSBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIFNQRUNJQUwsIElOQ0lERU5UQUwKK09SIENPTlNFUVVFTlRJQUwgREFNQUdFUyBBUklTSU5HIE9VVCBPRiBPUiBSRUxBVElORyBUTyBBTlkgVVNFIE9SCitESVNUUklCVVRJT04gT0YgVEhFIFNlcnZpY2UgQ29tcG9uZW50cyBBcmNoaXRlY3R1cmUgU1BFQ0lGSUNBVElPTi4KK1RoZSBuYW1lIGFuZCB0cmFkZW1hcmtzIG9mIHRoZSBBdXRob3JzIG1heSBOT1QgYmUgdXNlZCBpbiBhbnkgbWFubmVyLCBpbmNsdWRpbmcgYWR2ZXJ0aXNpbmcgb3IKK3B1YmxpY2l0eSBwZXJ0YWluaW5nIHRvIHRoZSBTZXJ2aWNlIENvbXBvbmVudCBBcmNoaXRlY3R1cmUgU3BlY2lmaWNhdGlvbiBvciBpdHMgY29udGVudHMgd2l0aG91dCBzcGVjaWZpYywKKworPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KKworVGhlIHR1c2NhbnktYXNzZW1ibHkteHNkIGphciBpbmNsdWRlcyBmaWxlcyB1bmRlciB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6CisKK1czQ64gU09GVFdBUkUgTk9USUNFIEFORCBMSUNFTlNFCitodHRwOi8vd3d3LnczLm9yZy9Db25zb3J0aXVtL0xlZ2FsLzIwMDIvY29weXJpZ2h0LXNvZnR3YXJlLTIwMDIxMjMxCisKK1RoaXMgd29yayAoYW5kIGluY2x1ZGVkIHNvZnR3YXJlLCBkb2N1bWVudGF0aW9uIHN1Y2ggYXMgUkVBRE1Fcywgb3Igb3RoZXIgcmVsYXRlZCBpdGVtcykgCitpcyBiZWluZyBwcm92aWRlZCBieSB0aGUgY29weXJpZ2h0IGhvbGRlcnMgdW5kZXIgdGhlIGZvbGxvd2luZyBsaWNlbnNlLiBCeSBvYnRhaW5pbmcsIAordXNpbmcgYW5kL29yIGNvcHlpbmcgdGhpcyB3b3JrLCB5b3UgKHRoZSBsaWNlbnNlZSkgYWdyZWUgdGhhdCB5b3UgaGF2ZSByZWFkLCB1bmRlcnN0b29kLCAKK2FuZCB3aWxsIGNvbXBseSB3aXRoIHRoZSBmb2xsb3dpbmcgdGVybXMgYW5kIGNvbmRpdGlvbnMuCisKK1Blcm1pc3Npb24gdG8gY29weSwgbW9kaWZ5LCBhbmQgZGlzdHJpYnV0ZSB0aGlzIHNvZnR3YXJlIGFuZCBpdHMgZG9jdW1lbnRhdGlvbiwgd2l0aCBvciAKK3dpdGhvdXQgbW9kaWZpY2F0aW9uLCBmb3IgYW55IHB1cnBvc2UgYW5kIHdpdGhvdXQgZmVlIG9yIHJveWFsdHkgaXMgaGVyZWJ5IGdyYW50ZWQsIHByb3ZpZGVkIAordGhhdCB5b3UgaW5jbHVkZSB0aGUgZm9sbG93aW5nIG9uIEFMTCBjb3BpZXMgb2YgdGhlIHNvZnR3YXJlIGFuZCBkb2N1bWVudGF0aW9uIG9yIHBvcnRpb25zIAordGhlcmVvZiwgaW5jbHVkaW5nIG1vZGlmaWNhdGlvbnM6CisKKyAgIDEuIFRoZSBmdWxsIHRleHQgb2YgdGhpcyBOT1RJQ0UgaW4gYSBsb2NhdGlvbiB2aWV3YWJsZSB0byB1c2VycyBvZiB0aGUgcmVkaXN0cmlidXRlZCBvciAKKyAgICAgIGRlcml2YXRpdmUgd29yay4KKyAgIDIuIEFueSBwcmUtZXhpc3RpbmcgaW50ZWxsZWN0dWFsIHByb3BlcnR5IGRpc2NsYWltZXJzLCBub3RpY2VzLCBvciB0ZXJtcyBhbmQgY29uZGl0aW9ucy4gCisgICAgICBJZiBub25lIGV4aXN0LCB0aGUgVzNDIFNvZnR3YXJlIFNob3J0IE5vdGljZSBzaG91bGQgYmUgaW5jbHVkZWQgKGh5cGVydGV4dCBpcyBwcmVmZXJyZWQsCisgICAgICB0ZXh0IGlzIHBlcm1pdHRlZCkgd2l0aGluIHRoZSBib2R5IG9mIGFueSByZWRpc3RyaWJ1dGVkIG9yIGRlcml2YXRpdmUgY29kZS4KKyAgIDMuIE5vdGljZSBvZiBhbnkgY2hhbmdlcyBvciBtb2RpZmljYXRpb25zIHRvIHRoZSBmaWxlcywgaW5jbHVkaW5nIHRoZSBkYXRlIGNoYW5nZXMgd2VyZSAKKyAgICAgIG1hZGUuIChXZSByZWNvbW1lbmQgeW91IHByb3ZpZGUgVVJJcyB0byB0aGUgbG9jYXRpb24gZnJvbSB3aGljaCB0aGUgY29kZSBpcyBkZXJpdmVkLikKKworVEhJUyBTT0ZUV0FSRSBBTkQgRE9DVU1FTlRBVElPTiBJUyBQUk9WSURFRCAiQVMgSVMsIiBBTkQgQ09QWVJJR0hUIEhPTERFUlMgTUFLRSBOTyAKK1JFUFJFU0VOVEFUSU9OUyBPUiBXQVJSQU5USUVTLCBFWFBSRVNTIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8sIFdBUlJBTlRJRVMgCitPRiBNRVJDSEFOVEFCSUxJVFkgT1IgRklUTkVTUyBGT1IgQU5ZIFBBUlRJQ1VMQVIgUFVSUE9TRSBPUiBUSEFUIFRIRSBVU0UgT0YgVEhFIFNPRlRXQVJFIE9SIAorRE9DVU1FTlRBVElPTiBXSUxMIE5PVCBJTkZSSU5HRSBBTlkgVEhJUkQgUEFSVFkgUEFURU5UUywgQ09QWVJJR0hUUywgVFJBREVNQVJLUyBPUiBPVEhFUiAKK1JJR0hUUy4KKworQ09QWVJJR0hUIEhPTERFUlMgV0lMTCBOT1QgQkUgTElBQkxFIEZPUiBBTlkgRElSRUNULCBJTkRJUkVDVCwgU1BFQ0lBTCBPUiBDT05TRVFVRU5USUFMIAorREFNQUdFUyBBUklTSU5HIE9VVCBPRiBBTlkgVVNFIE9GIFRIRSBTT0ZUV0FSRSBPUiBET0NVTUVOVEFUSU9OLgorCitUaGUgbmFtZSBhbmQgdHJhZGVtYXJrcyBvZiBjb3B5cmlnaHQgaG9sZGVycyBtYXkgTk9UIGJlIHVzZWQgaW4gYWR2ZXJ0aXNpbmcgb3IgcHVibGljaXR5IAorcGVydGFpbmluZyB0byB0aGUgc29mdHdhcmUgd2l0aG91dCBzcGVjaWZpYywgd3JpdHRlbiBwcmlvciBwZXJtaXNzaW9uLiBUaXRsZSB0byBjb3B5cmlnaHQgCitpbiB0aGlzIHNvZnR3YXJlIGFuZCBhbnkgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIHdpbGwgYXQgYWxsIHRpbWVzIHJlbWFpbiB3aXRoIGNvcHlyaWdodCAKK2hvbGRlcnMuCisKZGlmZiAtLWdpdCBhL3Bob3Rhcmstd2ViYXBwL3NyYy9tYWluL3dlYmFwcC9NRVRBLUlORi9OT1RJQ0UgYi9waG90YXJrLXdlYmFwcC9zcmMvbWFpbi93ZWJhcHAvTUVUQS1JTkYvTk9USUNFCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAuLmE0MjNhOTIKLS0tIC9kZXYvbnVsbAorKysgYi9waG90YXJrLXdlYmFwcC9zcmMvbWFpbi93ZWJhcHAvTUVUQS1JTkYvTk9USUNFCkBAIC0wLDAgKzEsNjEgQEAKK0FwYWNoZSBQaG90QXJrCitDb3B5cmlnaHQgKGMpIDIwMDggLSAyMDEwIFRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbgorCitUaGlzIHByb2R1Y3QgaW5jbHVkZXMgc29mdHdhcmUgZGV2ZWxvcGVkIGF0CitUaGUgQXBhY2hlIFNvZnR3YXJlIEZvdW5kYXRpb24gKGh0dHA6Ly93d3cuYXBhY2hlLm9yZy8pLgorCitUaGlzIHByb2R1Y3QgaW5jbHVkZXMvdXNlcyBYbWxTY2hlbWEgZGV2ZWxvcGVkIGF0IAorVGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChodHRwOi8vd3MuYXBhY2hlLm9yZy9jb21tb25zL1htbFNjaGVtYSkKKyBQb3J0aW9ucyBDb3B5cmlnaHQgMjAwNiBJbnRlcm5hdGlvbmFsIEJ1c2luZXNzIE1hY2hpbmVzIENvcnAuCisKK1RoaXMgcHJvZHVjdCBpbmNsdWRlcyBBcGFjaGUgRGVyYnksIHdoaWNoIGlzIGJhc2VkIG9uIHNvdXJjZSBjb2RlIG9yaWdpbmFsbHkKK2RldmVsb3BlZCBhdCB0aGUgSW50ZXJuYXRpb25hbCBCdXNpbmVzcyBNYWNoaW5lcyBDb3Jwb3JhdGlvbi4KKyhDKSBDb3B5cmlnaHQgMTk5NywyMDA0IEludGVybmF0aW9uYWwgQnVzaW5lc3MgTWFjaGluZXMgQ29ycG9yYXRpb24uCitBbGwgcmlnaHRzIHJlc2VydmVkLgorKEMpIENvcHlyaWdodCBJQk0gQ29ycC4gMjAwMy4KKworVGhpcyBzb2Z0d2FyZSBjb250YWlucyBQREYgcmVhZGVyIGZ1bmN0aW9uYWxpdHkgZnJvbSB0aGUgUERGQm94LCBGb250Qm94LCBhbmQKK0plbXBCb3ggcHJvamVjdHMuIENvcHlyaWdodCAoYykgMjAwMy0yMDA1LCB3d3cucGRmYm94Lm9yZyBhbmQgd3d3LmZvbnRib3gub3JnLgorCitUaGlzIHNvZnR3YXJlIGNvbnRhaW5zIFNMRjRKIGxpYnJhcmllcy4gQ29weXJpZ2h0IChjKSAyMDA0LTIwMDggUU9TLmNoCisKK1RoaXMgcHJvZHVjdCBpbmNsdWRlcy91c2VzIHNvZnR3YXJlLCBBT1AgYWxsaWFuY2UgKGh0dHA6Ly9hb3BhbGxpYW5jZS5zb3VyY2Vmb3JnZS5uZXQpCitMaWNlbnNlOiBQdWJsaWMgRG9tYWluIAorCitUaGlzIHByb2R1Y3QgaW5jbHVkZXMvdXNlcyBKU09OLVJQQy1KYXZhIChodHRwOi8vb3NzLm1ldGFwYXJhZGlnbS5jb20vanNvbnJwYy8pCisKK1RoaXMgcHJvZHVjdCBpbmNsdWRlcyBzb2Z0d2FyZSBmcm9tIHRoZSBHbGFzc0Zpc2ggcHJvamVjdCAoaHR0cHM6Ly9nbGFzc2Zpc2guZGV2LmphdmEubmV0LykKKyAgICBDb3B5cmlnaHQgKGMpIDIwMDYsIFN1biBNaWNyb3N5c3RlbXMsIEluYy4KKyAgICAgIAorVGhpcyBwcm9kdWN0IGluY2x1ZGVzL3VzZXMgZG9qb3Rvb2xraXQgKGh0dHA6Ly9kb2pvdG9vbGtpdC5vcmcvKQorIENvcHlyaWdodCAoYykgMjAwNSwgVGhlIERvam8gRm91bmRhdGlvbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC4KKworVGhpcyBwcm9kdWN0IGFsc28gaW5jbHVkZXMgc29mdHdhcmUgdW5kZXIgdGhlIEJTRCBsaWNlbnNlCit3aXRoIHRoZSBmb2xsb3dpbmcgY29weXJpZ2h0OgorIENvcHlyaWdodCAoYykgMjAwNiwgU3VuIE1pY3Jvc3lzdGVtcywgSW5jLiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIHNwZWNpZmljYXRpb24gbGljZW5zZQorKHNlZSB0aGUgTElDRU5TRSBmaWxlIGNvbnRhaW5lZCBpbiB0aGlzIGRpc3RyaWJ1dGlvbikgd2l0aCB0aGUgZm9sbG93aW5nIGNvcHlyaWdodAorCisoQykgQ29weXJpZ2h0IEJFQSBTeXN0ZW1zLCBJbmMuLCBDYXBlIENsZWFyIFNvZnR3YXJlLCBJbnRlcm5hdGlvbmFsIEJ1c2luZXNzIE1hY2hpbmVzIENvcnAsIEludGVyZmFjZTIxLCBJT05BIFRlY2hub2xvZ2llcywKKzM3IE9yYWNsZSwgUHJpbWV0b24gVGVjaG5vbG9naWVzLCBQcm9ncmVzcyBTb2Z0d2FyZSwgUmVkIEhhdCwgUm9ndWUgV2F2ZSBTb2Z0d2FyZSwgU0FQIEFHLiwgU2llbWVucyBBRy4sIFNvZnR3YXJlIEFHLiwgU3liYXNlCiszOCBJbmMuLCBUSUJDTyBTb2Z0d2FyZSBJbmMuLCAyMDA1LCAyMDA3LiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgU2VydmljZSBDb21wb25lbnQgQXJjaGl0ZWN0dXJlIHNwZWNpZmljYXRpb24gbGljZW5zZQorKHNlZSB0aGUgTElDRU5TRSBmaWxlIGNvbnRhaW5lZCBpbiB0aGlzIGRpc3RyaWJ1dGlvbikgd2l0aCB0aGUgZm9sbG93aW5nIGNvcHlyaWdodAorCisoQykgQ29weXJpZ2h0IEJFQSBTeXN0ZW1zLCBJbmMuLCBDYXBlIENsZWFyIFNvZnR3YXJlLCBJbnRlcm5hdGlvbmFsIEJ1c2luZXNzIE1hY2hpbmVzIENvcnAsIEludGVyZmFjZTIxLCBJT05BCitUZWNobm9sb2dpZXMsIE9yYWNsZSwgUHJpbWV0b24gVGVjaG5vbG9naWVzLCBQcm9ncmVzcyBTb2Z0d2FyZSwgUmVkIEhhdCwgUm9ndWUgV2F2ZSBTb2Z0d2FyZSwgU0FQIEFHLiwgU2llbWVucworQUcuLCBTb2Z0d2FyZSBBRy4sIFN1biBNaWNyb3N5c3RlbXMsIEluYy4sIFN5YmFzZSBJbmMuLCBUSUJDTyBTb2Z0d2FyZSBJbmMuLCAyMDA1LCAyMDA4LiBBbGwgcmlnaHRzIHJlc2VydmVkLgorCitUaGlzIHByb2R1Y3QgYWxzbyBpbmNsdWRlcyBzb2Z0d2FyZSB1bmRlciB0aGUgVzNDKHIpIFNvZnR3YXJlIExpY2Vuc2UKKyhzZWUgdGhlIExJQ0VOU0UgZmlsZSBjb250YWluZWQgaW4gdGhpcyBkaXN0cmlidXRpb24pLCB3aXRoIHRoZSBmb2xsb3dpbmcKK2NvcHlyaWdodDoKKworQ29weXJpZ2h0IChjKSAyMDA0IFdvcmxkIFdpZGUgV2ViIENvbnNvcnRpdW0gKE1hc3NhY2h1c2V0dHMgSW5zdGl0dXRlIG9mIFRlY2hub2xvZ3ksIAorRXVyb3BlYW4gUmVzZWFyY2ggQ29uc29ydGl1bSBmb3IgSW5mb3JtYXRpY3MgYW5kIE1hdGhlbWF0aWNzLCBLZWlvIFVuaXZlcnNpdHkpLiAKK0FsbCBSaWdodHMgUmVzZXJ2ZWQuIFRoaXMgd29yayBpcyBkaXN0cmlidXRlZCB1bmRlciB0aGUgVzNDKHIpIFNvZnR3YXJlIExpY2Vuc2UgWzFdIAoraW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwgYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgCit3YXJyYW50eSBvZiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCisKKyAgICBbMV0gaHR0cDovL3d3dy53My5vcmcvQ29uc29ydGl1bS9MZWdhbC8yMDAyL2NvcHlyaWdodC1zb2Z0d2FyZS0yMDAyMTIzMQo=