From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: AS4713 221.184.0.0/13 X-Spam-Status: No, score=-3.0 required=3.0 tests=AWL,BAYES_00,DKIM_INVALID, DKIM_SIGNED,MAILING_LIST_MULTI,RCVD_IN_BL_SPAMCOP_NET,RCVD_IN_DNSWL_HI, SPF_HELO_PASS,SPF_PASS,UNPARSEABLE_RELAY shortcircuit=no autolearn=no autolearn_force=no version=3.4.2 Received: from neon.ruby-lang.org (neon.ruby-lang.org [221.186.184.75]) by dcvr.yhbt.net (Postfix) with ESMTP id B38B11F910 for ; Sun, 13 Nov 2022 08:08:40 +0000 (UTC) Authentication-Results: dcvr.yhbt.net; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=ruby-lang.org header.i=@ruby-lang.org header.b="AnvjN0Xg"; dkim-atps=neutral Received: from neon.ruby-lang.org (localhost [IPv6:::1]) by neon.ruby-lang.org (Postfix) with ESMTP id 4F21B120DC0; Sun, 13 Nov 2022 17:08:38 +0900 (JST) Received: from xtrwkhkc.outbound-mail.sendgrid.net (xtrwkhkc.outbound-mail.sendgrid.net [167.89.16.28]) by neon.ruby-lang.org (Postfix) with ESMTPS id B3FA6120D5E for ; Sun, 13 Nov 2022 17:08:35 +0900 (JST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ruby-lang.org; h=from:references:subject:mime-version:content-type: content-transfer-encoding:list-id:to:cc; s=s1; bh=/+7BuK/0Uuqy6PFzFbLl/efqaPwzbqpgzQBlF9k4IXI=; b=AnvjN0XgHdSDtEtusSdSeELoQyFoPeMVdggfyf5IMzTYXntbn/7f8gGkTdqNZkSVF3rn ubwmNCXJ6AOa0Swgs/ky2wKAzzRGLiwAzexjke5WjHKH3YBkTyAMZTzvF+55bB+2SPQdim O25sZjlXOuFGobnvulQriL2ayhLoJPubtLK9ZHL4jeShESp4qdAuRHqtk+C5/cdTCSjN0C s9jrvCGUMPLKl5QRG1UH8uP66Ft0FX1tn7Sx3GvEvglWVcBBBKckoRyKkyWthAgiDBLQ7q x9xRwIUd4W/yNcKPHrRSvfKhUEuh4Y58yy5u8O2o44i8KnOKyM+F88btb7yuzpZw== Received: by filterdrecv-c8b658c76-rhq4v with SMTP id filterdrecv-c8b658c76-rhq4v-1-6370A600-8 2022-11-13 08:08:32.466489537 +0000 UTC m=+217719.734440471 Received: from herokuapp.com (unknown) by geopod-ismtpd-5-5 (SG) with ESMTP id 5lkPq_-jRrqSoQ18C3b0Og for ; Sun, 13 Nov 2022 08:08:32.412 +0000 (UTC) Date: Sun, 13 Nov 2022 08:08:32 +0000 (UTC) From: "nagachika (Tomoyuki Chikanaga)" Message-ID: References: Mime-Version: 1.0 X-Redmine-Project: ruby-master X-Redmine-Issue-Tracker: Bug X-Redmine-Issue-Id: 18599 X-Redmine-Issue-Author: byroot X-Redmine-Sender: nagachika X-Mailer: Redmine X-Redmine-Host: bugs.ruby-lang.org X-Redmine-Site: Ruby Issue Tracking System X-Auto-Response-Suppress: All Auto-Submitted: auto-generated X-Redmine-MailingListIntegration-Message-Ids: 87191 X-SG-EID: =?us-ascii?Q?5tswmMdpuZtWC+SIdASU151b2aqPGWt2MCGiK8FM5waeDDbfOiDH=2FZvzDCybLH?= =?us-ascii?Q?ac5aUpPkJl2qsSCwuuhJa5kBFsc=2FNuo8RbFzwG3?= =?us-ascii?Q?LHWVN9zG9T9+zuUVNkeiOrAGy6G0R3dCDNqpZSR?= =?us-ascii?Q?LoyrHeo7EBrenQkifvD4IdVl7UtqDxpFE=2FBLwwR?= =?us-ascii?Q?VTUSWTO4GrS5WHp6PQkZgUGixGZBHKS2RVqkreL?= =?us-ascii?Q?zbnUR+fJn5bMFlkhbi4MAjYDFA8IRgo+635yTdC?= =?us-ascii?Q?D4TSMmkLkz09pERhfyQZv15UPInX79muD9GEgpy?= =?us-ascii?Q?808=3D?= To: ruby-core@neon.ruby-lang.org X-Entity-ID: b/2+PoftWZ6GuOu3b0IycA== X-ML-Name: ruby-core X-Mail-Count: 110735 Subject: [ruby-core:110735] [Ruby master Bug#18599] `vm->loaded_features_snapshot` became very inefficient in Ruby 3.1 X-BeenThere: ruby-core@ruby-lang.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Ruby developers List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Reply-To: Ruby developers Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: ruby-core-bounces@ruby-lang.org Sender: "ruby-core" SXNzdWUgIzE4NTk5IGhhcyBiZWVuIHVwZGF0ZWQgYnkgbmFnYWNoaWthIChUb21veXVraSBDaGlr YW5hZ2EpLgoKQmFja3BvcnQgY2hhbmdlZCBmcm9tIDIuNjogV09OVEZJWCwgMi43OiBSRVFVSVJF RCwgMy4wOiBSRVFVSVJFRCwgMy4xOiBSRVFVSVJFRCB0byAyLjY6IFdPTlRGSVgsIDIuNzogUkVR VUlSRUQsIDMuMDogUkVRVUlSRUQsIDMuMTogRE9ORQoKcnVieV8zXzEgMDEyMDE1ZDc2MmQwMDA5 NjZhMzNmY2VhNWYzMDY5ZGVjZDlkNDAwNyBtZXJnZWQgcmV2aXNpb24ocykgYjhmMGRjNTlkNTIy NjZkOWZiZmMwMzllMmY0YjBmNzI3YzYyYmFhMC4KCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0KQnVnICMxODU5OTogYHZtLT5sb2FkZWRfZmVhdHVyZXNfc25hcHNob3Rg IGJlY2FtZSB2ZXJ5IGluZWZmaWNpZW50IGluIFJ1YnkgMy4xCmh0dHBzOi8vYnVncy5ydWJ5LWxh bmcub3JnL2lzc3Vlcy8xODU5OSNjaGFuZ2UtMTAwMDcyCgoqIEF1dGhvcjogYnlyb290IChKZWFu IEJvdXNzaWVyKQoqIFN0YXR1czogQ2xvc2VkCiogUHJpb3JpdHk6IE5vcm1hbAoqIHJ1YnkgLXY6 IHJ1YnkgMy4xLjFwMTggKDIwMjItMDItMTggcmV2aXNpb24gNTNmNWZjNDIzNikgW3g4Nl82NC1k YXJ3aW4yMF0KKiBCYWNrcG9ydDogMi42OiBXT05URklYLCAyLjc6IFJFUVVJUkVELCAzLjA6IFJF UVVJUkVELCAzLjE6IERPTkUKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LQpBIGNoYW5nZSBpbiBob3cgc2hhcmVkIGFycmF5cyBiZWhhdmUgaGFzIGNhdXNlZCBhIGZhaXJs eSBtYWpvciBwZXJmb3JtYW5jZSByZWdyZXNzaW9uIGluIGBLZXJuZWwucmVxdWlyZWAuIEluIHNo b3J0IG9uIGV2ZXJ5IHNpbmdsZSBjYWxsLCBhIGZ1bGwgY29weSBvZiBgJExPQURFRF9GRUFUVVJF U2AgaXMgbWFkZS4KCkluIG91ciBhcHAgdGhpcyBjYXVzZXMgb3ZlciA2R2lCIHdvcnRoIG9mIHVz ZWxlc3MgYWxsb2NhdGlvbnMuCgojIyMgUmVwcm9kdWN0aW9uCgpgYGBydWJ5CiMgZnJvemVuX3N0 cmluZ19saXRlcmFsOiB0cnVlCnJlcXVpcmUgIm9ianNwYWNlIgpmaWxlcyA9IDUudGltZXMubWFw IHsgfGl8ICIvdG1wL2Zvby0je2l9LnJiIiB9CmZpbGVzLmVhY2ggeyB8ZnwgRmlsZS53cml0ZShm LCAiIikgfQoKcmVxdWlyZSBmaWxlcy5zaGlmdAo0LnRpbWVzIHsgR0Muc3RhcnQgfQpnZW5lcmF0 aW9uID0gR0MuY291bnQKCk9iamVjdFNwYWNlLnRyYWNlX29iamVjdF9hbGxvY2F0aW9ucyBkbwog IGZpbGVzLmVhY2ggeyB8ZnwgcmVxdWlyZSBmIH0KZW5kCgpPYmplY3RTcGFjZS5kdW1wX2FsbChv dXRwdXQ6IEZpbGUub3BlbigiL3RtcC9hbGxvY2F0ZWQuaGVhcCIsICJ3KyIpLCBzaW5jZTogZ2Vu ZXJhdGlvbikKT2JqZWN0U3BhY2UuZHVtcF9hbGwob3V0cHV0OiBGaWxlLm9wZW4oIi90bXAvZnVs bC5oZWFwIiwgIncrIikpCmBgYAoKSWYgeW91IGluc3BlY3QgdGhlIGBhbGxvY2F0ZWQuaGVhcGAs IHlvdSdsbCBub3RpY2UgNCBhcnJheSwgZWFjaCBpbmNyZWFzaW5nbHkgYmlnZ2VyLgoKYGBgCiQg Z3JlcCBBUlJBWSAvdG1wL2FsbG9jYXRlZC5oZWFwIAp7ImFkZHJlc3MiOiIweDEwZmUyYjNiOCIs ICJ0eXBlIjoiQVJSQVkiLCAiZnJvemVuIjp0cnVlLCAibGVuZ3RoIjo5MiwgInJlZmVyZW5jZXMi OlsiMHgxMGZjZDNkYTgiLCAiMHgxMGZjY2EyYTgiLCAiMHgxMGZjYzIxYzAiLCAuLi5dLCAiZmls ZSI6IjxpbnRlcm5hbDovb3B0L3J1Ymllcy8zLjEuMC9saWIvcnVieS8zLjEuMC9ydWJ5Z2Vtcy9j b3JlX2V4dC9rZXJuZWxfcmVxdWlyZS5yYj4iLCAibGluZSI6ODUsICJtZXRob2QiOiJyZXF1aXJl IiwgImdlbmVyYXRpb24iOjEzLCAibWVtc2l6ZSI6Nzc2LCAiZmxhZ3MiOnsid2JfcHJvdGVjdGVk Ijp0cnVlfX0KLi4uCnsiYWRkcmVzcyI6IjB4MTBmZTJiNjg4IiwgInR5cGUiOiJBUlJBWSIsICJm cm96ZW4iOnRydWUsICJsZW5ndGgiOjkxLCAicmVmZXJlbmNlcyI6WyIweDEwZmNkM2RhOCIsICIw eDEwZmNjYTJhOCIsICIweDEwZmNjMjFjMCIsIC4uLl0sICJmaWxlIjoiPGludGVybmFsOi9vcHQv cnViaWVzLzMuMS4wL2xpYi9ydWJ5LzMuMS4wL3J1YnlnZW1zL2NvcmVfZXh0L2tlcm5lbF9yZXF1 aXJlLnJiPiIsICJsaW5lIjo4NSwgIm1ldGhvZCI6InJlcXVpcmUiLCAiZ2VuZXJhdGlvbiI6MTMs ICJtZW1zaXplIjo3NjgsICJmbGFncyI6eyJ3Yl9wcm90ZWN0ZWQiOnRydWV9fQouLi4KeyJhZGRy ZXNzIjoiMHgxMGZlMmI5NTgiLCAidHlwZSI6IkFSUkFZIiwgImZyb3plbiI6dHJ1ZSwgImxlbmd0 aCI6ODksICJyZWZlcmVuY2VzIjpbIjB4MTBmY2QzZGE4IiwgIjB4MTBmY2NhMmE4IiwgIjB4MTBm Y2MyMWMwIiwgLi4uXSwgImZpbGUiOiI8aW50ZXJuYWw6L29wdC9ydWJpZXMvMy4xLjAvbGliL3J1 YnkvMy4xLjAvcnVieWdlbXMvY29yZV9leHQva2VybmVsX3JlcXVpcmUucmI+IiwgImxpbmUiOjg1 LCAibWV0aG9kIjoicmVxdWlyZSIsICJnZW5lcmF0aW9uIjoxMywgIm1lbXNpemUiOjc1MiwgImZs YWdzIjp7IndiX3Byb3RlY3RlZCI6dHJ1ZX19Ci4uLgp7ImFkZHJlc3MiOiIweDEwZmUyYmMyOCIs ICJ0eXBlIjoiQVJSQVkiLCAiZnJvemVuIjp0cnVlLCAibGVuZ3RoIjo4OCwgInJlZmVyZW5jZXMi OlsiMHgxMGZjZDNkYTgiLCAiMHgxMGZjY2EyYTgiLCAiMHgxMGZjYzIxYzAiLCAuLi5dLCAiZmls ZSI6IjxpbnRlcm5hbDovb3B0L3J1Ymllcy8zLjEuMC9saWIvcnVieS8zLjEuMC9ydWJ5Z2Vtcy9j b3JlX2V4dC9rZXJuZWxfcmVxdWlyZS5yYj4iLCAibGluZSI6ODUsICJtZXRob2QiOiJyZXF1aXJl IiwgImdlbmVyYXRpb24iOjEzLCAibWVtc2l6ZSI6NzQ0LCAiZmxhZ3MiOnsid2JfcHJvdGVjdGVk Ijp0cnVlfX0KLi4uCmBgYAoKQW5kIGlmIHlvdSBsb29rdXAgdGhlIGFkZHJlc3NlcyBpbiBgZnVs bC5oZWFwYCwgaXQgbWFrZXMgbm8gZG91YnQgdGhhdCBpdCdzIGAkTE9BREVEX0ZFQVRVUkVTYC4K Ck5vdGUgaG93ZXZlciBob3cgdGhlIGFycmF5IGlzIGAiZnJvemVuIjp0cnVlYCwgc28gaXQncyBu b3QgYCRMT0FERURfRkVBVFVSRVNgIGRpcmVjdGx5LCBidXQgdGhlIHNoYXJlZCBhcnJheSB0aGF0 IGJhY2tzIGB2bS0+bG9hZGVkX2ZlYXR1cmVzYCBhbmQgYHZtLT5sb2FkZWRfZmVhdHVyZXNfc25h cHNob3RgLgoKCiMjIyBNb3JlIHNjb3BlZCByZXByb2R1Y3Rpb24KCklmIHdlIHNjb3BlIG9uIHNo YXJlZCBhcnJheXMgYmVoYXZpb3Igc3BlY2lmaWNhbGx5LCB3ZSBjYW4gZ2V0IGEgbXVjaCBzbWFs bGVyIHJlcHJvZHVjdGlvbjoKCmBgYHJ1YnkKYXJyYXkgPSAxMC50aW1lcy50b19hCmNvcHkgPSBh cnJheS5kdXAKYmVmb3JlID0gR0Muc3RhdCg6dG90YWxfYWxsb2NhdGVkX29iamVjdHMpCmNvcHkg PDwgMQpwIEdDLnN0YXQoOnRvdGFsX2FsbG9jYXRlZF9vYmplY3RzKSAtIGJlZm9yZSAjIDEgb24g UnVieSAzLjEsIDAgb24gMy4wIGFuZCBvbGRlcgpgYGAKCkluIHNob3J0LCBiYWNrIGluIDMuMCBh bmQgb2xkZXIsIGFwcGVuZGluZyB0byBhIHNoYXJlZCBhcnJheSB3b3VsZG4ndCAidW5zaGFyZSIg dGhlIGFycmF5LCBidXQgc3RhcnRpbmcgaW4gMy4xIGl0IG5vdyBkb2VzLgpUaGUgcHJvYmxlbSBi ZWluZyB0aGF0IGBLZXJuZWwucmVxdWlyZWAgaGVhdmlseSBhc3N1bWVkIHRoaXMgaW1wbGVtZW50 YXRpb24gZGV0YWlsOgoKYGBgYwpzdGF0aWMgdm9pZApyZXNldF9sb2FkZWRfZmVhdHVyZXNfc25h cHNob3QocmJfdm1fdCAqdm0pCnsKICAgIHJiX2FyeV9yZXBsYWNlKHZtLT5sb2FkZWRfZmVhdHVy ZXNfc25hcHNob3QsIHZtLT5sb2FkZWRfZmVhdHVyZXMpOwp9CgpyYl9wcm92aWRlX2ZlYXR1cmUo cmJfdm1fdCAqdm0sIFZBTFVFIGZlYXR1cmUpCnsKICAgIC8vLi4uCiAgICBnZXRfbG9hZGVkX2Zl YXR1cmVzX2luZGV4KHZtKTsKICAgIHJiX2FyeV9wdXNoKGZlYXR1cmVzLCByYl9mc3RyaW5nKGZl YXR1cmUpKTsKICAgIGZlYXR1cmVzX2luZGV4X2FkZCh2bSwgZmVhdHVyZSwgSU5UMkZJWChSQVJS QVlfTEVOKGZlYXR1cmVzKS0xKSk7CiAgICByZXNldF9sb2FkZWRfZmVhdHVyZXNfc25hcHNob3Qo dm0pOwp9CmBgYAoKYHJiX3Byb3ZpZGVfZmVhdHVyZWAgZmlyc3QgYXBwZW5kIHRvIGAkTE9BREVE X0ZFQVRVUkVTYCBhbmQgdGhlbiByZXNldHMgYHZtLT5sb2FkZWRfZmVhdHVyZXNfc25hcHNob3Rg IHRvIGJlIGEgc2hhcmVkIGNvcHkgb2YgYCRMT0FERURfRkVBVFVSRVNgLgoKCgoKCi0tIApodHRw czovL2J1Z3MucnVieS1sYW5nLm9yZy8K