public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Yixun Lan" <dlan@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/riscv:master commit in: www-client/firefox/files/icon/, www-client/firefox/files/, www-client/firefox/
Date: Sat,  8 Apr 2023 21:16:32 +0000 (UTC)	[thread overview]
Message-ID: <1680988529.3a343ba4c4c05e9f1e9721480c4542f64a6e9ace.dlan@gentoo> (raw)

commit:     3a343ba4c4c05e9f1e9721480c4542f64a6e9ace
Author:     Yixun Lan <dlan <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  8 21:15:29 2023 +0000
Commit:     Yixun Lan <dlan <AT> gentoo <DOT> org>
CommitDate: Sat Apr  8 21:15:29 2023 +0000
URL:        https://gitweb.gentoo.org/proj/riscv.git/commit/?id=3a343ba4

www-client/firefox: drop it, as already pushed to official portage

Signed-off-by: Yixun Lan <dlan <AT> gentoo.org>

 www-client/firefox/Manifest                        |   99 -
 .../firefox/files/disable-auto-update.policy.json  |    5 -
 www-client/firefox/files/distribution.ini          |   42 -
 www-client/firefox/files/firefox-r1.sh             |  116 -
 .../firefox/files/firefox-riscv64-hack.patch       |  102 -
 .../firefox/files/firefox-riscv64-support.patch    | 3283 --------------------
 www-client/firefox/files/gentoo-default-prefs.js   |   12 -
 www-client/firefox/files/gentoo-hwaccel-prefs.js   |    3 -
 .../firefox/files/gentoo-hwaccel-prefs.js-r2       |    5 -
 www-client/firefox/files/icon/firefox-r2.desktop   |  236 --
 www-client/firefox/files/icon/firefox-r3.desktop   |  236 --
 www-client/firefox/files/icon/firefox-symbolic.svg |   64 -
 www-client/firefox/firefox-103.0.1.ebuild          | 1301 --------
 www-client/firefox/metadata.xml                    |   40 -
 14 files changed, 5544 deletions(-)

diff --git a/www-client/firefox/Manifest b/www-client/firefox/Manifest
deleted file mode 100644
index c8e20c7..0000000
--- a/www-client/firefox/Manifest
+++ /dev/null
@@ -1,99 +0,0 @@
-DIST firefox-103-patches-03j.tar.xz 19152 BLAKE2B dc4080f058bccfe3e092834501ee6210f44a02291d177b3aba5ebf6909d612411c622c794f30437136a8826c2bfe94f568dabdf05360f9a8f14dbe742404d195 SHA512 6edbfa089a0dd97a987065d63c4c2cba417cacdd45e9a6081193e87cae60c38e6327b0cdef0c1f272e082e985289d9bb6807caf262c272165362e696ca974010
-DIST firefox-103.0.1-ach.xpi 454180 BLAKE2B 350e8fba5485ed23db305f149e517964a89c058f61144cdfad78c83afac291d6f3214fe480fca7b54cd66434494a79f20d4b57e8e96782973528a65759f8d680 SHA512 36efc86cab0ad0232c25645f94968c6aada5c96e693cf93ca3d244da99942bae6791b8ca8b9a689ffb7e8bac5afa0466178455215350eb3140bd2ca63d764fd5
-DIST firefox-103.0.1-af.xpi 419567 BLAKE2B 7d1d7769906e262cc135bf760fa0bdc34b5ccc3e821082be68a00770253e04f30633f61855558d13158a29c9280c6cb95bdf44488b7da79e0d00b3f0b6bba154 SHA512 e204446bc2fca06d536bce01d9d920f8c6aad2a78ea1cdd4e149582616bde6d1155e5a0aab91119e7b02052368cfe5662bf6636d5fe18c9ab147a357b35a54f5
-DIST firefox-103.0.1-an.xpi 498031 BLAKE2B e7440682fbaef6cda8d5e6f0069d8385fcc112b22613c6221cbc31f7b5ec683479458f42164275ff695ec3b765588db38dfb83a2f26afa1b1c896aad4dc3577d SHA512 35540a4ce39efc8c65282bf5e5934f3b1d932db295976a889f3086437454d0bd0987af17feb6d935154dea41476f59a32910d1196099fdeacb12507a4d067e77
-DIST firefox-103.0.1-ar.xpi 561680 BLAKE2B 606e04a5f6bd8f5b79b9d80b8cf180d21a181a4a5b15d1556879fe8fdbba80c7fc24e6055a5cc4ebf1a9c9069100f61fb670bc32ac3cac7af9c7539cfd611ef9 SHA512 156c635d58dc4283cda6ea951886732747e724228933a3aebf8c7ff1629660a529f5c2052613240dd8c9c85186b754edd26462108dbc3cb6c3951d2bceaedeab
-DIST firefox-103.0.1-ast.xpi 494288 BLAKE2B c443bda216ea18aad76cabf5649977e8b1023012fbc46e986a2cdd08e6bf67b7c8f471025b1c591173749223f975ff71eef3b9bc4c5053728e76d55d22a279c2 SHA512 e8e8b71dde722dfad3360c8b578bd3ba1ea40efcb9214cc5a25e82f90c0d4fcaca16a070e346493b81237bf4265d81523c198d02ea3225eae83622b96062be59
-DIST firefox-103.0.1-az.xpi 485448 BLAKE2B d8095924cc95dee7d2aa16761d79dc6e5bb9070c25562b56c49e3415bb81bfaf773d15554f3128a8da011f860d5ccfed010f32039831b52ed701c24580d26f1a SHA512 2abcef585eaef03f6cce10bb39e9c8de05a324620762f0bdaddbe15550afe65dcc35d71d564c84c2bc263c4d1c1a0aa2119e5a1265b2a3247aa0247222e9b311
-DIST firefox-103.0.1-be.xpi 625934 BLAKE2B 85b364e2f6232afbe0e1d8a1f1837e61dd63443746f14f4129b2249de073b8834028f19a0cc2b09d7b99d01a697f157d0d9769bec919406e4f183f48138cc8a1 SHA512 c887055d8369cabaca43a401011cd4c706f0546ba6ed4648980b0824e75edf73f91673354ccda1355967efe70b289d8f8bb9f581cdc37b05ac41ed8231357e06
-DIST firefox-103.0.1-bg.xpi 574190 BLAKE2B a45d5acddc70f08999e657e5eb3055fcab55ab1b21b29e4c9f9ab67db4b96d8472859367683caa0f26069727d675f90b32e9918fcbbc0d237550fdf2e2f2dea2 SHA512 e0e0e67921bc67ef16cb40fdb6543b39c935d20940a2ed18416f70662d9504a0743a1dab841214bb087ed6472b30d944beb8479eac3986c4287ce1df758630e4
-DIST firefox-103.0.1-bn.xpi 576223 BLAKE2B bf5cdae17920b8946d641aaf78b5a1d7d8bb0c8b3a64cc56458f0c75d2063712fd28ca6955c500c5ad5aab400a2e1f9c3d66ac5dd074bc79271e06304b9e9557 SHA512 1739c3125eeb6826b016ea4d28844e71d45e0bad2f4d422b8c7677dad34b03660840ebafbaedc1fe27c7f66b9a9ed42d0a57c32bbfcc59a7c53493a0ec9e7d9d
-DIST firefox-103.0.1-br.xpi 532123 BLAKE2B 38ce46e4f98ec47190aab10156d37a0589bac61cce0945734a043bfe2fd761da0596fc807592f87dab4c2c9d02ab30d9db2bcc5cf01434be2d7f89d7bad97d40 SHA512 025ea89eba79d5db4d1fe3e277aa9a1e511b8ed7dc2e613059e131575f0abb09715b04de451db552040499e2f6b29421384f315e0fbeccd7f9fecb892b44a52b
-DIST firefox-103.0.1-bs.xpi 462892 BLAKE2B 97222965a6f465b797d208cdb19a7a7c3d2c5a340c5661600ad8bd5d5c10b06b8ce2837ee1af69d75c62cfac0d596f930671778bc831a2a9d013096ece9e6b9a SHA512 bb23a6361e21c2a46d1800d5628e96164db29ba2b8121ba1ca7c590920d3239bf9b5d3d09595a303a2053c9123467bfb0eaceb9dcdec7618c4e2d5fbc91bdee8
-DIST firefox-103.0.1-ca-valencia.xpi 537351 BLAKE2B f39260718b26764535ee9816f45f2fffcd22c0e13043b8243fd285b9c132a90e9e59cd30bfbf3730e29c6d96716534b4a14eb36067abe178ad7971b4a5957ae8 SHA512 dca2e423d4c6390a53eb6caa50aaf093150beb97a3f7a39a937e36235a69e1d4d0fff66629ecc60f63ca35bca3559d5e21d9b4fcd4ced40403c23317cabe543d
-DIST firefox-103.0.1-ca.xpi 534088 BLAKE2B 63835ab296d47859ba2ea60fab1d8c6a1352cf48522e0587bf893291fa4e13411236ca9931a011d4f7c4a0f5e853c144faaacd87442164de236222f618691e0d SHA512 763dcaeed9adc56df75eb4632b6a9184b59b22f5518a223910d20934ade76467b5b2732148fc2f5342ba0371d9682ddf354ccd4b8a3823caedf3b918e44a4e0a
-DIST firefox-103.0.1-cak.xpi 550806 BLAKE2B f01eb8c0bced05784340040546b88c089f0808e1f9b060714ef2ad0fe1ecfb5577f545133c3bf1e5090f6a9efc16dc5faa41f4a997fb3025f44021b2573e8660 SHA512 470917b8df6592f14386a502706c0da6ea787be0599b6b9bc455a4c7532d3b03fad2765fa2c100f62a9a552dab4180c23b3ca992dbda90685e6c4f62f3100851
-DIST firefox-103.0.1-cs.xpi 567609 BLAKE2B 065e5ace8afe256c5439a5661366213f488554b73a5c92b8fa2b0d57120010e5a463d67cb05f624bc7afde81c8afe4018c5517c9337c750022369cf2275b08f0 SHA512 8b60e4284e6c4bae9fa3cd67d58dee9b0ef76f8669585a6eaf8756aa0bbf1452e2c456cd377e70702a2c3407b74198aa086c94b1ea51a2ce919df938ba244ded
-DIST firefox-103.0.1-cy.xpi 545481 BLAKE2B bf45c050be5435c55071e00d1bd0e88c782c75e2e939a63b962bd305a2a1ae75a955783e218c5b495d11d1bee428531c176dc66db04430150639f62286fdffe6 SHA512 a9e91cb710400b9004ac614c74398a30a2d0c811b7f5f2e470192255162a7a5b13e71c8b247ae2a19a7e5397486fbda516b33742ef4a599b57a36e5f390890b9
-DIST firefox-103.0.1-da.xpi 535886 BLAKE2B 12d78d808f512600a1514dbe01ae5dc77e92341e7157f86782a1d2ef913f1dffd9ed34ab14202de6e51fbeb89bc9f43ac0c5a47c93e5baea1a70399a2feaed25 SHA512 c54e5c9d28b709554408c762d9976bc18d2288cbee10e08b7a4ca215ed50be9033ea2f9b2c1a35e12df80fc0939a5b945dcf5cb693884fd05b9e2ac457527a15
-DIST firefox-103.0.1-de.xpi 555988 BLAKE2B 303a0be5291c9173c1d20c9b1a8cf20e77530d394bf80e071007802234577553bdce636cb791bf880924d85ce82cfb993063e9272d8e8db96ca1566c4d19c4d2 SHA512 4cce07a305c17a1516aef2eff0b525a62b37e4f0a03cba62dd54db4a53a4205fe8f908284aaf7dbeddc51f0c3b7cf4b7196fca0a058a76e402039cc790febcbc
-DIST firefox-103.0.1-dsb.xpi 569472 BLAKE2B 06b0345fb26895a0f99791310ac9782244b86d059561f3dfe1273f95a3bd42312ed73ca1720822048f582931699a9c3149d85556f4508ffa0769ac5c750910a0 SHA512 6ffece90e31be81a1352fc8b3b8b25df7d7cabe4788d7398b767ddcdb49822658e0dc0de1bff74078362465ec26c8bcd1e5e35b213281ee9503ca4ace270dfed
-DIST firefox-103.0.1-el.xpi 640805 BLAKE2B 044d238602aff05a75cc31446ee718e681fc93d7681f9e785020f9c774f1a2b980931e03a99942f615fcb1c7874803459b1112a2c29e180e3654b42573ecdf47 SHA512 294d31c28806632fe879350b42cb3e3fa999904c275da304aa9190a797bf5fbe479441180938cf728429e59a5e75b0be2bb59d6ba4454ba6f875ed7f9539acad
-DIST firefox-103.0.1-en-CA.xpi 513842 BLAKE2B 9bffcb48c629e6031ebb67ec4a7cd2204c5426bc06dad92e975acbdbaeb17a8cd8b208bfe42a1c1373b8658a165d84c644229e7827c6ffa0274b17f159600f92 SHA512 bc786ed24bc241d226636e8154cc1750321370326d5e67eb4fa9181b6498e8cff783b2af257ef702bf29b44798ca22852589538860ae3351482e9d886b61d28f
-DIST firefox-103.0.1-en-GB.xpi 514045 BLAKE2B ee925bd08b5e9d4e202337e85351129ae6983e1d83c6a7dcd2f5ac455768a356ca83eb9e9dbe286a887c23dfb1dbf9d29546b06f2ded3dd98e47b0cf1bcb1ead SHA512 54b778e963875b7063deb20d34bcf65f2a4b60050946f63ecc1c2c1119176694e453e60bc2944f8bf91e4d399e765be5d37277db249e576cb0f237ab0b1876c0
-DIST firefox-103.0.1-eo.xpi 540165 BLAKE2B 4a6540f04e0f1b247fb3fb9b0e9332ef5fd4d25fcf33d845e7a60dc46d25201151cb1601a868deec0810c0c001890e5105dda97cf6819687e8c03251d4e13568 SHA512 87bf652f5a8c14b5f029d6d229a951e5d1e513bc5a89b605d32046ae950f7fcf9cad36dcb7531b9ba6ea364161d0b5d0116b39e15c58f000cf66a17c6979a909
-DIST firefox-103.0.1-es-AR.xpi 550477 BLAKE2B 674e6f2779d0a5da638441f5cad8bcddfc095cbbe2dfccf8610e85b405dad60999f0db352aeb0bb298c0748449186f95a03b388d11ec3a331ef456cd1971d071 SHA512 5e7eda59a7ab6aaf8274d21f30863192aac640e0060b3c3874a58190483ce7db359d41115196d8dc5691c9f331e8243b6eb3c570b1c9dc4160a0b7f38a24c023
-DIST firefox-103.0.1-es-CL.xpi 549855 BLAKE2B 520a1bdada5b63de8af347520f78dfe1c30941510b9f2ab4cee215766c13f1318f938b610f06b88d346e2742eff400b847a1675a10a4c08d4604377e9394820e SHA512 b664a17962cc7341da4e2c4623b5a3869e8c028cbe1972d13ca02dcf1c3ff3da1f4426aa24e017b506eacc018c4b05b1d0f25325e2ca36a6b3175431aafa8b89
-DIST firefox-103.0.1-es-ES.xpi 541257 BLAKE2B ee8032d66e174309a8ec8457c9929ae05a3860ccd6d08b4ba5088eb2f385e6b406335a0a8b797b28db42e4bf9a4ac3f989a0740419d36194c38bdb7711b58ef6 SHA512 57eb8cd2376208cc3daf5adbcfb2c577857a8a1d6ca1c38a0d862024c1677e6b667cc18d6c99003acdc13fe56c04bc02aa425af0ff22476a0ae03128315e87e6
-DIST firefox-103.0.1-es-MX.xpi 553698 BLAKE2B 8a1c7c690915485e233de7c517688eb906c1cae737fb9be424f3809b51b0a394c656a5d3f09db975802c9c16f5b5d67e8ad3cf3a70a1ac046ad8f08fc10ff2d2 SHA512 bb7110e8370dfdc3a5386c710373fe4d38b795ef1d42896dc255609797a3009d9b94b25a45e9e600efed32c2f8b0d34e923738712026fee69a09c955f5dfe4b2
-DIST firefox-103.0.1-et.xpi 530732 BLAKE2B af9867d87c191d7f4d3bc47d3b3a8cc4fcdec651e7bc4704bbcd12c6ee5a9cef081b83ca16c9b4a31e45599bf8e749a4a9cc8bb1b90da40a618267e7a968b005 SHA512 9e848eda97cc0733a87d909bad8634c6ce2c4f993209be354b5f35d22e3a1157963d0d25fea8ebbfd6c1cc84974f5b0236cc29bcdeeaba40b8187a2eed9f3e4f
-DIST firefox-103.0.1-eu.xpi 540016 BLAKE2B 23cc04352ed44180903f0873afca91740dac6855aafef6592801c32fe10df33a85b059e79cbe81cd750701a7da79023c1a477a330627c085198e25172f0a66bf SHA512 a4ff6ac7c33166a14b2cd32b8f2f0204c9278f6fd633af42868c944862064847dc13efe1080ea9ffe72fa0477a63ec980b1124960f16cc03485595953f9092c7
-DIST firefox-103.0.1-fa.xpi 561835 BLAKE2B 57a0e1881388a6d8c28eeb848783ff72946a83b3a214e9635f4c9feb03c2e6f6cc2ede18971275b66be52ef27df44f5da5ed06572ff1b1be77b7be62fb70371b SHA512 00f567229df51a5c33a55c08475ead09f1eb85029f414b6206de47d892ebfd7d4cbb303fc761cec289625f1641179305d467fb2400426c4bd31b0d4b2888847e
-DIST firefox-103.0.1-ff.xpi 472339 BLAKE2B d0756543217ce5a001546de3e7c2229864aed307eb0edb1800ae598d4267a8a695cc68b24d0430052db94afa8a1ff69c7bd365f87cb218a11eae5c6b06f28867 SHA512 b42180bb24e5fee6f4ef2ad6a8404945855faf20b8bd9b552903c2a38dd0c23ba0868a8449209ae82b551288a471f5350b4f1dbb15097f0beff10f7f5e396169
-DIST firefox-103.0.1-fi.xpi 534455 BLAKE2B b901dcc37911b268a9c04279885d1fa58b706bc06e4cc6be44c1d44c553ee2cc73024cbcce43112c23c669da455cc8732b4794e845d3327b188ebffa00a7b4f7 SHA512 53951a57c1becfb18db6ad601780b49fd4d4b3b2eda24040b5cf508d465aec23abe61d9fa086d91b99debfcc2755524f488ef5a6776701d08dc7dc500cdb9f2c
-DIST firefox-103.0.1-fr.xpi 561669 BLAKE2B c1609a28d03aa599805968794814747b8825845de3be33ea12e77b0f32c8a8325288e072b78879a54c644bb0631f878b4a21a92c9b1086a6ace1125367432f21 SHA512 261867c89c5f4331faec401b5ad0f9e166760e032924646bc8b6d0d77ddb82b4d150112baee565d5f7a47c195f90eba6a55656bb2f79a556c470603407cca312
-DIST firefox-103.0.1-fy-NL.xpi 546731 BLAKE2B d0aa5d376cca3f97df44af1d9f7987c169e76e07ae732ad79e0198a135c95288915bab75161da3f2205a29c99d82feffd051d07b2527ca5a1930a66b8fa5ca41 SHA512 6519b9d52a9f3ed650076c991fc6cf24713a2f203b047938e6abc642e2ba343e124ff39d8476ae58bfcca93cc99f11213d78d1710c5946ae4b62947a421492b6
-DIST firefox-103.0.1-ga-IE.xpi 471799 BLAKE2B bdd5c5d5d55b0a19b195d81081c285d66688a75291ac23fa0666c74b94a6e92c194923118ea348f4e59140d1f3ebbe4999ef5c3eeed41cdf9ca11436ccf0bace SHA512 2a0ee31afabe79e4f00f8f385953dd7cdb5f80273a4027b776396e2dd26709c0f28c48214f1a62858fd73ea8cbab7ce829f69f78781d283458af47f2a1152b4a
-DIST firefox-103.0.1-gd.xpi 533648 BLAKE2B b97b0f198d86a6968220af72f0915c8c1d41bdfe950349430ebccac97cb403cf127f82978648d043f3699e1c3f6b640fad96ab8d2061953aae5e531ec0b4750b SHA512 56cb374044b5e7a5a924029dc6397601b6e87cf943af8d2f79c9e38df8c97a052d0c992f6e44158e6a23fb3b002e4d85a1592251f7d3c2e60b0f91f9f46cd600
-DIST firefox-103.0.1-gl.xpi 540057 BLAKE2B 0ec6b40c7a9175f127f96e52b79becd9882fe5623f3cf00561ce7c41c4cc73579a1e6fd6e3a9040ee3f6231778034390a86bc479d4389f57fd8f1500f57853c6 SHA512 60116df1014606b97935f36984140b4ff96fbc16e23d749965a94aadabfb43fd098aef9a650763ad30bf3c25ef394a84443e2666075a6e05bea2280955b02ec8
-DIST firefox-103.0.1-gn.xpi 561564 BLAKE2B e1a29760ebb3384d86a83acd8ec196810f57b985ba5d6e5e4dd1fd0be4bf9a265d4604c08b35b4e26b21d703a2694a21a8e41a89032ab6a40bbf68084ab742d5 SHA512 1a044632779a9d7e7040b9ab2cc1da0ab124fef35a6fb70f9fa161fe818d9d6eb9ca0063d6bc8a2d1690e52ecc4aea5226ae3f8f0ab0531df5316d6e6f14da4b
-DIST firefox-103.0.1-gu-IN.xpi 526869 BLAKE2B a891065c702f8eb2137e024b2268f6a03726469575ac695d1c087716a4093f9290fa72b33b195dc708f47f55fcd2fa3fbe411da499fb73dd63e84cada772e4c4 SHA512 2177171610d3466d1c4a26932ae32728bc1363b631f6964f4bcd36cd643230f5fbbaa14ab204a493725a574cbc8a4bec8115f6bd35a17616055209c89ca1c6aa
-DIST firefox-103.0.1-he.xpi 559706 BLAKE2B ce8031d8149a6270fd286012116c25d681b09d6e805623274f7fb53d7ac82117333eaf018971ab3640385a7e76d3988a3799f5e88d2e96e34bb1a16798b926f6 SHA512 2c938099d464c66d6c7e8aa5eca9fb073cc3e0728018c494bf4a01effe7cfd6e78752b2afa9a2d81024a1b7a2e738d1621d1e1690578d455719948b264af9c27
-DIST firefox-103.0.1-hi-IN.xpi 556926 BLAKE2B d2b8a700a52cf366622851ac3013b59ce9072eb7ad1f176465ffc00c101cae0dc904ed32550214e8198d0f3c6a9e5cfe29700999dca39139a63707fae3a05819 SHA512 54f76de0b86f66f0a298df11b260e7fa5c2a5c8809231a98750b9ccddb29d7be1faafe36430d1e06490a95b4b8208f830a50d75c052d298d18637f19debbc607
-DIST firefox-103.0.1-hr.xpi 530620 BLAKE2B c4523bb1337705cb7731908d130db988fad5cba3e823636abcb5dd0e968197156e8e21f38421a128fee7c749a350445980424e243521ad03c8265f25705a58be SHA512 526869c5cea7d7ad06419ad56aafbc56d397534924896510e3304ace4b023346cd4ef3ee69219b39250f6af6d826ce956cfbd0a53694b6837adeb08e9f0cdbc0
-DIST firefox-103.0.1-hsb.xpi 565694 BLAKE2B 930b452e972dc88923d3e41328e15d6d103b5d454ce7634dd4aa7a001685b336746f0b86f50581cdbd1189c4730aca92b48eed99616644003e81a7f20e5602c4 SHA512 99f2943f5502a60cbd14ed1ab9e12d3a88b134a2bfe3bebecc6564e37e1aba0ce5ef17fc535aa1f3e7834d6b85f2ef74c3b70fbd2d261d45e93bd1e6b8c39143
-DIST firefox-103.0.1-hu.xpi 568992 BLAKE2B 22c6ec23da10490925aa16b5b70c5e019dd0802e7bdfe23d231f07105c011ed5789b76a9e57116993ce533b95035d0b75990efb6628a2c6fbf7615bdf26288ab SHA512 2d8b5f6395ee51222e23f81978451b1e00aaeb8be04d053c06abd279da083ea2adedb08da6e544f0e1d7369a5b1cab8ac36c4e6113681254106d6d0b89ea371f
-DIST firefox-103.0.1-hy-AM.xpi 581567 BLAKE2B 43e413889c6bf59148a7e6a1955031720a6d8ececd19bd43aefbf9588fa21a8c284255a99d90289e2170a9cfd1edc9c3d9daba9ba4f1dba83046d09b3bbb6412 SHA512 5c3576ee1ae33af189a1c694ea2be90cdd98d6fc54df583f4f27ad974ddeef55702ab1fbd370b095a5be53f6b4f94bea8358d507a01cc7abfb767d29863f0e6e
-DIST firefox-103.0.1-ia.xpi 535624 BLAKE2B 443464e9cd9044abdd0db41203365a9f4836175d196392d9ea64824c63fdff00ca8a3f7e6b6dca1c83a409366dc2d3f02c7a8550196f36b841ec5e19fc4799c2 SHA512 33b67985658185065dba0e6d09df7de75d7488524158b1ee0f232a9e69ba61ec57b1dffe871ac5b316338abf292092c59b0a336e2abd6d5c7f0d0010f49a135a
-DIST firefox-103.0.1-id.xpi 532811 BLAKE2B 94d704daa9d8e28bdd7e65fc2a9a6feab5f3be0c188dbd8a134727699b7ffca69a66cca0b8c613cbb30b8984c7cf81bfae08c5437c272f4f098c00e18d70b215 SHA512 172a556b4c01db3fa2907a6e874aeb1f4b448e0d747c7d6a27758b7ecc1194fe36f7b52744189b842a6204d8a1dec56dde71889519006bebf7477e3de27e4baa
-DIST firefox-103.0.1-is.xpi 540847 BLAKE2B e35aa14a437a6f257b749302d1b1a1c57b5499f1c3259cd5605a72dbfdf610058878a62d01037c855ef112e61ae1cda27d6daf31ae7aa1b2d1c8541983faba8a SHA512 f88f03651e8e2d3a2787614f523e28527cdbdbd40ffda0bc1c5c43b3de0ce5755d1cc9a38e3f2d52557d14e774a42c7c967303db35cd49d48620f3857ed64504
-DIST firefox-103.0.1-it.xpi 454439 BLAKE2B 61e5148e9df3fe6797b7b6484a3936c6da29803cbeae75fe768cdbe38937fe2b98b8aaa16be8e098c36c16f8fbc28f4ec06a98474c17f1f7ba2ad3d62542e3d6 SHA512 3e96c8b7a644fa1fe8e1589a97f1100a7b400b14d1a996fc045900752af3ab4c92bdefa5b0ce9052b70fc303749fde3aabdeadf1e7b147c7640aa1a0e7731c7b
-DIST firefox-103.0.1-ja.xpi 574517 BLAKE2B 6002448d6fe2946645c2fb3ebd8ee3468504a1b20b61695a80c9d203c73bb7e93d135b5dce08433b3310f47f164dae29bafccebd7b0cb07222c5928c32531dd0 SHA512 e48a75c02ecd3f3675321da8c14312ad55cb78ef3da8082a038960ec32594b2d41a0571111e579110d3cdb0083246281224a35675a04680c947371ee96927968
-DIST firefox-103.0.1-ka.xpi 594023 BLAKE2B 347e9b25912db37490b8c3b50728ffeb9795805e0f0926ab24a7bda220420ee27f5c465085eb137c8cfa5d9cd6dc2cee319fa14aff48fc82d448f802673b3d4d SHA512 99f8b45937b4693f8129b8e2678913c9766f2abe1fd8c263d6bc1f8ef273eec2a8045d6423af5dd360bd4dcc3bdd1bbcb82a2f37ba5839a1b87700b0d22aafa1
-DIST firefox-103.0.1-kab.xpi 554265 BLAKE2B 5c4a589e71bce3dae8c5e2a51f71656b1ceb7bd78cc11e557eba0b449de88d8d49ca26d9a93ece68519fd74d48df532edd1a20ef3513a822de1b8167cfe99285 SHA512 7a50ae25949c456a39d5923a07a104462029cb80418fa9db127301ad1ee524afafb005d9d709dfd9a1e2aabc681666bce5342fa3ce307b812c1ffca36089773b
-DIST firefox-103.0.1-kk.xpi 616956 BLAKE2B a48871662163b31df30c3cd77a34d2529736fd3ea3875f7e71b78821b91928069fd718633c948509a5820305c0ba0ec4096c779db3dc2277d0c35efacd78132c SHA512 08f98b9a0cd0b0f02b1b42be669200706bf7aebe353cb63f1f6ee86cd8ba7436656709c587492d58f0f53b55e93e03555b588d8c872a1a236bb1fbaaf4fa286d
-DIST firefox-103.0.1-km.xpi 531396 BLAKE2B ead91b703e41f62323d7b00918f6a0620f10cd6f64a2202c8abd2bca2dfedcff23516bf239d472f619027329cff82b982c6863f088d0d092a61c29058b43d79f SHA512 31f7b421c3ca5adb5bbbcc0b5fdaf5a777d2f2a1c625e02cefe3511a389d36dbf1209234e52e62cc0343b63a8ee9a506f463eba6382d43fe4ca178b5f5012547
-DIST firefox-103.0.1-kn.xpi 497493 BLAKE2B 4e022946652c166c3719e56c9a9aa710c881534e5d3eec8c593b383bba1d85503ce677a23f1607e29ead0316ef8d80152a59be4c87125b74b035fe6fca723899 SHA512 dbc5a9e2462ba7f92e86785b30fba0cd83ec409eeceda152f34870abc3ae9e38223d6192cdd47f045c5f5e85584b4353b09f7fe6933255abf45c3ad5df752f37
-DIST firefox-103.0.1-ko.xpi 581110 BLAKE2B 1ea3bf3f19cd0f6a93420466bb2d52e5f41b7787574e36b66adb84ed1dabbcff0062836d0a11eb8134cbeed56e1af2345e0a8b926e1974eeca4c6d546002b61a SHA512 87f4f1119647019ab7763bdafc6910013db0227f4fb248ba2c01d616aa5fb1613bbedfe9adfed0369e450f94f56d24029f36b775e2379029af81b6d08b97a4a4
-DIST firefox-103.0.1-lij.xpi 470256 BLAKE2B c73ec59d5babb7033807dad9b43653ca84c294da07cf7eb0b4eaddaa1db6061bedae8e7b0982b0dd34f7c237a56f15b2afad2a3c69b478f4393f7a8ef0aae492 SHA512 035d19c40a4fd22328a067a297c4e0d05277b6f671d342b3be49ff89f5224a3bea6e9abc3a639aaa2a9f895ba522a03f8f590fcd1fd7e6ce1f6e0d7cc8ff8c00
-DIST firefox-103.0.1-lt.xpi 562006 BLAKE2B 2ac04541539edc8274c5965472b3e617b963551c67a0fedc50b6911c30fc5b972ce8ba596420d957911b9e8990f3da4133787a408cae6514a31732935ccfaf33 SHA512 d71a2e9ca6084aa927b87628ec976a799045ff3cb708e01d5018b62a8e9536b7b16360b6c85c9994afa6b510ffa93b6666a771f6dcbf9558c1dd29706316325d
-DIST firefox-103.0.1-lv.xpi 463409 BLAKE2B 4b74e079fa44b8693ab8a6ffd6f4d1726cac2772483129fd55c74ac137a64eb4c4f1022c5289ca04f459e92492b60054fd906a57d6e842606a0c43701f579b4a SHA512 556be9bd482cabb55edb7433b8822a7a7da1e9b16b066df131d6455e0ce04ddb72f69ce33691bb47c32ce02beb4e7d3c8e5a3035a0da10a7cb3d8cc44de35537
-DIST firefox-103.0.1-mk.xpi 474765 BLAKE2B 9c7488301b958d360077005deb5fdf677420cc8b26882e6236f03e28ac42da8ddaf8ed172678e8eb53ff0f913c507fc92d2b6749eeeab1110d582de107cbb8de SHA512 00b1e0759035e70bc47d372220b0c1985ba364808a28720f9b0f1589bf476a405c31a416dcb1fa759f4b7693629fb9f82c8e833ca5142c0e3cd47ea0b23c3f46
-DIST firefox-103.0.1-mr.xpi 530635 BLAKE2B 9d4d17c5b90de850a40abaff901d48c644cffa2dca81c8b7f57234844ce0db171cc6f03bc7beeddbd3431f44d01cf6dcd8f7d8cdfeb2776726dd6e19341a26a4 SHA512 5c2edd61b35c3689232961d22d1aa0badc3cd477a521c75a290ffc25aa2ae23788defdc56745a68727b9676163f34c4511c513aa7e87aa565eb0793bca93c89a
-DIST firefox-103.0.1-ms.xpi 448400 BLAKE2B 53f287df3feefb0dc2db7e0a25caedd60d8530db36ef1bcc969a76e747581bcd8cee3e46d20147c6644263148cb5c608faf491f446632b0327912ffe7a8b67af SHA512 88d5f96298d3fd3a3774d029e150e5769bc1a6fe3fcb3201cd88517ce08184c2f470832350474249e7c14bfab6a6c635117fef5bf49849b27e4c123dc49214b1
-DIST firefox-103.0.1-my.xpi 510289 BLAKE2B 94b395d795863d28b099de316cb1e5b9bc512fbdaeb77ab98414ce8a22ca85ac949d9102129d2f4966ccde4586b217e2d4607e5da9da0dc1beec9968f00316c4 SHA512 19ff692f044f144856ff2bc1f31166e9e7fa299b5f9270a0ab533bfdc9c49ccba6ec503dc47923d3942fcc108832d29eb45bb781104332d12cbdf9156b553f8a
-DIST firefox-103.0.1-nb-NO.xpi 533227 BLAKE2B 0533a374f699e295960bb7dde3b42f78c6c3182b12f4f0ec70dacded8e6bf8836ecf183168ae09c7ba43d65e9bd55a355e20b48740a444934968ef769dad49b4 SHA512 1ca36127aa29cec45a55f8de6f39d8a854d811924849d79790ff92b26f6dbd2e5eb54083e1ace22d645b7abb562b7f2a937bef9d2a0388586c2ae2644ae27d7b
-DIST firefox-103.0.1-ne-NP.xpi 489027 BLAKE2B 40795a9d47f59502a3899c8a5c4611aaf963bd7b69d94127fd7b6a6bb9f45552460670a64cc4d2ec393d1baa28b4925e8b804e6d2293f025ba814c2ae72f666e SHA512 6b66658263e0128aa2c16ad1b00ef9a7353823ab420602e25133d8ef6920e0c1d8d3257a154f962e05193e1e73595e864a10eb68a524d781a5433493b0ee1908
-DIST firefox-103.0.1-nl.xpi 541036 BLAKE2B 0d38e3f8c8c06fd60d8f1655ccde9197961fddb1bd923874cead2db07e29354459195c04bcf35b6d27c73e63ad0b5cc46f2538bb16d65c4b1f1ed4d31e4a1fcf SHA512 38fe6dbb0510842cabcf100cc7ed1181a8c72066e5dd92bda3654ceeb27c563ab2132d9692ba8aa76936035f8016c6ead5981dc22ec6b0097c237fc7dd069980
-DIST firefox-103.0.1-nn-NO.xpi 535172 BLAKE2B 9b9e4e31cf95d93c610c7e223af94adcb037bf7ba8d8cee766aefc7404549b6377e4f2e48df33948a99eb08a90fe05dfd1a6a548854957167f58097008773636 SHA512 fbb1ab6977d8981472534c32ab7eba9c5b6a1aeb204a0bff21120498e47682bc446f2f867dce9eb1a85b48e3ae0e59347c76031615d47551ce083eb5895042e6
-DIST firefox-103.0.1-oc.xpi 556233 BLAKE2B 23e403faff4f44e2056a64eccf16cc338c4f19687ab6a57cb10fb1246a9aab82df2d86c61131174c22bfdf195cd36cd3087f25898d81d28bd3895c8dc12d4989 SHA512 0187396d7b42c369ad23127cc366e20756ecb459036659fe505c72ebab0818105b083f09d40ada144fd3b7b6c28f935590542047fb52df34d8cb6116b3a5eb9a
-DIST firefox-103.0.1-pa-IN.xpi 599787 BLAKE2B 0210a219cf461e172265bee51f073669e69efdd7c8ebf2c0f94d9503d5130d0a81f209c4a5d973d8f33b5036783cc5eae34af95eaea3cda1fc0ed5f39d2ccab5 SHA512 b1cb03ff31eb0d9a19734840900c835508553e56204fdd4b29065f164a2ab26926c996f719bb5d55a9a159df6533e3ac13fbc0af294a47f408a57360e89ac712
-DIST firefox-103.0.1-pl.xpi 560477 BLAKE2B 93c37423eceeba464589cfdd0cd33829df9a0ff2668a75436954342207e3a82ee761046600675b9a1a867fa0a07d746c9840a344f9213f63cf0f05f40e48f220 SHA512 ec78a340d37dc33376dd27c818ce78200c39f32965d35cbdd52372a17b2537735a24e5284035aa5ef7e08c7f3c9f9632224620337482bd357f0ee443c75e9da7
-DIST firefox-103.0.1-pt-BR.xpi 545988 BLAKE2B 099124f7e1c5a001b850f0ce3c1bb25a80b30ffce1657e513c90e944f9476db2c25b9c15890d7f7ef7c5871ef3f56ebe50306c447ec855f0838caf0b3cee53ae SHA512 5f641fe0801cad00f62a635e5997cbcaacc4cc2388e2ace71a9b95af10649d6dbe1d0540bcc6a6e8397805a0be4ff909efbfc95fde282b4e585ac0a76d00abb6
-DIST firefox-103.0.1-pt-PT.xpi 550410 BLAKE2B d70f65d982c6ed3e266b792bd078a9b8ff5dc70e7bb569e740a68f419bda0e4a88edff937d8cc46cc090b9fb11ffc1868e293939bae76175d0f02585eabbb3c6 SHA512 8c7be713ad2e7da4f9eaa82c159d908628973f00f060849dc4523a24c6ea03a9bfe00ed452a48dfc26e4030f6b27061e61027908d10748c4134b1f293ce213d5
-DIST firefox-103.0.1-rm.xpi 539556 BLAKE2B 9644909af76bc6bc8c54449918e9c326ce6bd59f1b317c88faf1419565b872f3bb0d5a8045c8bf8d0692a370f50b7f891eda566863324883a407f1347c692864 SHA512 55eff37fa0f7b7dee136a144e9f6488325130b38189108fd8e1f9c2a03b2f3d4ca4553f0e5dedaba455df5d25e0acdd6cac94eb9c96e1f17c0aa1e23ea919170
-DIST firefox-103.0.1-ro.xpi 528561 BLAKE2B d25d05bd1374db69adabfce1d09438120981a09d96aeb87d9dade9392aef849ca6e7f16df356fe087579065c90b1f35e4d6992e9e195b98ab6e62787b3b42df7 SHA512 27d70d17cbb82dd0a176e8db6c1506d6d051cf3a8032a2f5dfbd0cfce31071d9d91e7f064c81c75deaf3e213de93314ab57b03559e3f45f1cf47562cf4800642
-DIST firefox-103.0.1-ru.xpi 630089 BLAKE2B 6529952c641360de1509055320587f87b945e232661409ac75cf4288ceabf083f9f028f23a66776e4f2866582df55ea6b682722e2ba827f7c85c73d6cc1d66f5 SHA512 bcf51f22b7fe4fff9c120dfb0e5d24a9692b12c2b047fd7c30c9ae516bab0475bb03e6bd8c22c126eadd4aa107b0a3e1b08a4c8ec2eb7265a491fb4d257110c4
-DIST firefox-103.0.1-sco.xpi 496685 BLAKE2B e79bc99927e87c54e5cc45c9108a9066fc324aee9da8720cc9dd7da1af4f151c66bd6c1e04a50272d7db8ebc8a1ae764183a9342428d61402004624783c9702a SHA512 9d432671efafa3b79bb325f535c382b419f143b4c8a5db38a8a672b314268ebf0de808e079fdf4b8e76759979e7bede1c8b7f61d70935079b8642b27f274509d
-DIST firefox-103.0.1-si.xpi 485248 BLAKE2B 2ea6638a4ab598f61f5f089d7525ac9c4a2d543f20624f62b9dd561eaecac8e9552222e7eae1cb66fa4ad83adc87443dc85a014053a1acd7bed4cffef3cf136d SHA512 538194b27afae35733efa98cb650db34af2e21592b3e42cabe81117f95a8214cd65754b51c18420f1244d29c4c22ea32bbdeed571d8355d69c3d627035221a96
-DIST firefox-103.0.1-sk.xpi 569080 BLAKE2B 73a06a8cf41b713e6488610b8ffc8b4d1f2c6f01969e2cde8647e6afe1c1f5f227ca56774d36e3e8f51ebc45e12a6a872849e08876bbd56c55dd31b524d71dce SHA512 6626065cd619502a5decf9584f43a024198d2a842ae8aaafed01950ac51d7dfc2d658652eb619d84f0ab3651692856df1c2b8c35f97fee9b0c7da9cc379183ee
-DIST firefox-103.0.1-sl.xpi 542272 BLAKE2B b05fc307336f56f1a0ceb6cf41bf95ecf38654be0477bb37e0dcdf9d1fdc7dc55db8a55d1e1c97b0b40afef2a408b85fa1547c5146dbb7ff68929bfc23042caa SHA512 d38973c1668641efb8589f3f4a668c6cb7da5d521a21b323dae438ebae6efdcf80e1baeb665ecbe39343b8165c5357a9e567df6fead89b4145f489471bad0117
-DIST firefox-103.0.1-son.xpi 426230 BLAKE2B 135d33247a6512e9e9c35c22c7156ea81e6152c545333c37676f0610480f359fec260633c7d5f3219c764f2f7ab14057c5efe4bbc611d39ac468707733168038 SHA512 272c4a0c46c43cf98298610359ed6ac8a6d66a24b50a7806bf31bc5b69060ac4334ee1db0a104fb8aaf679baa7e7d756046288eb7fe2cc36fb5ba94f149afd87
-DIST firefox-103.0.1-sq.xpi 557264 BLAKE2B e547d43e98e0c1a55031a01514a8f872907193fc6d2d9acba2e07d0de2393abba4861febf9947c367fe4bc90474e664c2d5d96e7f212f74af429eccbfabbef4a SHA512 9269d60e3e42de08ab6d6fc5fd95592eebb61b99b0fa472f714812402b277d550b858cb23ea3866c0c18676a62ad60fa4c4a70a88a5a0daca55650c4dec5262f
-DIST firefox-103.0.1-sr.xpi 582540 BLAKE2B 13f792db4918ef1e143d4caa1bd6d775d6bd431385d04daa2c59ccd9bb9081edd2c872b05de4b0c065641082ad02e7c8b2d4c13b906063615ab1000738c58483 SHA512 77ecd2c9f2a2ee617c88a51391f038e868a50ad6307487cb48113717b671ab40bec11f1b53ef3587d96ba96d52caccf9c4fb5f68b28f74077a25c42e928f7242
-DIST firefox-103.0.1-sv-SE.xpi 542862 BLAKE2B 560d2f411c2ab548af5e10b88f90c0cb6c87b92c89cabdabce62fc060db91515c513664e7d34825c5313a58583ed1844da461ead91a71fa0a01635d4be53e1e5 SHA512 d361caa3f2135a9c4f4927dc5d4ebe6c0f3cc375d5b4147b6a59c9901821143a5097eb39be6c6cd01627a29e7f847c8fd72360a72a101e4d6f2347ba2b8f50f9
-DIST firefox-103.0.1-szl.xpi 508458 BLAKE2B dcd0949e26bf9112015b1e89c42340c5e45d479b4efc610b6bce3a6b9017262fce38601fa22ad53868974f0424d69ada90b3bf892e3481460c2d2bc88371b09e SHA512 75ab9ab58a8f6329ac703e157a8dc526e9b9853948016beaa086725c3deecc8593dc6fec7c7666c626f81677a8fdbe05fff61c8b4b41f8a851abf93c1090fe32
-DIST firefox-103.0.1-ta.xpi 510671 BLAKE2B 3da228200c470a5aaeeb1ad5075f671c84261c8c77eba4db862652ff6b7c5774a5522a0ce6b21a1f50fe8cb0d913d74c9e317ce7c9e13db481b8287cc6dd9774 SHA512 68ef9bf4f52b791ec36a845858f9873c80c2a66b52636d2c06b69820a097e65a3aba0aea401c5562767a8d793a40f0116cc76bb8bcc346c86949acc49e81739c
-DIST firefox-103.0.1-te.xpi 551778 BLAKE2B 1566182a148aa4be855e260edab9fb79fa2623264164f49974360cc9c1adb1872dcd3a74a7b234b3633dde57bd33611ba7f61f26ca861407fe79360f810cb757 SHA512 67628764f316ae9b776885bd2a17948b4a9f1d764b484715422ee8741f1407c2db18de64c90aa4014789e074b94b6eaa585376baa5650d8711f7ed3e81d5dcc7
-DIST firefox-103.0.1-th.xpi 610646 BLAKE2B 3b9ac255f84b34b9ed1f0987e7bce8a5c95822bb302992e47cf6a02c1d5d672329aa15a899b1d4392faa691dc23a742f3b87e594e1f4633e47bfffab7272e85b SHA512 26254ef9a4f2be9b8115623867bf350c6e9023213320a8c21e6177b2d5cdeb47c8a25a34ce1dd0ff36118776aa95a663c3e93c5933e0b24dbf0da5d61e099d76
-DIST firefox-103.0.1-tl.xpi 518725 BLAKE2B 8513a21152b618393e872b3330f1ad82547a1c826ffb4cd32bcc05b8e811cc22e1117ee25299c667f4bbfc3af17f4ee974c9fb917b7191906bb72c5e97664126 SHA512 f86f3ea84f95016eba5eaa99b2d5376055d525a31d6d08b9270d7916c335abf4becdab695236497a04feb7d698f72f9e9a3f27d347e707008b21dc6f9c23c750
-DIST firefox-103.0.1-tr.xpi 555677 BLAKE2B b8a2f8b6ad0cc9cfe18ea5bd23a18eab8b73fb66ac517226d9d66506ed50095db37a45ada84fc3c7e47b12fa0a70df69435ee31e5841e5193995d83e7ff0ca37 SHA512 95f46570d96a81ab44f5ace88f64896e9dfd86acd4d98c91cb63ceaf42731dbc8e7b328b1b764eaeee4eeab4f6fbe7c57bffef5357325391ad71c698fb7ac5a6
-DIST firefox-103.0.1-trs.xpi 488885 BLAKE2B 77e2df1c47c1fffb248e865f105c27d2a09f9537355f0c7a848f33dadcac331a8b2922aa9b2f3787616c93274b61ec05df7bbbc7c9f803aaca34f29c92eab9ff SHA512 5b3bfae7765934189af3837b1591969ceaa483fd06d130ab296552511863b2be972e5a509053cff94e65c6dc176d07c6f6676579a64b30aa150423b1a73e9a9f
-DIST firefox-103.0.1-uk.xpi 623498 BLAKE2B 78d0e757ad2a74d36985ef990a2f06db8d77d603dfa381d465690b46a3bcf429186bf8579dec7ce5f49eef09dc1f40d390dd459e71633d94b2c14dd1b11a1f2c SHA512 452ac5845c7c5968cf8b8450fdb716e719d110f1f29656637850883815e7e3b83983b10b1fb5c15eea65400c3648388f8ba7f4bf96d49824c83d99f08f25c46e
-DIST firefox-103.0.1-ur.xpi 558770 BLAKE2B 1e37442c843df8a96cbadee34fe16ab2e11559e5d87f2d1859eb3e85f78096bc2396a801ac86a9eb7207a8ee49fccabd2376f3e8a8fab4943c4212eaa5cc3b68 SHA512 d8f693b33cde0433f1f358c49f3f1cec98725df47c852c284e0995177589c4e1efbd6279aabb020bfbedca8fd5e0a3eb53da4977d21e80f45b185ecd79eb0a7a
-DIST firefox-103.0.1-uz.xpi 478410 BLAKE2B f594e6a0341f35bc737afbe614245663012e9d07a260921d7cc50cc4041d810927e37cacf74f760b201f01029bce7c92b75a1a6a25e3e9809b54efeb50754a35 SHA512 151638d3e42e41a41ea60ae2689f70a0cdcc99d505cef209ed806134a4bd8f7f586b3bbebd2b28412f49515d7619791e6c644b9de8edf3fd583c9690b9f4caca
-DIST firefox-103.0.1-vi.xpi 576267 BLAKE2B d9c88a6862eedc2a6b1691e869608c7254c7999bb581f19cd5956fae0f165bc77da92ce21201bf9dfb64f8032f5bbd42989f905250f94dcb115bf9ae6c3bf1ab SHA512 9d2b180fc3561656fcf39ead2c12fd272c2cb8e5920a1b54cca534f989c93bc20d3f93e52d2fdbcd2d8c68fc6cafa89f2cf9caf2a9230cc142f663097f1726e2
-DIST firefox-103.0.1-xh.xpi 429247 BLAKE2B 299883a21a176cada6900fd778fe170cd0911fb40b6ac03e9462e83899cf47e0c092889e43690bfbb1ff2a634671f4e65289f71547df2572c41d1bb97acab6d0 SHA512 f02711153bc337bb3bbcbaf2fbe7b54f696fdb43cc4e12559c344387876293ca6826a42c229a65a7f888a86dd4b6723abade6015d32dbd845f33f2ad5164d3a1
-DIST firefox-103.0.1-zh-CN.xpi 577425 BLAKE2B da82d2b3d75a385eebcdedd769f111de4ad05bd7ea2835d4e0c1096a5774af40584d8fe5d29a768455613be03ee3de5aa8d1713cc804195517eed31a590955b4 SHA512 14f5324508a8820bdd8a248a4e989444c444a183aad99f96ef841d98804d1941189e49143ae9c96b63ac0427d277c7a29357752234b9ce0be543c491e9c03b7d
-DIST firefox-103.0.1-zh-TW.xpi 578007 BLAKE2B 4cd77a1ad9046f2799a0da55831533d989b5ff7680988a96b2e9d184ff82edaaa5717830782760e3d2b3ad7a4a4efc75133e9787f5f32969bc3cc57b3674a249 SHA512 4c054aae826b5e54e5f3c5c4c2baf10b63c307684625c3f0d48f3de4ee18bc7923f0e03eff89fe74699b30fd971b80cb5fafe033d1ab2a68949a466c0be3e48c
-DIST firefox-103.0.1.source.tar.xz 480380068 BLAKE2B eb9a4212e44ed835b62674e6bfba63aab0cfa76ac40010cc8da195835f3f3f8733d1de2710a1c2ed9db1b4275ad23b2022988c0592f0579f455e50756c220ef9 SHA512 cb487e1d5d602e6b07093b5e722c4e70b9bf39f42c13c25642f263f90f9d3940d02e6fdbab9e8f41b66a50f81d70300acf81c222f08a26eed3ae55777fdc6303

diff --git a/www-client/firefox/files/disable-auto-update.policy.json b/www-client/firefox/files/disable-auto-update.policy.json
deleted file mode 100644
index f366220..0000000
--- a/www-client/firefox/files/disable-auto-update.policy.json
+++ /dev/null
@@ -1,5 +0,0 @@
-{
-  "policies": {
-    "DisableAppUpdate": true
-  }
-}

diff --git a/www-client/firefox/files/distribution.ini b/www-client/firefox/files/distribution.ini
deleted file mode 100644
index 680512e..0000000
--- a/www-client/firefox/files/distribution.ini
+++ /dev/null
@@ -1,42 +0,0 @@
-[Global]
-id=gentoo
-version=1.0
-about=Mozilla Firefox for Gentoo
-about.de=Mozilla Firefox für Gentoo
-
-[Preferences]
-app.distributor="gentoo"
-app.distributor.channel="gentoo"
-startup.homepage_welcome_url="https://www.gentoo.org/"
-
-[BookmarksToolbar]
-item.1.type=default
-item.2.title=Gentoo's Bugzilla
-item.2.link=https://bugs.gentoo.org/
-item.3.title=Gentoo Forums
-item.3.link=https://forums.gentoo.org/
-item.4.title=Gentoo Packages
-item.4.link=https://packages.gentoo.org/
-item.5.title=Planet Gentoo
-item.5.link=https://planet.gentoo.org/
-item.6.title=Gentoo Wiki
-item.6.link=https://wiki.gentoo.org/
-
-[BookmarksMenu]
-item.1.title=Gentoo
-item.1.type=folder
-item.1.folderId=1
-
-[BookmarksFolder-1]
-item.1.title=Gentoo Linux
-item.1.link=https://www.gentoo.org/
-item.2.title=Gentoo's Bugzilla
-item.2.link=https://bugs.gentoo.org/
-item.3.title=Gentoo Forums
-item.3.link=https://forums.gentoo.org/
-item.4.title=Gentoo Packages
-item.4.link=https://packages.gentoo.org/
-item.5.title=Planet Gentoo
-item.5.link=https://planet.gentoo.org/
-item.6.title=Gentoo Wiki
-item.6.link=https://wiki.gentoo.org/

diff --git a/www-client/firefox/files/firefox-r1.sh b/www-client/firefox/files/firefox-r1.sh
deleted file mode 100644
index 853a4ef..0000000
--- a/www-client/firefox/files/firefox-r1.sh
+++ /dev/null
@@ -1,116 +0,0 @@
-#!/bin/bash
-
-##
-## Usage:
-##
-## $ firefox
-##
-## This script is meant to run Mozilla Firefox in Gentoo.
-
-cmdname=$(basename "$0")
-
-##
-## Variables
-##
-MOZ_ARCH=$(uname -m)
-case ${MOZ_ARCH} in
-	x86_64|s390x|sparc64)
-		MOZ_LIB_DIR="@PREFIX@/lib64"
-		SECONDARY_LIB_DIR="@PREFIX@/lib"
-		;;
-	*)
-		MOZ_LIB_DIR="@PREFIX@/lib"
-		SECONDARY_LIB_DIR="@PREFIX@/lib64"
-		;;
-esac
-
-MOZ_FIREFOX_FILE="firefox"
-
-if [[ ! -r ${MOZ_LIB_DIR}/firefox/${MOZ_FIREFOX_FILE} ]]; then
-	if [[ ! -r ${SECONDARY_LIB_DIR}/firefox/${MOZ_FIREFOX_FILE} ]]; then
-		echo "Error: ${MOZ_LIB_DIR}/firefox/${MOZ_FIREFOX_FILE} not found" >&2
-		if [[ -d ${SECONDARY_LIB_DIR} ]]; then
-			echo "       ${SECONDARY_LIB_DIR}/firefox/${MOZ_FIREFOX_FILE} not found" >&2
-		fi
-		exit 1
-	fi
-	MOZ_LIB_DIR="${SECONDARY_LIB_DIR}"
-fi
-MOZILLA_FIVE_HOME="${MOZ_LIB_DIR}/firefox"
-MOZ_EXTENSIONS_PROFILE_DIR="${HOME}/.mozilla/extensions/{ec8030f7-c20a-464f-9b0e-13a3a9e97384}"
-MOZ_PROGRAM="${MOZILLA_FIVE_HOME}/${MOZ_FIREFOX_FILE}"
-
-##
-## Enable Wayland backend?
-##
-if @DEFAULT_WAYLAND@ && [[ -z ${MOZ_DISABLE_WAYLAND} ]]; then
-	if [[ -n "${WAYLAND_DISPLAY}" ]]; then
-		export MOZ_ENABLE_WAYLAND=1
-	fi
-fi
-
-##
-## Use D-Bus remote exclusively when there's Wayland display.
-##
-if [[ -n "${WAYLAND_DISPLAY}" ]]; then
-	export MOZ_DBUS_REMOTE=1
-fi
-
-##
-## Make sure that we set the plugin path
-##
-MOZ_PLUGIN_DIR="plugins"
-
-if [[ -n "${MOZ_PLUGIN_PATH}" ]]; then
-	MOZ_PLUGIN_PATH=${MOZ_PLUGIN_PATH}:${MOZ_LIB_DIR}/mozilla/${MOZ_PLUGIN_DIR}
-else
-	MOZ_PLUGIN_PATH=${MOZ_LIB_DIR}/mozilla/${MOZ_PLUGIN_DIR}
-fi
-
-if [[ -d "${SECONDARY_LIB_DIR}/mozilla/${MOZ_PLUGIN_DIR}" ]]; then
-	MOZ_PLUGIN_PATH=${MOZ_PLUGIN_PATH}:${SECONDARY_LIB_DIR}/mozilla/${MOZ_PLUGIN_DIR}
-fi
-
-export MOZ_PLUGIN_PATH
-
-##
-## Set MOZ_APP_LAUNCHER for gnome-session
-##
-export MOZ_APP_LAUNCHER="@PREFIX@/bin/${cmdname}"
-
-##
-## Disable the GNOME crash dialog, Mozilla has its own
-##
-if [[ "${XDG_CURRENT_DESKTOP}" == "GNOME" ]]; then
-	GNOME_DISABLE_CRASH_DIALOG=1
-	export GNOME_DISABLE_CRASH_DIALOG
-fi
-
-##
-## Enable Xinput2 (#617344)
-##
-
-# respect user settings
-MOZ_USE_XINPUT2=${MOZ_USE_XINPUT2:-auto}
-
-if [[ ${MOZ_USE_XINPUT2} == auto && -n ${WAYLAND_DISPLAY} ]]; then
-	# enabling XINPUT2 should be safe for all wayland users
-	MOZ_USE_XINPUT2=1
-elif [[ ${MOZ_USE_XINPUT2} == auto && ${XDG_CURRENT_DESKTOP^^} == KDE ]]; then
-	# XINPUT2 is known to cause problems for KWin users
-	MOZ_USE_XINPUT2=0
-elif [[ ${MOZ_USE_XINPUT2} == auto && ${XDG_CURRENT_DESKTOP^^} == LXQT ]]; then
-	# LXQt uses KWin
-	MOZ_USE_XINPUT2=0
-elif [[ ${MOZ_USE_XINPUT2} == auto ]]; then
-	# should work on Mate, Xfce, FluxBox, OpenBox and all the others ...
-	MOZ_USE_XINPUT2=1
-fi
-
-[[ ${MOZ_USE_XINPUT2} != 0 ]] && export MOZ_USE_XINPUT2=${MOZ_USE_XINPUT2}
-
-# Don't throw "old profile" dialog box.
-export MOZ_ALLOW_DOWNGRADE=1
-
-# Run the browser
-exec ${MOZ_PROGRAM} "${@}"

diff --git a/www-client/firefox/files/firefox-riscv64-hack.patch b/www-client/firefox/files/firefox-riscv64-hack.patch
deleted file mode 100644
index b4fca4d..0000000
--- a/www-client/firefox/files/firefox-riscv64-hack.patch
+++ /dev/null
@@ -1,102 +0,0 @@
-Temporary hack to allow us to directly apply diff of matoko's branch.  Disable
-rust-vet to skip auditing third party libs in order to download/vendor rust
-deps on non-git firefox src.  Skip some style checks, as
-macroassembler support in js/src/jit/ is not complete yet
-
-diff --git a/python/mozbuild/mozbuild/vendor/vendor_rust.py b/python/mozbuild/mozbuild/vendor/vendor_rust.py
-index 7394ccaf40..491bd7fbdb 100644
---- a/python/mozbuild/mozbuild/vendor/vendor_rust.py
-+++ b/python/mozbuild/mozbuild/vendor/vendor_rust.py
-@@ -740,38 +740,40 @@ license file's hash.
-                     failed = True
- 
-         # Only emit warnings for cargo-vet for now.
--        env = os.environ.copy()
--        env["PATH"] = os.pathsep.join(
--            (
--                str(Path(cargo).parent),
--                os.environ["PATH"],
--            )
--        )
--        flags = ["--output-format=json"]
--        if "MOZ_AUTOMATION" in os.environ:
--            flags.append("--locked")
--            flags.append("--frozen")
--        res = cargo_vet(
--            self,
--            flags,
--            stdout=subprocess.PIPE,
--            env=env,
--        )
--        if res.returncode:
--            vet = json.loads(res.stdout)
--            for failure in vet.get("failures", []):
--                failure["crate"] = failure.pop("name")
--                self.log(
--                    logging.ERROR,
--                    "cargo_vet_failed",
--                    failure,
--                    "Missing audit for {crate}:{version} (requires {missing_criteria})."
--                    " Run `./mach cargo vet` for more information.",
--                )
--                failed = True
--
--        if failed:
--            return False
-+        #env = os.environ.copy()
-+        #env["PATH"] = os.pathsep.join(
-+        #    (
-+        #        str(Path(cargo).parent),
-+        #        os.environ["PATH"],
-+        #    )
-+        #)
-+        #print(env["PATH"])
-+        #print(self.topsrcdir)
-+        #flags = ["--output-format=json"]
-+        #if "MOZ_AUTOMATION" in os.environ:
-+        #    flags.append("--locked")
-+        #    flags.append("--frozen")
-+        #res = cargo_vet(
-+        #    self,
-+        #    flags,
-+        #    stdout=subprocess.PIPE,
-+        #    env=env,
-+        #)
-+        #if res.returncode:
-+        #    vet = json.loads(res.stdout)
-+        #    for failure in vet.get("failures", []):
-+        #        failure["crate"] = failure.pop("name")
-+        #        self.log(
-+        #            logging.ERROR,
-+        #            "cargo_vet_failed",
-+        #            failure,
-+        #            "Missing audit for {crate}:{version} (requires {missing_criteria})."
-+        #            " Run `./mach cargo vet` for more information.",
-+        #        )
-+        #        failed = True
-+
-+        #if failed:
-+        #    return False
- 
-         res = subprocess.run(
-             [cargo, "vendor", vendor_dir], cwd=self.topsrcdir, stdout=subprocess.PIPE
-@@ -848,6 +848,7 @@ license file's hash.
-                     directory=replace["directory"],
-                 )
-             )
-+        return True
- 
-         if not self._check_licenses(vendor_dir):
-             self.log(
-diff --git a/js/src/build/moz.build b/js/src/build/moz.build
-index 4c48a5c4ff..e68d79447e 100644
---- a/js/src/build/moz.build
-+++ b/js/src/build/moz.build
-@@ -101,7 +101,5 @@ GeneratedFile(
-     inputs=[
-         "!%sjs_static.%s" % (CONFIG["LIB_PREFIX"], CONFIG["LIB_SUFFIX"]),
--        "/config/check_spidermonkey_style.py",
--        "/config/check_macroassembler_style.py",
-         "/config/check_js_opcode.py",
-     ],
- )

diff --git a/www-client/firefox/files/firefox-riscv64-support.patch b/www-client/firefox/files/firefox-riscv64-support.patch
deleted file mode 100644
index 7e9abfc..0000000
--- a/www-client/firefox/files/firefox-riscv64-support.patch
+++ /dev/null
@@ -1,3283 +0,0 @@
-patch generated directly from https://github.com/makotokato/gecko-dev by
-
-    git diff master..riscv64 -- . :^third_party
-
-:^third_party is a git feature to exclude third_party/ from diff
-
-diff --git a/.cargo/config.in b/.cargo/config.in
-index 20b8c3fad8..34c5f9a1f4 100644
---- a/.cargo/config.in
-+++ b/.cargo/config.in
-@@ -22,11 +22,6 @@ git = "https://github.com/mozilla/mp4parse-rust"
- replace-with = "vendored-sources"
- rev = "3bfc47d9a571d0842676043ba60716318e946c06"
- 
--[source."https://github.com/mozilla/midir.git"]
--git = "https://github.com/mozilla/midir.git"
--replace-with = "vendored-sources"
--rev = "4c11f0ffb5d6a10de4aff40a7b81218b33b94e6f"
--
- [source."https://github.com/mozilla/cubeb-pulse-rs"]
- git = "https://github.com/mozilla/cubeb-pulse-rs"
- replace-with = "vendored-sources"
-@@ -37,6 +32,11 @@ git = "https://github.com/mozilla/cubeb-coreaudio-rs"
- replace-with = "vendored-sources"
- rev = "44eca95823bb57e964cf7b6d9791ed2ccb4b2108"
- 
-+[source."https://github.com/mozilla/authenticator-rs"]
-+git = "https://github.com/mozilla/authenticator-rs"
-+replace-with = "vendored-sources"
-+rev = "b85bccf0527e42c877573029e8d35ff13ef06f9d"
-+
- [source."https://github.com/mozilla/audioipc"]
- git = "https://github.com/mozilla/audioipc"
- replace-with = "vendored-sources"
-diff --git a/Cargo.lock b/Cargo.lock
-index 85a143565c..b4924869cb 100644
---- a/Cargo.lock
-+++ b/Cargo.lock
-@@ -30,14 +30,14 @@ dependencies = [
- 
- [[package]]
- name = "alsa"
--version = "0.4.3"
-+version = "0.6.0"
- source = "registry+https://github.com/rust-lang/crates.io-index"
--checksum = "eb213f6b3e4b1480a60931ca2035794aa67b73103d254715b1db7b70dcb3c934"
-+checksum = "5915f52fe2cf65e83924d037b6c5290b7cee097c6b5c8700746e6168a343fd6b"
- dependencies = [
-  "alsa-sys",
-  "bitflags",
-  "libc",
-- "nix",
-+ "nix 0.23.1",
- ]
- 
- [[package]]
-@@ -359,9 +359,8 @@ dependencies = [
- 
- [[package]]
- name = "authenticator"
--version = "0.3.1"
--source = "registry+https://github.com/rust-lang/crates.io-index"
--checksum = "08cee7a0952628fde958e149507c2bb321ab4fccfafd225da0b20adc956ef88a"
-+version = "0.3.2"
-+source = "git+https://github.com/mozilla/authenticator-rs?rev=b85bccf0527e42c877573029e8d35ff13ef06f9d#b85bccf0527e42c877573029e8d35ff13ef06f9d"
- dependencies = [
-  "bitflags",
-  "core-foundation",
-@@ -369,7 +368,7 @@ dependencies = [
-  "libc",
-  "libudev",
-  "log",
-- "rand 0.7.999",
-+ "rand 0.8.5",
-  "runloop",
-  "winapi",
- ]
-@@ -2204,6 +2203,7 @@ dependencies = [
-  "log",
-  "mapped_hyph",
-  "mdns_service",
-+ "midir",
-  "midir_impl",
-  "mio 0.8.0",
-  "moz_asserts",
-@@ -3274,8 +3274,9 @@ dependencies = [
- 
- [[package]]
- name = "midir"
--version = "0.7.0"
--source = "git+https://github.com/mozilla/midir.git?rev=4c11f0ffb5d6a10de4aff40a7b81218b33b94e6f#4c11f0ffb5d6a10de4aff40a7b81218b33b94e6f"
-+version = "0.8.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "2c1c68e2b589cce71b14a10d7d1599a845673f9decde80fa9e8500fdccd50dca"
- dependencies = [
-  "alsa",
-  "bitflags",
-@@ -3283,10 +3284,9 @@ dependencies = [
-  "js-sys",
-  "libc",
-  "memalloc",
-- "nix",
-  "wasm-bindgen",
-  "web-sys",
-- "winapi",
-+ "windows",
- ]
- 
- [[package]]
-@@ -3325,7 +3325,7 @@ dependencies = [
-  "libc",
-  "memmap2 0.2.999",
-  "memoffset 0.5.6",
-- "nix",
-+ "nix 0.15.0",
-  "tempfile",
-  "thiserror",
- ]
-@@ -3735,6 +3735,19 @@ dependencies = [
-  "void",
- ]
- 
-+[[package]]
-+name = "nix"
-+version = "0.23.1"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "9f866317acbd3a240710c63f065ffb1e4fd466259045ccb504130b7f668f35c6"
-+dependencies = [
-+ "bitflags",
-+ "cc",
-+ "cfg-if 1.0.0",
-+ "libc",
-+ "memoffset 0.6.5",
-+]
-+
- [[package]]
- name = "nom"
- version = "5.999.999"
-@@ -6218,6 +6231,49 @@ version = "0.4.0"
- source = "registry+https://github.com/rust-lang/crates.io-index"
- checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
- 
-+[[package]]
-+name = "windows"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "fbedf6db9096bc2364adce0ae0aa636dcd89f3c3f2cd67947062aaf0ca2a10ec"
-+dependencies = [
-+ "windows_aarch64_msvc",
-+ "windows_i686_gnu",
-+ "windows_i686_msvc",
-+ "windows_x86_64_gnu",
-+ "windows_x86_64_msvc",
-+]
-+
-+[[package]]
-+name = "windows_aarch64_msvc"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "d8e92753b1c443191654ec532f14c199742964a061be25d77d7a96f09db20bf5"
-+
-+[[package]]
-+name = "windows_i686_gnu"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "6a711c68811799e017b6038e0922cb27a5e2f43a2ddb609fe0b6f3eeda9de615"
-+
-+[[package]]
-+name = "windows_i686_msvc"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "146c11bb1a02615db74680b32a68e2d61f553cc24c4eb5b4ca10311740e44172"
-+
-+[[package]]
-+name = "windows_x86_64_gnu"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "c912b12f7454c6620635bbff3450962753834be2a594819bd5e945af18ec64bc"
-+
-+[[package]]
-+name = "windows_x86_64_msvc"
-+version = "0.32.0"
-+source = "registry+https://github.com/rust-lang/crates.io-index"
-+checksum = "504a2476202769977a040c6364301a3f65d0cc9e3fb08600b2bda150a0488316"
-+
- [[package]]
- name = "wineventlog"
- version = "0.1.0"
-diff --git a/Cargo.toml b/Cargo.toml
-index 2b499a0841..dcf1e401d7 100644
---- a/Cargo.toml
-+++ b/Cargo.toml
-@@ -153,7 +153,6 @@ coremidi = { git = "https://github.com/chris-zen/coremidi.git", rev="fc68464b544
- fog = { path = "toolkit/components/glean/api" }
- libudev-sys = { path = "dom/webauthn/libudev-sys" }
- packed_simd = { package = "packed_simd_2", git = "https://github.com/hsivonen/packed_simd", rev="c149d0a519bf878567c7630096737669ec2ff15f" }
--midir = { git = "https://github.com/mozilla/midir.git", rev = "4c11f0ffb5d6a10de4aff40a7b81218b33b94e6f" }
- minidump_writer_linux = { git = "https://github.com/rust-minidump/minidump-writer.git", rev = "75ada456c92a429704691a85e1cb42fef8cafc0d" }
- 
- # application-services overrides to make updating them all simpler.
-diff --git a/README.riscv64.md b/README.riscv64.md
-new file mode 100644
-index 0000000000..705099a3db
---- /dev/null
-+++ b/README.riscv64.md
-@@ -0,0 +1,69 @@
-+## Cross building
-+I recommend you should use docker environment
-+
-+#### Dockerfile
-+```dockerfile
-+FROM ubuntu:21.04
-+MAINTAINER Makoto Kato <m_kato@ga2.so-net.ne.jp>
-+
-+ADD sources.list /etc/apt/
-+ENV DEBIAN_FRONTEND=noninteractive
-+RUN dpkg --add-architecture riscv64 && \
-+    apt-get update && \
-+    apt-get install -y clang g++ mercurial g++-riscv64-linux-gnu curl gyp ninja-build make python-is-python3 libssl-dev zlib1g-dev nodejs build-essential libpython3-dev m4 unzip zip uuid git python3-pip && \
-+    apt-get install -y zlib1g-dev:riscv64 libssl-dev:riscv64 libffi-dev:riscv64 libasound2-dev:riscv64 libcurl4-openssl-dev:riscv64 libdbus-1-dev:riscv64 libdbus-glib-1-dev:riscv64 libdrm-dev:riscv64 libgtk-3-dev:riscv64 libpulse-dev:riscv64 libx11-xcb-dev:riscv64 libxt-dev:riscv64 xvfb:riscv64 libstdc++-10-dev:riscv64 && \
-+    apt-get clean
-+WORKDIR /root
-+ENV PATH="/root/.cargo/bin:${PATH}"
-+RUN curl https://sh.rustup.rs -s -o install.sh && sh install.sh -y && rm install.sh && rustup target add riscv64gc-unknown-linux-gnu
-+RUN cargo install cbindgen
-+```
-+
-+#### sources.list
-+```
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute main restricted
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute-updates main restricted
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute universe
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute-updates universe
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute multiverse
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute-updates multiverse
-+deb [arch=amd64] http://archive.ubuntu.com/ubuntu/ hirsute-backports main restricted universe multiverse
-+deb [arch=amd64] http://security.ubuntu.com/ubuntu/ hirsute-security main restricted
-+deb [arch=amd64] http://security.ubuntu.com/ubuntu/ hirsute-security universe
-+deb [arch=amd64] http://security.ubuntu.com/ubuntu/ hirsute-security multiverse
-+
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute main restricted
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-updates main restricted
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute universe
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-updates universe
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute multiverse
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-updates multiverse
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-backports main restricted universe multiverse
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-security main restricted
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-security universe
-+deb [arch=riscv64] http://ports.ubuntu.com/ubuntu-ports hirsute-security multiverse
-+```
-+
-+## mozconfig
-+```
-+mk_add_options MOZ_OBJDIR=@TOPSRCDIR@/objdir
-+mk_add_options AUTOCLOBBER=1
-+
-+ac_add_options --disable-debug
-+ac_add_options --enable-optimize
-+
-+ac_add_options --target=riscv64
-+export CC=riscv64-linux-gnu-gcc
-+export CXX=riscv64-linux-gnu-g++
-+export HOST_CC=gcc
-+export HOST_CXX=g++
-+ac_add_options --disable-bootstrap
-+ac_add_options --without-wasm-sandboxed-libraries
-+ac_add_options --enable-webrtc
-+ac_add_options --disable-crashreporter
-+ac_add_options --disable-jit
-+```
-+
-+## How to build
-+1. `./mach build`
-+2. `./mach package`
-diff --git a/dom/bindings/moz.build b/dom/bindings/moz.build
-index cf3a8d5017..5e1388cfe5 100644
---- a/dom/bindings/moz.build
-+++ b/dom/bindings/moz.build
-@@ -96,12 +96,16 @@ LOCAL_INCLUDES += [
-     "/layout/xul/tree",
-     "/media/webrtc/",
-     "/netwerk/base/",
--    "/third_party/libwebrtc",
--    "/third_party/libwebrtc/third_party/abseil-cpp",
- ]
- 
- LOCAL_INCLUDES += ["/third_party/msgpack/include"]
- 
-+if CONFIG["MOZ_WEBRTC"]:
-+    LOCAL_INCLUDES += [
-+        "/third_party/libwebrtc",
-+        "/third_party/libwebrtc/third_party/abseil-cpp",
-+    ]
-+
- DEFINES["GOOGLE_PROTOBUF_NO_RTTI"] = True
- DEFINES["GOOGLE_PROTOBUF_NO_STATIC_INITIALIZER"] = True
- 
-diff --git a/dom/media/gtest/moz.build b/dom/media/gtest/moz.build
-index 05803392cb..d689c7bd77 100644
---- a/dom/media/gtest/moz.build
-+++ b/dom/media/gtest/moz.build
-@@ -13,10 +13,14 @@ LOCAL_INCLUDES += [
-     "/dom/media/systemservices",
-     "/dom/media/webrtc",
-     "/dom/media/webrtc/common",
--    "/third_party/libwebrtc",
--    "/third_party/libwebrtc/third_party/abseil-cpp",
- ]
- 
-+if CONFIG["MOZ_WEBRTC"]:
-+    LOCAL_INCLUDES += [
-+        "/third_party/libwebrtc",
-+        "/third_party/libwebrtc/third_party/abseil-cpp",
-+    ]
-+
- UNIFIED_SOURCES += [
-     "MockCubeb.cpp",
-     "MockMediaResource.cpp",
-diff --git a/dom/midi/midir_impl/Cargo.toml b/dom/midi/midir_impl/Cargo.toml
-index 7628fb4a68..a918ff2227 100644
---- a/dom/midi/midir_impl/Cargo.toml
-+++ b/dom/midi/midir_impl/Cargo.toml
-@@ -7,7 +7,7 @@ edition = "2018"
- # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
- 
- [dependencies]
--midir = "0.7.0"
-+midir = "0.8.0"
- nsstring = { path = "../../../xpcom/rust/nsstring/" }
- uuid = { version = "0.8", features = ["v4"] }
- thin-vec = { version = "0.2.1", features = ["gecko-ffi"] }
-diff --git a/ipc/glue/moz.build b/ipc/glue/moz.build
-index c4b7c1d69e..775f553d05 100644
---- a/ipc/glue/moz.build
-+++ b/ipc/glue/moz.build
-@@ -220,6 +220,12 @@ LOCAL_INCLUDES += [
-     "/xpcom/build",
- ]
- 
-+if CONFIG["MOZ_WEBRTC"]:
-+    LOCAL_INCLUDES += [
-+        "/third_party/libwebrtc",
-+        "/third_party/libwebrtc/third_party/abseil-cpp",
-+    ]
-+
- PREPROCESSED_IPDL_SOURCES = [
-     "PUtilityProcess.ipdl",
- ]
-diff --git a/js/moz.configure b/js/moz.configure
-index 4f9bb8992f..d53c672aa0 100644
---- a/js/moz.configure
-+++ b/js/moz.configure
-@@ -184,7 +184,7 @@ def report_deprecated(value):
- # =======================================================
- option(
-     "--enable-simulator",
--    choices=("arm", "arm64", "mips32", "mips64", "loong64"),
-+    choices=("arm", "arm64", "mips32", "mips64", "loong64", "riscv64"),
-     nargs=1,
-     help="Enable a JIT code simulator for the specified architecture",
- )
-@@ -201,7 +201,7 @@ def simulator(jit_enabled, simulator_enabled, target):
-         if target.cpu != "x86":
-             die("The %s simulator only works on x86." % sim_cpu)
- 
--    if sim_cpu in ("arm64", "mips64", "loong64"):
-+    if sim_cpu in ("arm64", "mips64", "loong64", "riscv64"):
-         if target.cpu != "x86_64" and target.cpu != "aarch64":
-             die("The %s simulator only works on x86-64 or arm64." % sim_cpu)
- 
-@@ -214,12 +214,14 @@ set_config("JS_SIMULATOR_ARM64", simulator.arm64)
- set_config("JS_SIMULATOR_MIPS32", simulator.mips32)
- set_config("JS_SIMULATOR_MIPS64", simulator.mips64)
- set_config("JS_SIMULATOR_LOONG64", simulator.loong64)
-+set_config("JS_SIMULATOR_RISCV64", simulator.riscv64)
- set_define("JS_SIMULATOR", depends_if(simulator)(lambda x: True))
- set_define("JS_SIMULATOR_ARM", simulator.arm)
- set_define("JS_SIMULATOR_ARM64", simulator.arm64)
- set_define("JS_SIMULATOR_MIPS32", simulator.mips32)
- set_define("JS_SIMULATOR_MIPS64", simulator.mips64)
- set_define("JS_SIMULATOR_LOONG64", simulator.loong64)
-+set_define("JS_SIMULATOR_RISCV64", simulator.riscv64)
- 
- 
- @depends("--enable-jit", simulator, target)
-@@ -244,6 +246,7 @@ set_config("JS_CODEGEN_ARM64", jit_codegen.arm64)
- set_config("JS_CODEGEN_MIPS32", jit_codegen.mips32)
- set_config("JS_CODEGEN_MIPS64", jit_codegen.mips64)
- set_config("JS_CODEGEN_LOONG64", jit_codegen.loong64)
-+set_config("JS_CODEGEN_RISCV64", jit_codegen.riscv64)
- set_config("JS_CODEGEN_X86", jit_codegen.x86)
- set_config("JS_CODEGEN_X64", jit_codegen.x64)
- set_define("JS_CODEGEN_NONE", jit_codegen.none)
-@@ -252,6 +255,7 @@ set_define("JS_CODEGEN_ARM64", jit_codegen.arm64)
- set_define("JS_CODEGEN_MIPS32", jit_codegen.mips32)
- set_define("JS_CODEGEN_MIPS64", jit_codegen.mips64)
- set_define("JS_CODEGEN_LOONG64", jit_codegen.loong64)
-+set_define("JS_CODEGEN_RISCV64", jit_codegen.riscv64)
- set_define("JS_CODEGEN_X86", jit_codegen.x86)
- set_define("JS_CODEGEN_X64", jit_codegen.x64)
- 
-diff --git a/js/src/builtin/TestingFunctions.cpp b/js/src/builtin/TestingFunctions.cpp
-index 2b8de6284f..1b9b4b62c7 100644
---- a/js/src/builtin/TestingFunctions.cpp
-+++ b/js/src/builtin/TestingFunctions.cpp
-@@ -426,6 +426,24 @@ static bool GetBuildConfiguration(JSContext* cx, unsigned argc, Value* vp) {
-     return false;
-   }
- 
-+#ifdef JS_CODEGEN_RISCV64
-+  value = BooleanValue(true);
-+#else
-+  value = BooleanValue(false);
-+#endif
-+  if (!JS_SetProperty(cx, info, "riscv64", value)) {
-+    return false;
-+  }
-+
-+#ifdef JS_SIMULATOR_RISCV64
-+  value = BooleanValue(true);
-+#else
-+  value = BooleanValue(false);
-+#endif
-+  if (!JS_SetProperty(cx, info, "riscv64-simulator", value)) {
-+    return false;
-+  }
-+
- #ifdef JS_SIMULATOR
-   value = BooleanValue(true);
- #else
-diff --git a/js/src/jit/Assembler.h b/js/src/jit/Assembler.h
-index 04dcdc647e..2081f254b0 100644
---- a/js/src/jit/Assembler.h
-+++ b/js/src/jit/Assembler.h
-@@ -19,6 +19,8 @@
- #  include "jit/mips32/Assembler-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/Assembler-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/Assembler-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/Assembler-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/CodeGenerator.h b/js/src/jit/CodeGenerator.h
-index 67453d3cd3..82e58d2a16 100644
---- a/js/src/jit/CodeGenerator.h
-+++ b/js/src/jit/CodeGenerator.h
-@@ -26,6 +26,8 @@
- #  include "jit/mips64/CodeGenerator-mips64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/CodeGenerator-loong64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/CodeGenerator-riscv64.h"
- #elif defined(JS_CODEGEN_NONE)
- #  include "jit/none/CodeGenerator-none.h"
- #else
-diff --git a/js/src/jit/FlushICache.h b/js/src/jit/FlushICache.h
-index 42b1fb045c..feeae3c793 100644
---- a/js/src/jit/FlushICache.h
-+++ b/js/src/jit/FlushICache.h
-@@ -25,7 +25,7 @@ inline void FlushICache(void* code, size_t size,
- 
- #elif (defined(JS_CODEGEN_ARM) || defined(JS_CODEGEN_ARM64)) ||   \
-     (defined(JS_CODEGEN_MIPS32) || defined(JS_CODEGEN_MIPS64)) || \
--    defined(JS_CODEGEN_LOONG64)
-+    defined(JS_CODEGEN_LOONG64) || defined(JS_CODEGEN_RISCV64)
- 
- extern void FlushICache(void* code, size_t size, bool codeIsThreadLocal = true);
- 
-diff --git a/js/src/jit/LIR.h b/js/src/jit/LIR.h
-index 66c665b5ba..016c8246f7 100644
---- a/js/src/jit/LIR.h
-+++ b/js/src/jit/LIR.h
-@@ -1933,6 +1933,8 @@ AnyRegister LAllocation::toRegister() const {
- #    include "jit/mips64/LIR-mips64.h"
- #  endif
- #  include "jit/mips-shared/LIR-mips-shared.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/LIR-riscv64.h"
- #elif defined(JS_CODEGEN_NONE)
- #  include "jit/none/LIR-none.h"
- #else
-diff --git a/js/src/jit/Lowering.h b/js/src/jit/Lowering.h
-index a04d09c446..21094a616e 100644
---- a/js/src/jit/Lowering.h
-+++ b/js/src/jit/Lowering.h
-@@ -23,6 +23,8 @@
- #  include "jit/mips32/Lowering-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/Lowering-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/Lowering-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/Lowering-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/MacroAssembler-inl.h b/js/src/jit/MacroAssembler-inl.h
-index 5ed4ac7458..1c208e676d 100644
---- a/js/src/jit/MacroAssembler-inl.h
-+++ b/js/src/jit/MacroAssembler-inl.h
-@@ -39,6 +39,8 @@
- #  include "jit/mips64/MacroAssembler-mips64-inl.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/MacroAssembler-loong64-inl.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/MacroAssembler-riscv64-inl.h"
- #elif !defined(JS_CODEGEN_NONE)
- #  error "Unknown architecture!"
- #endif
-diff --git a/js/src/jit/MacroAssembler.cpp b/js/src/jit/MacroAssembler.cpp
-index 3abc601bec..0665601509 100644
---- a/js/src/jit/MacroAssembler.cpp
-+++ b/js/src/jit/MacroAssembler.cpp
-@@ -4145,6 +4145,8 @@ void MacroAssembler::emitPreBarrierFastPath(JSRuntime* rt, MIRType type,
-   ma_dsll(temp1, temp1, temp3);
- #elif JS_CODEGEN_LOONG64
-   as_sll_d(temp1, temp1, temp3);
-+#elif JS_CODEGEN_RISCV64
-+  MOZ_CRASH();
- #elif JS_CODEGEN_NONE
-   MOZ_CRASH();
- #else
-diff --git a/js/src/jit/MacroAssembler.h b/js/src/jit/MacroAssembler.h
-index 5fa8f40bd1..3395a139d3 100644
---- a/js/src/jit/MacroAssembler.h
-+++ b/js/src/jit/MacroAssembler.h
-@@ -25,6 +25,8 @@
- #  include "jit/mips32/MacroAssembler-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/MacroAssembler-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/MacroAssembler-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/MacroAssembler-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-@@ -94,8 +96,8 @@
- //   }
- //   ////}}} check_macroassembler_style
- 
--#define ALL_ARCH mips32, mips64, arm, arm64, x86, x64, loong64
--#define ALL_SHARED_ARCH arm, arm64, loong64, x86_shared, mips_shared
-+#define ALL_ARCH mips32, mips64, arm, arm64, x86, x64, loong64, riscv64
-+#define ALL_SHARED_ARCH arm, arm64, loong64, riscv64, x86_shared, mips_shared
- 
- // * How this macro works:
- //
-@@ -142,6 +144,7 @@
- #define DEFINED_ON_mips64
- #define DEFINED_ON_mips_shared
- #define DEFINED_ON_loong64
-+#define DEFINED_ON_riscv64
- #define DEFINED_ON_none
- 
- // Specialize for each architecture.
-@@ -174,6 +177,9 @@
- #elif defined(JS_CODEGEN_LOONG64)
- #  undef DEFINED_ON_loong64
- #  define DEFINED_ON_loong64 define
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  undef DEFINED_ON_riscv64
-+#  define DEFINED_ON_riscv64 define
- #elif defined(JS_CODEGEN_NONE)
- #  undef DEFINED_ON_none
- #  define DEFINED_ON_none crash
-@@ -491,10 +497,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   // The size of the area used by PushRegsInMask.
-   size_t PushRegsInMaskSizeInBytes(LiveRegisterSet set)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   void PushRegsInMask(LiveRegisterSet set)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
-   void PushRegsInMask(LiveGeneralRegisterSet set);
- 
-   // Like PushRegsInMask, but instead of pushing the registers, store them to
-@@ -505,12 +511,12 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // must point to either the lowest address in the save area, or some address
-   // below that.
-   void storeRegsInMask(LiveRegisterSet set, Address dest, Register scratch)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   void PopRegsInMask(LiveRegisterSet set);
-   void PopRegsInMask(LiveGeneralRegisterSet set);
-   void PopRegsInMaskIgnore(LiveRegisterSet set, LiveRegisterSet ignore)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   // ===============================================================
-   // Stack manipulation functions -- single registers/values.
-@@ -543,7 +549,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   void Pop(FloatRegister t) PER_SHARED_ARCH;
-   void Pop(const ValueOperand& val) PER_SHARED_ARCH;
-   void PopFlags() DEFINED_ON(x86_shared);
--  void PopStackPtr() DEFINED_ON(arm, mips_shared, x86_shared, loong64);
-+  void PopStackPtr() DEFINED_ON(arm, mips_shared, x86_shared, loong64, riscv64);
-   void popRooted(VMFunctionData::RootType rootType, Register cellReg,
-                  const ValueOperand& valueReg);
- 
-@@ -601,8 +607,9 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   void callAndPushReturnAddress(Label* label) DEFINED_ON(x86_shared);
- 
-   // These do not adjust framePushed().
--  void pushReturnAddress() DEFINED_ON(mips_shared, arm, arm64, loong64);
--  void popReturnAddress() DEFINED_ON(mips_shared, arm, arm64, loong64);
-+  void pushReturnAddress()
-+      DEFINED_ON(mips_shared, arm, arm64, loong64, riscv64);
-+  void popReturnAddress() DEFINED_ON(mips_shared, arm, arm64, loong64, riscv64);
- 
-   // Useful for dealing with two-valued returns.
-   void moveRegPair(Register src0, Register src1, Register dst0, Register dst1,
-@@ -633,10 +640,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // Note: "Near" applies to ARM64 where the target must be within 1 MB (this is
-   // release-asserted).
-   CodeOffset moveNearAddressWithPatch(Register dest)
--      DEFINED_ON(x86, x64, arm, arm64, loong64, mips_shared);
-+      DEFINED_ON(x86, x64, arm, arm64, loong64, mips_shared, riscv64);
-   static void patchNearAddressMove(CodeLocationLabel loc,
-                                    CodeLocationLabel target)
--      DEFINED_ON(x86, x64, arm, arm64, loong64, mips_shared);
-+      DEFINED_ON(x86, x64, arm, arm64, loong64, mips_shared, riscv64);
- 
-  public:
-   // ===============================================================
-@@ -1045,17 +1052,17 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   inline void addPtr(ImmWord imm, Register dest) PER_ARCH;
-   inline void addPtr(ImmPtr imm, Register dest);
-   inline void addPtr(Imm32 imm, const Address& dest)
--      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64, riscv64);
-   inline void addPtr(Imm32 imm, const AbsoluteAddress& dest)
-       DEFINED_ON(x86, x64);
-   inline void addPtr(const Address& src, Register dest)
--      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64, riscv64);
- 
-   inline void add64(Register64 src, Register64 dest) PER_ARCH;
-   inline void add64(Imm32 imm, Register64 dest) PER_ARCH;
-   inline void add64(Imm64 imm, Register64 dest) PER_ARCH;
-   inline void add64(const Operand& src, Register64 dest)
--      DEFINED_ON(x64, mips64, loong64);
-+      DEFINED_ON(x64, mips64, loong64, riscv64);
- 
-   inline void addFloat32(FloatRegister src, FloatRegister dest) PER_SHARED_ARCH;
- 
-@@ -1074,16 +1081,16 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void subPtr(Register src, Register dest) PER_ARCH;
-   inline void subPtr(Register src, const Address& dest)
--      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64, riscv64);
-   inline void subPtr(Imm32 imm, Register dest) PER_ARCH;
-   inline void subPtr(ImmWord imm, Register dest) DEFINED_ON(x64);
-   inline void subPtr(const Address& addr, Register dest)
--      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64, riscv64);
- 
-   inline void sub64(Register64 src, Register64 dest) PER_ARCH;
-   inline void sub64(Imm64 imm, Register64 dest) PER_ARCH;
-   inline void sub64(const Operand& src, Register64 dest)
--      DEFINED_ON(x64, mips64, loong64);
-+      DEFINED_ON(x64, mips64, loong64, riscv64);
- 
-   inline void subFloat32(FloatRegister src, FloatRegister dest) PER_SHARED_ARCH;
- 
-@@ -1099,10 +1106,11 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void mul64(const Operand& src, const Register64& dest) DEFINED_ON(x64);
-   inline void mul64(const Operand& src, const Register64& dest,
--                    const Register temp) DEFINED_ON(x64, mips64, loong64);
-+                    const Register temp)
-+      DEFINED_ON(x64, mips64, loong64, riscv64);
-   inline void mul64(Imm64 imm, const Register64& dest) PER_ARCH;
-   inline void mul64(Imm64 imm, const Register64& dest, const Register temp)
--      DEFINED_ON(x86, x64, arm, mips32, mips64, loong64);
-+      DEFINED_ON(x86, x64, arm, mips32, mips64, loong64, riscv64);
-   inline void mul64(const Register64& src, const Register64& dest,
-                     const Register temp) PER_ARCH;
-   inline void mul64(const Register64& src1, const Register64& src2,
-@@ -1116,14 +1124,14 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   inline void mulDouble(FloatRegister src, FloatRegister dest) PER_SHARED_ARCH;
- 
-   inline void mulDoublePtr(ImmPtr imm, Register temp, FloatRegister dest)
--      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86, x64, loong64, riscv64);
- 
-   // Perform an integer division, returning the integer part rounded toward
-   // zero. rhs must not be zero, and the division must not overflow.
-   //
-   // On ARM, the chip must have hardware division instructions.
-   inline void quotient32(Register rhs, Register srcDest, bool isUnsigned)
--      DEFINED_ON(mips_shared, arm, arm64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, loong64, riscv64);
- 
-   // As above, but srcDest must be eax and tempEdx must be edx.
-   inline void quotient32(Register rhs, Register srcDest, Register tempEdx,
-@@ -1134,7 +1142,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   //
-   // On ARM, the chip must have hardware division instructions.
-   inline void remainder32(Register rhs, Register srcDest, bool isUnsigned)
--      DEFINED_ON(mips_shared, arm, arm64, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, loong64, riscv64);
- 
-   // As above, but srcDest must be eax and tempEdx must be edx.
-   inline void remainder32(Register rhs, Register srcDest, Register tempEdx,
-@@ -1149,7 +1157,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // rhs is preserved, srdDest is clobbered.
-   void flexibleRemainder32(Register rhs, Register srcDest, bool isUnsigned,
-                            const LiveRegisterSet& volatileLiveRegs)
--      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64, riscv64);
- 
-   // Perform an integer division, returning the integer part rounded toward
-   // zero. rhs must not be zero, and the division must not overflow.
-@@ -1160,7 +1168,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // rhs is preserved, srdDest is clobbered.
-   void flexibleQuotient32(Register rhs, Register srcDest, bool isUnsigned,
-                           const LiveRegisterSet& volatileLiveRegs)
--      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64, riscv64);
- 
-   // Perform an integer division, returning the integer part rounded toward
-   // zero. rhs must not be zero, and the division must not overflow. The
-@@ -1173,7 +1181,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   void flexibleDivMod32(Register rhs, Register srcDest, Register remOutput,
-                         bool isUnsigned,
-                         const LiveRegisterSet& volatileLiveRegs)
--      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64);
-+      DEFINED_ON(mips_shared, arm, arm64, x86_shared, loong64, riscv64);
- 
-   inline void divFloat32(FloatRegister src, FloatRegister dest) PER_SHARED_ARCH;
-   inline void divDouble(FloatRegister src, FloatRegister dest) PER_SHARED_ARCH;
-@@ -1380,7 +1388,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   template <typename T1, typename T2>
-   inline void cmp32Set(Condition cond, T1 lhs, T2 rhs, Register dest)
--      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64);
-+      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64, riscv64);
- 
-   // Only the NotEqual and Equal conditions are allowed.
-   inline void cmp64Set(Condition cond, Address lhs, Imm64 rhs,
-@@ -1415,10 +1423,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void branch32(Condition cond, const AbsoluteAddress& lhs, Register rhs,
-                        Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void branch32(Condition cond, const AbsoluteAddress& lhs, Imm32 rhs,
-                        Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   inline void branch32(Condition cond, const BaseIndex& lhs, Register rhs,
-                        Label* label) DEFINED_ON(arm, x86_shared);
-@@ -1432,7 +1440,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void branch32(Condition cond, wasm::SymbolicAddress lhs, Imm32 rhs,
-                        Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   // The supported condition are Equal, NotEqual, LessThan(orEqual),
-   // GreaterThan(orEqual), Below(orEqual) and Above(orEqual). When a fail label
-@@ -1483,14 +1491,14 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void branchPtr(Condition cond, const AbsoluteAddress& lhs,
-                         Register rhs, Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void branchPtr(Condition cond, const AbsoluteAddress& lhs, ImmWord rhs,
-                         Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   inline void branchPtr(Condition cond, wasm::SymbolicAddress lhs, Register rhs,
-                         Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   // Given a pointer to a GC Cell, retrieve the StoreBuffer pointer from its
-   // chunk header, or nullptr if it is in the tenured heap.
-@@ -1498,7 +1506,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   void branchPtrInNurseryChunk(Condition cond, Register ptr, Register temp,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   void branchPtrInNurseryChunk(Condition cond, const Address& address,
-                                Register temp, Label* label) DEFINED_ON(x86);
-   void branchValueIsNurseryCell(Condition cond, const Address& address,
-@@ -1520,10 +1528,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // x64 variants will do this only in the int64_t range.
-   inline void branchTruncateFloat32MaybeModUint32(FloatRegister src,
-                                                   Register dest, Label* fail)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void branchTruncateDoubleMaybeModUint32(FloatRegister src,
-                                                  Register dest, Label* fail)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   // Truncate a double/float32 to intptr and when it doesn't fit jump to the
-   // failure label.
-@@ -1536,10 +1544,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // failure label.
-   inline void branchTruncateFloat32ToInt32(FloatRegister src, Register dest,
-                                            Label* fail)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void branchTruncateDoubleToInt32(FloatRegister src, Register dest,
-                                           Label* fail)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   inline void branchDouble(DoubleCondition cond, FloatRegister lhs,
-                            FloatRegister rhs, Label* label) PER_SHARED_ARCH;
-@@ -1596,7 +1604,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                            Label* label) PER_SHARED_ARCH;
-   inline void branchTest32(Condition cond, const AbsoluteAddress& lhs,
-                            Imm32 rhs, Label* label)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   template <class L>
-   inline void branchTestPtr(Condition cond, Register lhs, Register rhs,
-@@ -1757,7 +1765,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   inline void branchTestInt32(Condition cond, Register tag,
-                               Label* label) PER_SHARED_ARCH;
-   inline void branchTestDouble(Condition cond, Register tag, Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
-   inline void branchTestNumber(Condition cond, Register tag,
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestBoolean(Condition cond, Register tag,
-@@ -1789,7 +1797,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                   Label* label) PER_SHARED_ARCH;
-   inline void branchTestUndefined(Condition cond, const ValueOperand& value,
-                                   Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestInt32(Condition cond, const Address& address,
-                               Label* label) PER_SHARED_ARCH;
-@@ -1797,7 +1805,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                               Label* label) PER_SHARED_ARCH;
-   inline void branchTestInt32(Condition cond, const ValueOperand& value,
-                               Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestDouble(Condition cond, const Address& address,
-                                Label* label) PER_SHARED_ARCH;
-@@ -1805,11 +1813,11 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestDouble(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestNumber(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestBoolean(Condition cond, const Address& address,
-                                 Label* label) PER_SHARED_ARCH;
-@@ -1817,7 +1825,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                 Label* label) PER_SHARED_ARCH;
-   inline void branchTestBoolean(Condition cond, const ValueOperand& value,
-                                 Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestString(Condition cond, const Address& address,
-                                Label* label) PER_SHARED_ARCH;
-@@ -1825,7 +1833,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestString(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestSymbol(Condition cond, const Address& address,
-                                Label* label) PER_SHARED_ARCH;
-@@ -1833,7 +1841,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestSymbol(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestBigInt(Condition cond, const Address& address,
-                                Label* label) PER_SHARED_ARCH;
-@@ -1841,7 +1849,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestBigInt(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestNull(Condition cond, const Address& address,
-                              Label* label) PER_SHARED_ARCH;
-@@ -1849,7 +1857,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                              Label* label) PER_SHARED_ARCH;
-   inline void branchTestNull(Condition cond, const ValueOperand& value,
-                              Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   // Clobbers the ScratchReg on x64.
-   inline void branchTestObject(Condition cond, const Address& address,
-@@ -1858,7 +1866,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-                                Label* label) PER_SHARED_ARCH;
-   inline void branchTestObject(Condition cond, const ValueOperand& value,
-                                Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestGCThing(Condition cond, const Address& address,
-                                 Label* label) PER_SHARED_ARCH;
-@@ -1869,7 +1877,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void branchTestPrimitive(Condition cond, const ValueOperand& value,
-                                   Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestMagic(Condition cond, const Address& address,
-                               Label* label) PER_SHARED_ARCH;
-@@ -1878,7 +1886,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   template <class L>
-   inline void branchTestMagic(Condition cond, const ValueOperand& value,
-                               L label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   inline void branchTestMagic(Condition cond, const Address& valaddr,
-                               JSWhyMagic why, Label* label) PER_ARCH;
-@@ -1896,17 +1904,17 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // The type of the value should match the type of the method.
-   inline void branchTestInt32Truthy(bool truthy, const ValueOperand& value,
-                                     Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
-   inline void branchTestDoubleTruthy(bool truthy, FloatRegister reg,
-                                      Label* label) PER_SHARED_ARCH;
-   inline void branchTestBooleanTruthy(bool truthy, const ValueOperand& value,
-                                       Label* label) PER_ARCH;
-   inline void branchTestStringTruthy(bool truthy, const ValueOperand& value,
-                                      Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
-   inline void branchTestBigIntTruthy(bool truthy, const ValueOperand& value,
-                                      Label* label)
--      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared);
-+      DEFINED_ON(arm, arm64, mips32, mips64, loong64, x86_shared, riscv64);
- 
-   // Create an unconditional branch to the address given as argument.
-   inline void branchToComputedAddress(const BaseIndex& address) PER_ARCH;
-@@ -2008,11 +2016,11 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void cmp32Move32(Condition cond, Register lhs, Register rhs,
-                           Register src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared, riscv64);
- 
-   inline void cmp32Move32(Condition cond, Register lhs, const Address& rhs,
-                           Register src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared, riscv64);
- 
-   inline void cmpPtrMovePtr(Condition cond, Register lhs, Register rhs,
-                             Register src, Register dest) PER_ARCH;
-@@ -2022,36 +2030,36 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void cmp32Load32(Condition cond, Register lhs, const Address& rhs,
-                           const Address& src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared, riscv64);
- 
-   inline void cmp32Load32(Condition cond, Register lhs, Register rhs,
-                           const Address& src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86_shared, riscv64);
- 
-   inline void cmp32LoadPtr(Condition cond, const Address& lhs, Imm32 rhs,
-                            const Address& src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64, riscv64);
- 
-   inline void cmp32MovePtr(Condition cond, Register lhs, Imm32 rhs,
-                            Register src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64, riscv64);
- 
-   inline void test32LoadPtr(Condition cond, const Address& addr, Imm32 mask,
-                             const Address& src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64, riscv64);
- 
-   inline void test32MovePtr(Condition cond, const Address& addr, Imm32 mask,
-                             Register src, Register dest)
--      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64);
-+      DEFINED_ON(arm, arm64, loong64, mips_shared, x86, x64, riscv64);
- 
-   // Conditional move for Spectre mitigations.
-   inline void spectreMovePtr(Condition cond, Register src, Register dest)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   // Zeroes dest if the condition is true.
-   inline void spectreZeroRegister(Condition cond, Register scratch,
-                                   Register dest)
--      DEFINED_ON(arm, arm64, mips_shared, x86_shared, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86_shared, loong64, riscv64);
- 
-   // Performs a bounds check and zeroes the index register if out-of-bounds
-   // (to mitigate Spectre).
-@@ -2063,17 +2071,17 @@ class MacroAssembler : public MacroAssemblerSpecific {
-  public:
-   inline void spectreBoundsCheck32(Register index, Register length,
-                                    Register maybeScratch, Label* failure)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void spectreBoundsCheck32(Register index, const Address& length,
-                                    Register maybeScratch, Label* failure)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   inline void spectreBoundsCheckPtr(Register index, Register length,
-                                     Register maybeScratch, Label* failure)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
-   inline void spectreBoundsCheckPtr(Register index, const Address& length,
-                                     Register maybeScratch, Label* failure)
--      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64);
-+      DEFINED_ON(arm, arm64, mips_shared, x86, x64, loong64, riscv64);
- 
-   // ========================================================================
-   // Canonicalization primitives.
-@@ -2087,10 +2095,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // ========================================================================
-   // Memory access primitives.
-   inline void storeUncanonicalizedDouble(FloatRegister src, const Address& dest)
--      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64);
-+      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64, riscv64);
-   inline void storeUncanonicalizedDouble(FloatRegister src,
-                                          const BaseIndex& dest)
--      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64);
-+      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64, riscv64);
-   inline void storeUncanonicalizedDouble(FloatRegister src, const Operand& dest)
-       DEFINED_ON(x86_shared);
- 
-@@ -2104,10 +2112,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   inline void storeUncanonicalizedFloat32(FloatRegister src,
-                                           const Address& dest)
--      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64);
-+      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64, riscv64);
-   inline void storeUncanonicalizedFloat32(FloatRegister src,
-                                           const BaseIndex& dest)
--      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64);
-+      DEFINED_ON(x86_shared, arm, arm64, mips32, mips64, loong64, riscv64);
-   inline void storeUncanonicalizedFloat32(FloatRegister src,
-                                           const Operand& dest)
-       DEFINED_ON(x86_shared);
-@@ -3508,10 +3516,10 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   // temp required on x86 and x64; must be undefined on mips64 and loong64.
-   void convertUInt64ToFloat32(Register64 src, FloatRegister dest, Register temp)
--      DEFINED_ON(arm64, mips64, loong64, x64, x86);
-+      DEFINED_ON(arm64, mips64, loong64, x64, x86, riscv64);
- 
-   void convertInt64ToFloat32(Register64 src, FloatRegister dest)
--      DEFINED_ON(arm64, mips64, loong64, x64, x86);
-+      DEFINED_ON(arm64, mips64, loong64, x64, x86, riscv64);
- 
-   bool convertUInt64ToDoubleNeedsTemp() PER_ARCH;
- 
-@@ -3563,19 +3571,19 @@ class MacroAssembler : public MacroAssemblerSpecific {
- 
-   void wasmBoundsCheck32(Condition cond, Register index,
-                          Register boundsCheckLimit, Label* ok)
--      DEFINED_ON(arm, arm64, mips32, mips64, x86_shared, loong64);
-+      DEFINED_ON(arm, arm64, mips32, mips64, x86_shared, loong64, riscv64);
- 
-   void wasmBoundsCheck32(Condition cond, Register index,
-                          Address boundsCheckLimit, Label* ok)
--      DEFINED_ON(arm, arm64, mips32, mips64, x86_shared, loong64);
-+      DEFINED_ON(arm, arm64, mips32, mips64, x86_shared, loong64, riscv64);
- 
-   void wasmBoundsCheck64(Condition cond, Register64 index,
-                          Register64 boundsCheckLimit, Label* ok)
--      DEFINED_ON(arm64, mips64, x64, x86, arm, loong64);
-+      DEFINED_ON(arm64, mips64, x64, x86, arm, loong64, riscv64);
- 
-   void wasmBoundsCheck64(Condition cond, Register64 index,
-                          Address boundsCheckLimit, Label* ok)
--      DEFINED_ON(arm64, mips64, x64, x86, arm, loong64);
-+      DEFINED_ON(arm64, mips64, x64, x86, arm, loong64, riscv64);
- 
-   // Each wasm load/store instruction appends its own wasm::Trap::OutOfBounds.
-   void wasmLoad(const wasm::MemoryAccessDesc& access, Operand srcAddr,
-@@ -3668,7 +3676,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   void oolWasmTruncateCheckF64ToI32(FloatRegister input, Register output,
-                                     TruncFlags flags, wasm::BytecodeOffset off,
-                                     Label* rejoin)
--      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64);
-+      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64, riscv64);
- 
-   void wasmTruncateFloat32ToUInt32(FloatRegister input, Register output,
-                                    bool isSaturating, Label* oolEntry) PER_ARCH;
-@@ -3678,35 +3686,35 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   void oolWasmTruncateCheckF32ToI32(FloatRegister input, Register output,
-                                     TruncFlags flags, wasm::BytecodeOffset off,
-                                     Label* rejoin)
--      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64);
-+      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64, riscv64);
- 
-   // The truncate-to-int64 methods will always bind the `oolRejoin` label
-   // after the last emitted instruction.
-   void wasmTruncateDoubleToInt64(FloatRegister input, Register64 output,
-                                  bool isSaturating, Label* oolEntry,
-                                  Label* oolRejoin, FloatRegister tempDouble)
--      DEFINED_ON(arm64, x86, x64, mips64, loong64);
-+      DEFINED_ON(arm64, x86, x64, mips64, loong64, riscv64);
-   void wasmTruncateDoubleToUInt64(FloatRegister input, Register64 output,
-                                   bool isSaturating, Label* oolEntry,
-                                   Label* oolRejoin, FloatRegister tempDouble)
--      DEFINED_ON(arm64, x86, x64, mips64, loong64);
-+      DEFINED_ON(arm64, x86, x64, mips64, loong64, riscv64);
-   void oolWasmTruncateCheckF64ToI64(FloatRegister input, Register64 output,
-                                     TruncFlags flags, wasm::BytecodeOffset off,
-                                     Label* rejoin)
--      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64);
-+      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64, riscv64);
- 
-   void wasmTruncateFloat32ToInt64(FloatRegister input, Register64 output,
-                                   bool isSaturating, Label* oolEntry,
-                                   Label* oolRejoin, FloatRegister tempDouble)
--      DEFINED_ON(arm64, x86, x64, mips64, loong64);
-+      DEFINED_ON(arm64, x86, x64, mips64, loong64, riscv64);
-   void wasmTruncateFloat32ToUInt64(FloatRegister input, Register64 output,
-                                    bool isSaturating, Label* oolEntry,
-                                    Label* oolRejoin, FloatRegister tempDouble)
--      DEFINED_ON(arm64, x86, x64, mips64, loong64);
-+      DEFINED_ON(arm64, x86, x64, mips64, loong64, riscv64);
-   void oolWasmTruncateCheckF32ToI64(FloatRegister input, Register64 output,
-                                     TruncFlags flags, wasm::BytecodeOffset off,
-                                     Label* rejoin)
--      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64);
-+      DEFINED_ON(arm, arm64, x86_shared, mips_shared, loong64, riscv64);
- 
-   void loadWasmGlobalPtr(uint32_t globalDataOffset, Register dest);
- 
-@@ -3764,7 +3772,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   // convention, which requires predictable high bits.  In practice, this means
-   // that the 32-bit value will be zero-extended or sign-extended to 64 bits as
-   // appropriate for the platform.
--  void widenInt32(Register r) DEFINED_ON(arm64, x64, mips64, loong64);
-+  void widenInt32(Register r) DEFINED_ON(arm64, x64, mips64, loong64, riscv64);
- 
-   // As enterFakeExitFrame(), but using register conventions appropriate for
-   // wasm stubs.
-@@ -5006,7 +5014,7 @@ class MacroAssembler : public MacroAssemblerSpecific {
-   inline void addStackPtrTo(T t);
- 
-   void subFromStackPtr(Imm32 imm32)
--      DEFINED_ON(mips32, mips64, loong64, arm, x86, x64);
-+      DEFINED_ON(mips32, mips64, loong64, arm, x86, x64, riscv64);
-   void subFromStackPtr(Register reg);
- 
-   template <typename T>
-diff --git a/js/src/jit/MoveEmitter.h b/js/src/jit/MoveEmitter.h
-index a51cbc100a..ea4d92bedc 100644
---- a/js/src/jit/MoveEmitter.h
-+++ b/js/src/jit/MoveEmitter.h
-@@ -17,6 +17,8 @@
- #  include "jit/mips32/MoveEmitter-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/MoveEmitter-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/MoveEmitter-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/MoveEmitter-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/Registers.h b/js/src/jit/Registers.h
-index 2c1cec0771..baf0630e07 100644
---- a/js/src/jit/Registers.h
-+++ b/js/src/jit/Registers.h
-@@ -20,6 +20,8 @@
- #  include "jit/mips32/Architecture-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/Architecture-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/Architecture-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/Architecture-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/SharedICHelpers-inl.h b/js/src/jit/SharedICHelpers-inl.h
-index 60a77956f0..242f5d3f27 100644
---- a/js/src/jit/SharedICHelpers-inl.h
-+++ b/js/src/jit/SharedICHelpers-inl.h
-@@ -17,6 +17,8 @@
- #  include "jit/arm64/SharedICHelpers-arm64-inl.h"
- #elif defined(JS_CODEGEN_MIPS32) || defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips-shared/SharedICHelpers-mips-shared-inl.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/SharedICHelpers-riscv64-inl.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/SharedICHelpers-loong64-inl.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/SharedICHelpers.h b/js/src/jit/SharedICHelpers.h
-index da8378ebae..bfe4a1b672 100644
---- a/js/src/jit/SharedICHelpers.h
-+++ b/js/src/jit/SharedICHelpers.h
-@@ -17,6 +17,8 @@
- #  include "jit/arm64/SharedICHelpers-arm64.h"
- #elif defined(JS_CODEGEN_MIPS32) || defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips-shared/SharedICHelpers-mips-shared.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/SharedICHelpers-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/SharedICHelpers-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/SharedICRegisters.h b/js/src/jit/SharedICRegisters.h
-index e29f21c28d..4091d9f595 100644
---- a/js/src/jit/SharedICRegisters.h
-+++ b/js/src/jit/SharedICRegisters.h
-@@ -19,6 +19,8 @@
- #  include "jit/mips32/SharedICRegisters-mips32.h"
- #elif defined(JS_CODEGEN_MIPS64)
- #  include "jit/mips64/SharedICRegisters-mips64.h"
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  include "jit/riscv64/SharedICRegisters-riscv64.h"
- #elif defined(JS_CODEGEN_LOONG64)
- #  include "jit/loong64/SharedICRegisters-loong64.h"
- #elif defined(JS_CODEGEN_NONE)
-diff --git a/js/src/jit/moz.build b/js/src/jit/moz.build
-index 967146e32f..1519351bbb 100644
---- a/js/src/jit/moz.build
-+++ b/js/src/jit/moz.build
-@@ -212,6 +212,13 @@ elif CONFIG["JS_CODEGEN_MIPS32"] or CONFIG["JS_CODEGEN_MIPS64"]:
-         ]
-         if CONFIG["JS_SIMULATOR_MIPS64"]:
-             UNIFIED_SOURCES += ["mips64/Simulator-mips64.cpp"]
-+elif CONFIG["JS_CODEGEN_RISCV64"]:
-+    UNIFIED_SOURCES += [
-+        "riscv64/Assembler-riscv64.cpp",
-+        "riscv64/Trampoline-riscv64.cpp",
-+    ]
-+    if CONFIG["JS_SIMULATOR_RISC64"]:
-+        UNIFIED_SOURCES += ["riscv64/Simulator-riscv64.cpp"]
- elif CONFIG["JS_CODEGEN_LOONG64"]:
-     UNIFIED_SOURCES += [
-         "loong64/Architecture-loong64.cpp",
-@@ -225,7 +232,6 @@ elif CONFIG["JS_CODEGEN_LOONG64"]:
-     if CONFIG["JS_SIMULATOR_LOONG64"]:
-         UNIFIED_SOURCES += ["loong64/Simulator-loong64.cpp"]
- 
--
- # Generate jit/MIROpsGenerated.h from jit/MIROps.yaml
- GeneratedFile(
-     "MIROpsGenerated.h",
-diff --git a/js/src/jit/riscv64/Architecture-riscv64.h b/js/src/jit/riscv64/Architecture-riscv64.h
-new file mode 100644
-index 0000000000..a676dc142e
---- /dev/null
-+++ b/js/src/jit/riscv64/Architecture-riscv64.h
-@@ -0,0 +1,404 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_Architecture_riscv64_h
-+#define jit_riscv64_Architecture_riscv64_h
-+
-+// JitSpewer.h is included through MacroAssembler implementations for other
-+// platforms, so include it here to avoid inadvertent build bustage.
-+#include "jit/JitSpewer.h"
-+
-+#include "jit/shared/Architecture-shared.h"
-+
-+namespace js {
-+namespace jit {
-+
-+static const uint32_t SimdMemoryAlignment =
-+    4;  // Make it 4 to avoid a bunch of div-by-zero warnings
-+static const uint32_t WasmStackAlignment = 8;
-+static const uint32_t WasmTrapInstructionLength = 0;
-+
-+// See comments in wasm::GenerateFunctionPrologue.
-+static constexpr uint32_t WasmCheckedCallEntryOffset = 0u;
-+static constexpr uint32_t WasmCheckedTailEntryOffset = 1u;
-+
-+class Registers {
-+ public:
-+  enum RegisterID {
-+    x0 = 0,
-+    zero = 0,
-+    x1 = 1,
-+    ra = 1,
-+    x2 = 2,
-+    sp = 2,
-+    x3 = 3,
-+    gp = 3,
-+    x4 = 4,
-+    tp = 4,
-+    x5 = 5,
-+    t0 = 5,
-+    x6 = 6,
-+    t1 = 6,
-+    x7 = 7,
-+    t2 = 7,
-+    x8 = 8,
-+    fp = 8,
-+    s0 = 8,
-+    x9 = 9,
-+    s1 = 9,
-+    x10 = 10,
-+    a0 = 10,
-+    x11 = 11,
-+    a1 = 11,
-+    x12 = 12,
-+    a2 = 12,
-+    x13 = 13,
-+    a3 = 13,
-+    x14 = 14,
-+    a4 = 14,
-+    x15 = 15,
-+    a5 = 15,
-+    x16 = 16,
-+    a6 = 16,
-+    x17 = 17,
-+    a7 = 17,
-+    x18 = 18,
-+    s2 = 18,
-+    x19 = 19,
-+    s3 = 19,
-+    x20 = 20,
-+    s4 = 20,
-+    x21 = 21,
-+    s5 = 21,
-+    x22 = 22,
-+    s6 = 22,
-+    x23 = 23,
-+    s7 = 23,
-+    x24 = 24,
-+    s8 = 24,
-+    x25 = 25,
-+    s9 = 25,
-+    x26 = 26,
-+    s10 = 26,
-+    x27 = 27,
-+    s11 = 27,
-+    x28 = 28,
-+    t3 = 28,
-+    x29 = 29,
-+    t4 = 29,
-+    x30 = 30,
-+    t5 = 30,
-+    x31 = 31,
-+    t6 = 31,
-+    invalid_reg
-+  };
-+  typedef uint8_t Code;
-+  typedef RegisterID Encoding;
-+  union RegisterContent {
-+    uintptr_t r;
-+  };
-+
-+  typedef uint32_t SetType;
-+
-+  static uint32_t SetSize(SetType x) {
-+    static_assert(sizeof(SetType) == 4, "SetType must be 32 bits");
-+    return mozilla::CountPopulation32(x);
-+  }
-+  static uint32_t FirstBit(SetType x) {
-+    return mozilla::CountTrailingZeroes32(x);
-+  }
-+  static uint32_t LastBit(SetType x) {
-+    return 31 - mozilla::CountLeadingZeroes32(x);
-+  }
-+
-+  static const char* GetName(uint32_t code) {
-+    // clang-format off
-+    static const char* const Names[] = {
-+        "zero", "ra", "sp",  "gp",  "tp", "t0", "t1", "t2",
-+        "fp",   "s1", "a0",  "a1",  "a2", "a3", "a4", "a5",
-+        "a6",   "a7", "s2",  "s3",  "s4", "s5", "s6", "s7",
-+        "s8",   "s9", "s10", "s11", "t3", "t4", "t5", "t6"};
-+    // clang-format on
-+    static_assert(Total == sizeof(Names) / sizeof(Names[0]),
-+                  "Table is the correct size");
-+    if (code >= Total) {
-+      return "invalid";
-+    }
-+    return Names[code];
-+  }
-+
-+  static Code FromName(const char* name) {
-+    for (size_t i = 0; i < Total; i++) {
-+      if (strcmp(GetName(Code(i)), name) == 0) {
-+        return Code(i);
-+      }
-+    }
-+    return Invalid;
-+  }
-+
-+  static const Encoding StackPointer = sp;
-+  static const Encoding Invalid = invalid_reg;
-+  static const uint32_t Total = 32;
-+  static const uint32_t TotalPhys = 32;
-+  static const uint32_t Allocatable = 28;
-+  static const SetType AllMask = 0xffffffff;
-+  static const SetType ArgRegMask =
-+      (1 << Registers::a0) | (1 << Registers::a1) | (1 << Registers::a2) |
-+      (1 << Registers::a3) | (1 << Registers::a4) | (1 << Registers::a5) |
-+      (1 << Registers::a6) | (1 << Registers::a7);
-+  static const SetType VolatileMask =
-+      (1 << Registers::a0) | (1 << Registers::a1) | (1 << Registers::a2) |
-+      (1 << Registers::a3) | (1 << Registers::a4) | (1 << Registers::a5) |
-+      (1 << Registers::a6) | (1 << Registers::a7) | (1 << Registers::t0) |
-+      (1 << Registers::t1) | (1 << Registers::t2) | (1 << Registers::t3) |
-+      (1 << Registers::t4) | (1 << Registers::t5) | (1 << Registers::t6);
-+  static const SetType NonVolatileMask =
-+      (1 << Registers::s0) | (1 << Registers::s1) | (1 << Registers::s2) |
-+      (1 << Registers::s3) | (1 << Registers::s4) | (1 << Registers::s5) |
-+      (1 << Registers::s6) | (1 << Registers::s7) | (1 << Registers::s8) |
-+      (1 << Registers::s9) | (1 << Registers::s10) | (1 << Registers::s11);
-+  static const SetType NonAllocatableMask =
-+      (1 << Registers::zero) | (1 << Registers::sp) | (1 << Registers::tp) |
-+      (1 << Registers::gp);
-+  static const SetType AllocatableMask = AllMask & ~NonAllocatableMask;
-+  static const SetType JSCallMask = 0;
-+  static const SetType CallMask = 0;
-+};
-+
-+typedef uint8_t PackedRegisterMask;
-+
-+class FloatRegisters {
-+ public:
-+  enum FPRegisterID {
-+    f0 = 0,
-+    ft0 = 0,
-+    f1 = 1,
-+    ft1 = 1,
-+    f2 = 2,
-+    ft2 = 2,
-+    f3 = 3,
-+    ft3 = 3,
-+    f4 = 4,
-+    ft4 = 4,
-+    f5 = 5,
-+    ft5 = 5,
-+    f6 = 6,
-+    ft6 = 6,
-+    f7 = 7,
-+    ft7 = 7,
-+    f8 = 8,
-+    fs0 = 8,
-+    f9 = 9,
-+    fs1 = 9,
-+    f10 = 10,
-+    fa0 = 10,
-+    f11 = 11,
-+    fa1 = 11,
-+    f12 = 12,
-+    fa2 = 12,
-+    f13 = 13,
-+    fa3 = 13,
-+    f14 = 14,
-+    fa4 = 14,
-+    f15 = 15,
-+    fa5 = 15,
-+    f16 = 16,
-+    fa6 = 16,
-+    f17 = 17,
-+    fa7 = 17,
-+    f18 = 18,
-+    fs2 = 18,
-+    f19 = 19,
-+    fs3 = 19,
-+    f20 = 20,
-+    fs4 = 20,
-+    f21 = 21,
-+    fs5 = 21,
-+    f22 = 22,
-+    fs6 = 22,
-+    f23 = 23,
-+    fs7 = 23,
-+    f24 = 24,
-+    fs8 = 24,
-+    f25 = 25,
-+    fs9 = 25,
-+    f26 = 26,
-+    fs10 = 26,
-+    f27 = 27,
-+    fs11 = 27,
-+    f28 = 28,
-+    ft8 = 28,
-+    f29 = 29,
-+    ft9 = 29,
-+    f30 = 30,
-+    ft10 = 30,
-+    f31 = 31,
-+    ft11 = 31,
-+    invalid_reg
-+  };
-+
-+  typedef uint8_t Code;
-+  typedef FPRegisterID Encoding;
-+  typedef uint32_t SetType;
-+
-+  enum Kind : uint8_t { Double, Single };
-+
-+  union RegisterContent {
-+    float s;
-+    double d;
-+  };
-+
-+  static const char* GetName(uint32_t code) {
-+    // clang-format off
-+    static const char* const Names[] = {
-+        "ft0", "ft1", "ft2", "ft3", "ft4", "ft5", "ft6", "ft7",
-+        "fs0", "fs1", "fa0", "fa1", "fa2", "fa3", "fa4", "fa5",
-+        "fa6", "fa7", "fs2", "fs3", "fs4", "fs5", "fs6", "fs7",
-+        "fs8", "fs9", "fs10", "fs11", "ft8", "ft9", "ft10", "ft11",
-+    };
-+    // clang-format on
-+    static_assert(Total == sizeof(Names) / sizeof(Names[0]),
-+                  "Table is the correct size");
-+    if (code >= Total) {
-+      return "invalid";
-+    }
-+    return Names[code];
-+  }
-+  static Code FromName(const char* name) {
-+    for (size_t i = 0; i < Total; i++) {
-+      if (strcmp(GetName(i), name) == 0) {
-+        return Code(i);
-+      }
-+    }
-+
-+    return Invalid;
-+  }
-+
-+  static constexpr Encoding encoding(Code c) { return Encoding(c & 31); }
-+
-+  static const Encoding Invalid = invalid_reg;
-+  static const uint32_t Total = 32;
-+  static const uint32_t TotalPhys = 32;
-+  static const uint32_t Allocatable = 32;
-+  static const SetType AllMask = 0xffffffff;
-+  static const SetType AllDoubleMask = 0;
-+  static const SetType AllSingleMask = 0;
-+  static const SetType VolatileMask =
-+      (1 << FloatRegisters::ft0) | (1 << FloatRegisters::ft1) |
-+      (1 << FloatRegisters::ft2) | (1 << FloatRegisters::ft3) |
-+      (1 << FloatRegisters::ft4) | (1 << FloatRegisters::ft5) |
-+      (1 << FloatRegisters::ft6) | (1 << FloatRegisters::ft7) |
-+      (1 << FloatRegisters::ft8) | (1 << FloatRegisters::ft9) |
-+      (1 << FloatRegisters::ft10) | (1 << FloatRegisters::ft11) |
-+      (1 << FloatRegisters::fa0) | (1 << FloatRegisters::fa1) |
-+      (1 << FloatRegisters::fa2) | (1 << FloatRegisters::fa3) |
-+      (1 << FloatRegisters::fa4) | (1 << FloatRegisters::fa5) |
-+      (1 << FloatRegisters::fa6) | (1 << FloatRegisters::fa7);
-+  static const SetType NonVolatileMask =
-+      (1 << FloatRegisters::fs0) | (1 << FloatRegisters::fs1) |
-+      (1 << FloatRegisters::fs2) | (1 << FloatRegisters::fs3) |
-+      (1 << FloatRegisters::fs4) | (1 << FloatRegisters::fs5) |
-+      (1 << FloatRegisters::fs6) | (1 << FloatRegisters::fs7) |
-+      (1 << FloatRegisters::fs8) | (1 << FloatRegisters::fs9) |
-+      (1 << FloatRegisters::fs10) | (1 << FloatRegisters::fs11);
-+  static const SetType NonAllocatableMask = 0;
-+  static const SetType AllocatableMask = AllMask & ~NonAllocatableMask;
-+};
-+
-+template <typename T>
-+class TypedRegisterSet;
-+
-+struct FloatRegister {
-+  typedef FloatRegisters Codes;
-+  typedef size_t Code;
-+  typedef Codes::Encoding Encoding;
-+  typedef Codes::SetType SetType;
-+  typedef Codes::Kind Kind;
-+
-+ private:
-+  uint8_t encoding_;
-+  uint8_t kind_;
-+  bool invalid_;
-+
-+ public:
-+  constexpr FloatRegister(Encoding encoding)
-+      : encoding_(encoding), kind_(FloatRegisters::Double), invalid_(false) {}
-+  constexpr FloatRegister(Encoding encoding, Kind kind)
-+      : encoding_(encoding), kind_(kind), invalid_(false) {}
-+  constexpr FloatRegister()
-+      : encoding_(0), kind_(FloatRegisters::Double), invalid_(true) {}
-+
-+  static uint32_t FirstBit(SetType) { MOZ_CRASH(); }
-+  static uint32_t LastBit(SetType) { MOZ_CRASH(); }
-+  static FloatRegister FromCode(uint32_t i) {
-+    return FloatRegister(FloatRegisters::encoding(i), FloatRegisters::Double);
-+  }
-+  bool isSingle() const { return kind_ == FloatRegisters::Single; }
-+  bool isDouble() const { return kind_ == FloatRegisters::Double; }
-+  bool isSimd128() const { return false; }
-+  bool isInvalid() const { return invalid_; }
-+  FloatRegister asSingle() const { MOZ_CRASH(); }
-+  FloatRegister asDouble() const { MOZ_CRASH(); }
-+  FloatRegister asSimd128() const { MOZ_CRASH(); }
-+  Code code() const { MOZ_CRASH(); }
-+  Encoding encoding() const { return Encoding(encoding_); }
-+  const char* name() const { return FloatRegisters::GetName(code()); }
-+  bool volatile_() const { MOZ_CRASH(); }
-+  bool operator!=(FloatRegister) const { MOZ_CRASH(); }
-+  bool operator==(FloatRegister) const { MOZ_CRASH(); }
-+  bool aliases(FloatRegister) const { MOZ_CRASH(); }
-+  uint32_t numAliased() const { MOZ_CRASH(); }
-+  FloatRegister aliased(uint32_t) { MOZ_CRASH(); }
-+  bool equiv(FloatRegister) const { MOZ_CRASH(); }
-+  uint32_t size() const { MOZ_CRASH(); }
-+  uint32_t numAlignedAliased() const { MOZ_CRASH(); }
-+  FloatRegister alignedAliased(uint32_t) { MOZ_CRASH(); }
-+  SetType alignedOrDominatedAliasedSet() const { MOZ_CRASH(); }
-+
-+  static constexpr RegTypeName DefaultType = RegTypeName::Float64;
-+
-+  template <RegTypeName = DefaultType>
-+  static SetType LiveAsIndexableSet(SetType s) {
-+    return SetType(0);
-+  }
-+
-+  template <RegTypeName Name = DefaultType>
-+  static SetType AllocatableAsIndexableSet(SetType s) {
-+    static_assert(Name != RegTypeName::Any, "Allocatable set are not iterable");
-+    return SetType(0);
-+  }
-+
-+  template <typename T>
-+  static T ReduceSetForPush(T) {
-+    MOZ_CRASH();
-+  }
-+  uint32_t getRegisterDumpOffsetInBytes() {
-+    MOZ_CRASH();
-+    return 0;
-+  }
-+  static uint32_t SetSize(SetType x) {
-+    MOZ_CRASH();
-+    return 0;
-+  }
-+  static Code FromName(const char* name) { return 0; }
-+
-+  // This is used in static initializers, so produce a bogus value instead of
-+  // crashing.
-+  static uint32_t GetPushSizeInBytes(const TypedRegisterSet<FloatRegister>&) {
-+    return 0;
-+  }
-+};
-+
-+inline bool hasUnaliasedDouble() { MOZ_CRASH(); }
-+inline bool hasMultiAlias() { MOZ_CRASH(); }
-+
-+static const uint32_t ShadowStackSpace = 0;
-+static const uint32_t JumpImmediateRange = INT32_MAX;
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_Architecture_riscv64_h */
-diff --git a/js/src/jit/riscv64/Assembler-riscv64.cpp b/js/src/jit/riscv64/Assembler-riscv64.cpp
-new file mode 100644
-index 0000000000..90fa6d87a8
---- /dev/null
-+++ b/js/src/jit/riscv64/Assembler-riscv64.cpp
-@@ -0,0 +1,47 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#include "jit/riscv64/Assembler-riscv64.h"
-+
-+using namespace js;
-+using namespace js::jit;
-+
-+ABIArg ABIArgGenerator::next(MIRType type) {
-+  switch (type) {
-+    case MIRType::Int32:
-+    case MIRType::Int64:
-+    case MIRType::Pointer:
-+    case MIRType::RefOrNull:
-+    case MIRType::StackResults:
-+      if (intRegIndex_ == NumIntArgRegs) {
-+        current_ = ABIArg(stackOffset_);
-+        stackOffset_ += sizeof(uintptr_t);
-+        break;
-+      }
-+      current_ = ABIArg(Register::FromCode(intRegIndex_));
-+      intRegIndex_++;
-+      break;
-+
-+    case MIRType::Float32:
-+    case MIRType::Double:
-+      if (floatRegIndex_ == NumFloatArgRegs) {
-+        current_ = ABIArg(stackOffset_);
-+        stackOffset_ += sizeof(double);
-+        break;
-+      }
-+      current_ = ABIArg(FloatRegister(FloatRegisters::Encoding(floatRegIndex_),
-+                                      type == MIRType::Double
-+                                          ? FloatRegisters::Double
-+                                          : FloatRegisters::Single));
-+      floatRegIndex_++;
-+      break;
-+
-+    case MIRType::Simd128:
-+    default:
-+      MOZ_CRASH("Unexpected argument type");
-+  }
-+  return current_;
-+}
-diff --git a/js/src/jit/riscv64/Assembler-riscv64.h b/js/src/jit/riscv64/Assembler-riscv64.h
-new file mode 100644
-index 0000000000..a58e6c4aff
---- /dev/null
-+++ b/js/src/jit/riscv64/Assembler-riscv64.h
-@@ -0,0 +1,303 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_Assembler_riscv64_h
-+#define jit_riscv64_Assembler_riscv64_h
-+
-+#include "mozilla/Sprintf.h"
-+#include <iterator>
-+
-+#include "jit/CompactBuffer.h"
-+#include "jit/JitCode.h"
-+#include "jit/JitSpewer.h"
-+#include "jit/riscv64/Architecture-riscv64.h"
-+#include "jit/shared/Assembler-shared.h"
-+#include "jit/shared/Disassembler-shared.h"
-+#include "jit/shared/IonAssemblerBuffer.h"
-+#include "wasm/WasmTypeDecls.h"
-+
-+namespace js {
-+namespace jit {
-+
-+class MacroAssembler;
-+
-+static constexpr Register t0{Registers::t0};
-+static constexpr Register t1{Registers::t1};
-+static constexpr Register t2{Registers::t2};
-+static constexpr Register t3{Registers::t3};
-+static constexpr Register t4{Registers::t4};
-+static constexpr Register t5{Registers::t5};
-+static constexpr Register t6{Registers::t6};
-+static constexpr Register s0{Registers::s0};
-+static constexpr Register s4{Registers::s4};
-+
-+static constexpr Register StackPointer{Registers::sp};
-+static constexpr Register FramePointer{Registers::fp};
-+static constexpr Register ReturnReg{Registers::a0};
-+static constexpr FloatRegister InvalidFloatReg;
-+static constexpr FloatRegister ReturnFloat32Reg{FloatRegisters::fa0,
-+                                                FloatRegisters::Single};
-+static constexpr FloatRegister ReturnDoubleReg{FloatRegisters::fa0,
-+                                               FloatRegisters::Double};
-+static constexpr FloatRegister ReturnSimd128Reg = InvalidFloatReg;
-+static constexpr FloatRegister ScratchSimd128Reg = InvalidFloatReg;
-+static constexpr FloatRegister ScratchFloat32Reg_ = InvalidFloatReg;
-+static constexpr FloatRegister ScratchDoubleReg_ = InvalidFloatReg;
-+
-+static constexpr Register ScratchRegister = t6;
-+
-+// Helper class for ScratchRegister usage. Asserts that only one piece
-+// of code thinks it has exclusive ownership of the scratch register.
-+struct ScratchRegisterScope : public AutoRegisterScope {
-+  explicit ScratchRegisterScope(MacroAssembler& masm)
-+      : AutoRegisterScope(masm, ScratchRegister) {}
-+};
-+
-+struct SecondScratchRegisterScope : public AutoRegisterScope {
-+  explicit SecondScratchRegisterScope(MacroAssembler& masm);
-+};
-+
-+struct ScratchFloat32Scope : AutoFloatRegisterScope {
-+  explicit ScratchFloat32Scope(MacroAssembler& masm)
-+      : AutoFloatRegisterScope(masm, ScratchFloat32Reg_) {}
-+};
-+
-+struct ScratchDoubleScope : AutoFloatRegisterScope {
-+  explicit ScratchDoubleScope(MacroAssembler& masm)
-+      : AutoFloatRegisterScope(masm, ScratchDoubleReg_) {}
-+};
-+
-+static constexpr Register OsrFrameReg{Registers::invalid_reg};
-+static constexpr Register PreBarrierReg{Registers::invalid_reg};
-+static constexpr Register InterpreterPCReg{Registers::invalid_reg};
-+static constexpr Register CallTempReg0 = t0;
-+static constexpr Register CallTempReg1 = t1;
-+static constexpr Register CallTempReg2 = t2;
-+static constexpr Register CallTempReg3 = t3;
-+static constexpr Register CallTempReg4 = t4;
-+static constexpr Register CallTempReg5 = t5;
-+static constexpr Register InvalidReg{Registers::invalid_reg};
-+static constexpr Register CallTempNonArgRegs[] = {t0, t1, t2, t3, t4, t5, t6};
-+static const uint32_t NumCallTempNonArgRegs = std::size(CallTempNonArgRegs);
-+
-+static constexpr Register IntArgReg0{Registers::a0};
-+static constexpr Register IntArgReg1{Registers::a1};
-+static constexpr Register IntArgReg2{Registers::a2};
-+static constexpr Register IntArgReg3{Registers::a3};
-+static constexpr Register IntArgReg4{Registers::a4};
-+static constexpr Register IntArgReg5{Registers::a5};
-+static constexpr Register IntArgReg6{Registers::a6};
-+static constexpr Register IntArgReg7{Registers::a7};
-+static constexpr Register HeapReg{Registers::invalid_reg};
-+
-+// Registerd used in RegExpTester instruction (do not use ReturnReg).
-+static constexpr Register RegExpTesterRegExpReg = CallTempReg0;
-+static constexpr Register RegExpTesterStringReg = CallTempReg1;
-+static constexpr Register RegExpTesterLastIndexReg = CallTempReg2;
-+
-+// Registerd used in RegExpMatcher instruction (do not use JSReturnOperand).
-+static constexpr Register RegExpMatcherRegExpReg = CallTempReg0;
-+static constexpr Register RegExpMatcherStringReg = CallTempReg1;
-+static constexpr Register RegExpMatcherLastIndexReg = CallTempReg2;
-+
-+static constexpr Register JSReturnReg_Type{Registers::a3};
-+static constexpr Register JSReturnReg_Data{Registers::a2};
-+static constexpr Register JSReturnReg{Registers::a2};
-+
-+static constexpr Register64 ReturnReg64(ReturnReg);
-+
-+static constexpr Register ABINonArgReg0{Registers::s0};
-+static constexpr Register ABINonArgReg1{Registers::s1};
-+static constexpr Register ABINonArgReg2{Registers::s2};
-+static constexpr Register ABINonArgReg3{Registers::s3};
-+static constexpr Register ABINonArgReturnReg0{Registers::s0};
-+static constexpr Register ABINonArgReturnReg1{Registers::s1};
-+static constexpr Register ABINonVolatileReg{Registers::fp};
-+static constexpr Register ABINonArgReturnVolatileReg{Registers::ra};
-+
-+static constexpr FloatRegister ABINonArgDoubleReg = InvalidFloatReg;
-+
-+// Instance pointer argument register for WebAssembly functions. This must not
-+// alias any other register used for passing function arguments or return
-+// values. Preserved by WebAssembly functions.
-+static constexpr Register InstanceReg = s4;
-+
-+static constexpr Register WasmTableCallScratchReg0{Registers::invalid_reg};
-+static constexpr Register WasmTableCallScratchReg1{Registers::invalid_reg};
-+static constexpr Register WasmTableCallSigReg{Registers::invalid_reg};
-+static constexpr Register WasmTableCallIndexReg{Registers::invalid_reg};
-+static constexpr Register WasmTlsReg{Registers::invalid_reg};
-+static constexpr Register WasmJitEntryReturnScratch{Registers::invalid_reg};
-+
-+static constexpr uint32_t ABIStackAlignment = 16;
-+static constexpr uint32_t CodeAlignment = 16;
-+static constexpr uint32_t JitStackAlignment = 8;
-+static constexpr uint32_t JitStackValueAlignment =
-+    JitStackAlignment / sizeof(Value);
-+
-+static const Scale ScalePointer = TimesOne;
-+
-+class Instruction;
-+typedef js::jit::AssemblerBuffer<1024, Instruction> RISCVBuffer;
-+
-+class Assembler : public AssemblerShared {
-+ public:
-+  enum RISCVCondition : uint32_t {
-+    EQ = 0b000,
-+    NE = 0b001,
-+    LT = 0b100,
-+    GE = 0b101,
-+    LTU = 0b110,
-+    GEU = 0b111,
-+  };
-+
-+  enum Condition {
-+    Equal,
-+    NotEqual,
-+    Above,
-+    AboveOrEqual,
-+    Below,
-+    BelowOrEqual,
-+    GreaterThan,
-+    GreaterThanOrEqual,
-+    LessThan,
-+    LessThanOrEqual,
-+    Overflow,
-+    CarrySet,
-+    CarryClear,
-+    Signed,
-+    NotSigned,
-+    Zero,
-+    NonZero,
-+    Always,
-+  };
-+
-+  enum DoubleCondition {
-+    DoubleOrdered,
-+    DoubleEqual,
-+    DoubleNotEqual,
-+    DoubleGreaterThan,
-+    DoubleGreaterThanOrEqual,
-+    DoubleLessThan,
-+    DoubleLessThanOrEqual,
-+    DoubleUnordered,
-+    DoubleEqualOrUnordered,
-+    DoubleNotEqualOrUnordered,
-+    DoubleGreaterThanOrUnordered,
-+    DoubleGreaterThanOrEqualOrUnordered,
-+    DoubleLessThanOrUnordered,
-+    DoubleLessThanOrEqualOrUnordered
-+  };
-+
-+  RISCVBuffer m_buffer;
-+
-+  BufferOffset nextOffset() { return m_buffer.nextOffset(); }
-+
-+  static Condition InvertCondition(Condition) { MOZ_CRASH(); }
-+
-+  static DoubleCondition InvertCondition(DoubleCondition) { MOZ_CRASH(); }
-+
-+  static void TraceJumpRelocations(JSTracer* trc, JitCode* code,
-+                                   CompactBufferReader& reader);
-+  static void TraceDataRelocations(JSTracer* trc, JitCode* code,
-+                                   CompactBufferReader& reader);
-+
-+  template <typename T, typename S>
-+  static void PatchDataWithValueCheck(CodeLocationLabel, T, S) {
-+    MOZ_CRASH();
-+  }
-+  static void PatchWrite_Imm32(CodeLocationLabel, Imm32) { MOZ_CRASH(); }
-+
-+  static void PatchWrite_NearCall(CodeLocationLabel, CodeLocationLabel) {
-+    MOZ_CRASH();
-+  }
-+  static uint32_t PatchWrite_NearCallSize() { MOZ_CRASH(); }
-+
-+  static void ToggleToJmp(CodeLocationLabel) { MOZ_CRASH(); }
-+  static void ToggleToCmp(CodeLocationLabel) { MOZ_CRASH(); }
-+  static void ToggleCall(CodeLocationLabel, bool) { MOZ_CRASH(); }
-+
-+  static void Bind(uint8_t* rawCode, const CodeLabel& label) { MOZ_CRASH(); }
-+
-+  static uintptr_t GetPointer(uint8_t*) { MOZ_CRASH(); }
-+
-+  static bool HasRoundInstruction(RoundingMode) { return false; }
-+
-+  void verifyHeapAccessDisassembly(uint32_t begin, uint32_t end,
-+                                   const Disassembler::HeapAccess& heapAccess) {
-+    MOZ_CRASH();
-+  }
-+
-+  void setUnlimitedBuffer() { MOZ_CRASH(); }
-+
-+  MOZ_ALWAYS_INLINE BufferOffset writeInst(uint32_t x) {
-+    MOZ_ASSERT(hasCreator());
-+    return m_buffer.putInt(x);
-+  }
-+};
-+
-+class Instruction {
-+ protected:
-+  uint32_t data;
-+
-+  // Standard constructor
-+  Instruction(uint32_t data_) : data(data_) {}
-+
-+ public:
-+  uint32_t encode() const { return data; }
-+
-+  void setData(uint32_t data) { this->data = data; }
-+  Instruction* next();
-+  const uint32_t* raw() const { return &data; }
-+  uint32_t size() const { return sizeof(data); }
-+};
-+
-+class Operand {
-+ public:
-+  enum Kind { REG };
-+
-+ private:
-+  Kind kind_ : 4;
-+  uint32_t reg_ : 5;
-+  int32_t offset_;
-+
-+ public:
-+  explicit Operand(const Register reg)
-+      : kind_(REG), reg_(reg.code()), offset_(0) {}
-+  explicit Operand(const FloatRegister) { MOZ_CRASH(); }
-+  explicit Operand(const Address& adress) { MOZ_CRASH(); }
-+  explicit Operand(Register reg, Imm32 offset)
-+      : kind_(REG), reg_(reg.code()), offset_(offset.value) {}
-+  explicit Operand(Register reg, int32_t offset)
-+      : kind_(REG), reg_(reg.code()), offset_(offset) {}
-+
-+  Kind kind() const { return kind_; }
-+};
-+
-+static const uint32_t NumIntArgRegs = 8;
-+static const uint32_t NumFloatArgRegs = 8;
-+
-+class ABIArgGenerator {
-+ public:
-+  ABIArgGenerator()
-+      : intRegIndex_(0), floatRegIndex_(0), stackOffset_(0), current_() {}
-+
-+  ABIArg next(MIRType);
-+  ABIArg& current() { return current_; }
-+  uint32_t stackBytesConsumedSoFar() const { return stackOffset_; }
-+  void increaseStackOffset(uint32_t bytes) { stackOffset_ += bytes; }
-+
-+ private:
-+  unsigned intRegIndex_;
-+  unsigned floatRegIndex_;
-+  uint32_t stackOffset_;
-+  ABIArg current_;
-+};
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_Assembler_riscv64_h */
-diff --git a/js/src/jit/riscv64/CodeGenerator-riscv64.h b/js/src/jit/riscv64/CodeGenerator-riscv64.h
-new file mode 100644
-index 0000000000..db30b32283
---- /dev/null
-+++ b/js/src/jit/riscv64/CodeGenerator-riscv64.h
-@@ -0,0 +1,78 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_CodeGenerator_riscv64_h
-+#define jit_riscv64_CodeGenerator_riscv64_h
-+
-+#include "jit/shared/CodeGenerator-shared.h"
-+
-+namespace js {
-+namespace jit {
-+
-+class CodeGeneratorRiscv64 : public CodeGeneratorShared {
-+ protected:
-+  CodeGeneratorRiscv64(MIRGenerator* gen, LIRGraph* graph, MacroAssembler* masm)
-+      : CodeGeneratorShared(gen, graph, masm) {
-+    MOZ_CRASH();
-+  }
-+
-+  MoveOperand toMoveOperand(LAllocation) const { MOZ_CRASH(); }
-+  template <typename T1, typename T2>
-+  void bailoutCmp32(Assembler::Condition, T1, T2, LSnapshot*) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T1, typename T2>
-+  void bailoutTest32(Assembler::Condition, T1, T2, LSnapshot*) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T1, typename T2>
-+  void bailoutCmpPtr(Assembler::Condition, T1, T2, LSnapshot*) {
-+    MOZ_CRASH();
-+  }
-+  void bailoutTestPtr(Assembler::Condition, Register, Register, LSnapshot*) {
-+    MOZ_CRASH();
-+  }
-+  void bailoutIfFalseBool(Register, LSnapshot*) { MOZ_CRASH(); }
-+  void bailoutFrom(Label*, LSnapshot*) { MOZ_CRASH(); }
-+  void bailout(LSnapshot*) { MOZ_CRASH(); }
-+  void bailoutIf(Assembler::Condition, LSnapshot*) { MOZ_CRASH(); }
-+  bool generateOutOfLineCode() { MOZ_CRASH(); }
-+  void testNullEmitBranch(Assembler::Condition, ValueOperand, MBasicBlock*,
-+                          MBasicBlock*) {
-+    MOZ_CRASH();
-+  }
-+  void testUndefinedEmitBranch(Assembler::Condition, ValueOperand, MBasicBlock*,
-+                               MBasicBlock*) {
-+    MOZ_CRASH();
-+  }
-+  void testObjectEmitBranch(Assembler::Condition, ValueOperand, MBasicBlock*,
-+                            MBasicBlock*) {
-+    MOZ_CRASH();
-+  }
-+  void testZeroEmitBranch(Assembler::Condition, Register, MBasicBlock*,
-+                          MBasicBlock*) {
-+    MOZ_CRASH();
-+  }
-+  void emitTableSwitchDispatch(MTableSwitch*, Register, Register) {
-+    MOZ_CRASH();
-+  }
-+  void emitBigIntDiv(LBigIntDiv*, Register, Register, Register, Label*) {
-+    MOZ_CRASH();
-+  }
-+  void emitBigIntMod(LBigIntMod*, Register, Register, Register, Label*) {
-+    MOZ_CRASH();
-+  }
-+  ValueOperand ToValue(LInstruction*, size_t) { MOZ_CRASH(); }
-+  ValueOperand ToTempValue(LInstruction*, size_t) { MOZ_CRASH(); }
-+  void generateInvalidateEpilogue() { MOZ_CRASH(); }
-+};
-+
-+typedef CodeGeneratorRiscv64 CodeGeneratorSpecific;
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_CodeGenerator_riscv64_h */
-diff --git a/js/src/jit/riscv64/LIR-riscv64.h b/js/src/jit/riscv64/LIR-riscv64.h
-new file mode 100644
-index 0000000000..59d42c6c75
---- /dev/null
-+++ b/js/src/jit/riscv64/LIR-riscv64.h
-@@ -0,0 +1,111 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_LIR_riscv64_h
-+#define jit_riscv64_LIR_riscv64_h
-+
-+namespace js {
-+namespace jit {
-+
-+class LUnboxFloatingPoint : public LInstruction {
-+ public:
-+  LIR_HEADER(UnboxFloatingPoint)
-+  static const size_t Input = 0;
-+
-+  MUnbox* mir() const { MOZ_CRASH(); }
-+
-+  const LDefinition* output() const { MOZ_CRASH(); }
-+  MIRType type() const { MOZ_CRASH(); }
-+};
-+
-+class LTableSwitch : public LInstruction {
-+ public:
-+  LIR_HEADER(TableSwitch)
-+  MTableSwitch* mir() { MOZ_CRASH(); }
-+
-+  const LAllocation* index() { MOZ_CRASH(); }
-+  const LDefinition* tempInt() { MOZ_CRASH(); }
-+  const LDefinition* tempPointer() { MOZ_CRASH(); }
-+};
-+
-+class LTableSwitchV : public LInstruction {
-+ public:
-+  LIR_HEADER(TableSwitchV)
-+  MTableSwitch* mir() { MOZ_CRASH(); }
-+
-+  const LDefinition* tempInt() { MOZ_CRASH(); }
-+  const LDefinition* tempFloat() { MOZ_CRASH(); }
-+  const LDefinition* tempPointer() { MOZ_CRASH(); }
-+
-+  static const size_t InputValue = 0;
-+};
-+
-+class LWasmUint32ToFloat32 : public LInstructionHelper<1, 1, 0> {
-+ public:
-+  explicit LWasmUint32ToFloat32(const LAllocation&)
-+      : LInstructionHelper(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+};
-+
-+class LUnbox : public LInstructionHelper<1, 2, 0> {
-+ public:
-+  MUnbox* mir() const { MOZ_CRASH(); }
-+  const LAllocation* payload() { MOZ_CRASH(); }
-+  const LAllocation* type() { MOZ_CRASH(); }
-+  const char* extraName() const { MOZ_CRASH(); }
-+};
-+class LDivI : public LBinaryMath<1> {
-+ public:
-+  LDivI(const LAllocation&, const LAllocation&, const LDefinition&)
-+      : LBinaryMath(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+  MDiv* mir() const { MOZ_CRASH(); }
-+};
-+class LDivPowTwoI : public LInstructionHelper<1, 1, 0> {
-+ public:
-+  LDivPowTwoI(const LAllocation&, int32_t)
-+      : LInstructionHelper(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+  const LAllocation* numerator() { MOZ_CRASH(); }
-+  int32_t shift() { MOZ_CRASH(); }
-+  MDiv* mir() const { MOZ_CRASH(); }
-+};
-+class LModI : public LBinaryMath<1> {
-+ public:
-+  LModI(const LAllocation&, const LAllocation&, const LDefinition&)
-+      : LBinaryMath(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+
-+  const LDefinition* callTemp() { MOZ_CRASH(); }
-+  MMod* mir() const { MOZ_CRASH(); }
-+};
-+class LWasmUint32ToDouble : public LInstructionHelper<1, 1, 0> {
-+ public:
-+  explicit LWasmUint32ToDouble(const LAllocation&)
-+      : LInstructionHelper(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+};
-+class LModPowTwoI : public LInstructionHelper<1, 1, 0> {
-+ public:
-+  int32_t shift() { MOZ_CRASH(); }
-+  LModPowTwoI(const LAllocation& lhs, int32_t shift)
-+      : LInstructionHelper(Opcode::Invalid) {
-+    MOZ_CRASH();
-+  }
-+  MMod* mir() const { MOZ_CRASH(); }
-+};
-+
-+class LMulI : public LInstruction {};
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_LIR_riscv64_h */
-diff --git a/js/src/jit/riscv64/Lowering-riscv64.h b/js/src/jit/riscv64/Lowering-riscv64.h
-new file mode 100644
-index 0000000000..a68e52b872
---- /dev/null
-+++ b/js/src/jit/riscv64/Lowering-riscv64.h
-@@ -0,0 +1,130 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_Lowering_riscv64_h
-+#define jit_riscv64_Lowering_riscv64_h
-+
-+#include "jit/shared/Lowering-shared.h"
-+
-+namespace js {
-+namespace jit {
-+
-+class LIRGeneratorRiscv64 : public LIRGeneratorShared {
-+ protected:
-+  LIRGeneratorRiscv64(MIRGenerator* gen, MIRGraph& graph, LIRGraph& lirGraph)
-+      : LIRGeneratorShared(gen, graph, lirGraph) {
-+    MOZ_CRASH();
-+  }
-+
-+  LBoxAllocation useBoxFixed(MDefinition*, Register, Register,
-+                             bool useAtStart = false) {
-+    MOZ_CRASH();
-+  }
-+
-+  LAllocation useByteOpRegister(MDefinition*) { MOZ_CRASH(); }
-+  LAllocation useByteOpRegisterAtStart(MDefinition*) { MOZ_CRASH(); }
-+  LAllocation useByteOpRegisterOrNonDoubleConstant(MDefinition*) {
-+    MOZ_CRASH();
-+  }
-+  LDefinition tempByteOpRegister() { MOZ_CRASH(); }
-+  LDefinition tempToUnbox() { MOZ_CRASH(); }
-+  bool needTempForPostBarrier() { MOZ_CRASH(); }
-+  void lowerUntypedPhiInput(MPhi*, uint32_t, LBlock*, size_t) { MOZ_CRASH(); }
-+  void lowerInt64PhiInput(MPhi*, uint32_t, LBlock*, size_t) { MOZ_CRASH(); }
-+  void defineInt64Phi(MPhi*, size_t) { MOZ_CRASH(); }
-+  void lowerForShift(LInstructionHelper<1, 2, 0>*, MDefinition*, MDefinition*,
-+                     MDefinition*) {
-+    MOZ_CRASH();
-+  }
-+  void lowerUrshD(MUrsh*) { MOZ_CRASH(); }
-+  void lowerPowOfTwoI(MPow*) { MOZ_CRASH(); }
-+  template <typename T>
-+  void lowerForALU(T, MDefinition*, MDefinition*, MDefinition* v = nullptr) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void lowerForFPU(T, MDefinition*, MDefinition*, MDefinition* v = nullptr) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void lowerForALUInt64(T, MDefinition*, MDefinition*,
-+                        MDefinition* v = nullptr) {
-+    MOZ_CRASH();
-+  }
-+  void lowerForMulInt64(LMulI64*, MMul*, MDefinition*,
-+                        MDefinition* v = nullptr) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void lowerForShiftInt64(T, MDefinition*, MDefinition*,
-+                          MDefinition* v = nullptr) {
-+    MOZ_CRASH();
-+  }
-+  void lowerForBitAndAndBranch(LBitAndAndBranch*, MInstruction*, MDefinition*,
-+                               MDefinition*) {
-+    MOZ_CRASH();
-+  }
-+  void lowerForCompareI64AndBranch(MTest*, MCompare*, JSOp, MDefinition*,
-+                                   MDefinition*, MBasicBlock*, MBasicBlock*) {
-+    MOZ_CRASH();
-+  }
-+
-+  void lowerConstantDouble(double, MInstruction*) { MOZ_CRASH(); }
-+  void lowerConstantFloat32(float, MInstruction*) { MOZ_CRASH(); }
-+  void lowerTruncateDToInt32(MTruncateToInt32*) { MOZ_CRASH(); }
-+  void lowerTruncateFToInt32(MTruncateToInt32*) { MOZ_CRASH(); }
-+  void lowerBuiltinInt64ToFloatingPoint(MBuiltinInt64ToFloatingPoint* ins) {
-+    MOZ_CRASH();
-+  }
-+  void lowerWasmBuiltinTruncateToInt64(MWasmBuiltinTruncateToInt64* ins) {
-+    MOZ_CRASH();
-+  }
-+  void lowerWasmBuiltinTruncateToInt32(MWasmBuiltinTruncateToInt32* ins) {
-+    MOZ_CRASH();
-+  }
-+  void lowerDivI(MDiv*) { MOZ_CRASH(); }
-+  void lowerModI(MMod*) { MOZ_CRASH(); }
-+  void lowerDivI64(MDiv*) { MOZ_CRASH(); }
-+  void lowerWasmBuiltinDivI64(MWasmBuiltinDivI64* div) { MOZ_CRASH(); }
-+  void lowerModI64(MMod*) { MOZ_CRASH(); }
-+  void lowerWasmBuiltinModI64(MWasmBuiltinModI64* mod) { MOZ_CRASH(); }
-+  void lowerNegI(MInstruction*, MDefinition*) { MOZ_CRASH(); }
-+  void lowerNegI64(MInstruction*, MDefinition*) { MOZ_CRASH(); }
-+  void lowerMulI(MMul*, MDefinition*, MDefinition*) { MOZ_CRASH(); }
-+  void lowerUDiv(MDiv*) { MOZ_CRASH(); }
-+  void lowerUMod(MMod*) { MOZ_CRASH(); }
-+  void lowerWasmSelectI(MWasmSelect* select) { MOZ_CRASH(); }
-+  void lowerWasmSelectI64(MWasmSelect* select) { MOZ_CRASH(); }
-+  void lowerWasmCompareAndSelect(MWasmSelect* ins, MDefinition* lhs,
-+                                 MDefinition* rhs, MCompare::CompareType compTy,
-+                                 JSOp jsop) {
-+    MOZ_CRASH();
-+  }
-+  bool canSpecializeWasmCompareAndSelect(MCompare::CompareType compTy,
-+                                         MIRType insTy) {
-+    MOZ_CRASH();
-+  }
-+
-+  void lowerBigIntLsh(MBigIntLsh*) { MOZ_CRASH(); }
-+  void lowerBigIntRsh(MBigIntRsh*) { MOZ_CRASH(); }
-+  void lowerBigIntDiv(MBigIntDiv*) { MOZ_CRASH(); }
-+  void lowerBigIntMod(MBigIntMod*) { MOZ_CRASH(); }
-+
-+  void lowerAtomicLoad64(MLoadUnboxedScalar*) { MOZ_CRASH(); }
-+  void lowerAtomicStore64(MStoreUnboxedScalar*) { MOZ_CRASH(); }
-+
-+  LTableSwitch* newLTableSwitch(LAllocation, LDefinition, MTableSwitch*) {
-+    MOZ_CRASH();
-+  }
-+  LTableSwitchV* newLTableSwitchV(MTableSwitch*) { MOZ_CRASH(); }
-+};
-+
-+typedef LIRGeneratorRiscv64 LIRGeneratorSpecific;
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_Lowering_riscv64_h */
-diff --git a/js/src/jit/riscv64/MacroAssembler-riscv64-inl.h b/js/src/jit/riscv64/MacroAssembler-riscv64-inl.h
-new file mode 100644
-index 0000000000..3dd6273d0f
---- /dev/null
-+++ b/js/src/jit/riscv64/MacroAssembler-riscv64-inl.h
-@@ -0,0 +1,18 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_MacroAssembler_riscv64_inl_h
-+#define jit_riscv64_MacroAssembler_riscv64_inl_h
-+
-+#include "jit/riscv64/MacroAssembler-riscv64.h"
-+
-+namespace js {
-+namespace jit {
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif
-diff --git a/js/src/jit/riscv64/MacroAssembler-riscv64.h b/js/src/jit/riscv64/MacroAssembler-riscv64.h
-new file mode 100644
-index 0000000000..30ca17d359
---- /dev/null
-+++ b/js/src/jit/riscv64/MacroAssembler-riscv64.h
-@@ -0,0 +1,458 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_MacroAssembler_riscv64_h
-+#define jit_riscv64_MacroAssembler_riscv64_h
-+
-+#include "jit/riscv64/Assembler-riscv64.h"
-+#include "jit/MoveResolver.h"
-+#include "wasm/WasmBuiltins.h"
-+
-+namespace js {
-+namespace jit {
-+
-+static constexpr ValueOperand JSReturnOperand{JSReturnReg};
-+
-+class ScratchTagScope : public SecondScratchRegisterScope {
-+ public:
-+  ScratchTagScope(MacroAssembler& masm, const js::jit::ValueOperand&)
-+      : SecondScratchRegisterScope(masm) {}
-+};
-+
-+class ScratchTagScopeRelease {
-+  ScratchTagScope* ts_;
-+
-+ public:
-+  explicit ScratchTagScopeRelease(ScratchTagScope* ts) : ts_(ts) {
-+    ts_->release();
-+  }
-+
-+  ~ScratchTagScopeRelease() { ts_->reacquire(); }
-+};
-+
-+class MacroAssemblerRiscv64 : public Assembler {
-+ protected:
-+  // Perform a downcast. Should be removed by Bug 996602.
-+  MacroAssembler& asMasm();
-+  const MacroAssembler& asMasm() const;
-+
-+ public:
-+  MacroAssemblerRiscv64() { MOZ_CRASH(); }
-+
-+  MoveResolver moveResolver_;
-+
-+  size_t size() const { MOZ_CRASH(); }
-+  size_t bytesNeeded() const { MOZ_CRASH(); }
-+  size_t jumpRelocationTableBytes() const { MOZ_CRASH(); }
-+  size_t dataRelocationTableBytes() const { MOZ_CRASH(); }
-+  size_t preBarrierTableBytes() const { MOZ_CRASH(); }
-+
-+  size_t numCodeLabels() const { MOZ_CRASH(); }
-+  CodeLabel codeLabel(size_t) { MOZ_CRASH(); }
-+
-+  bool reserve(size_t size) { MOZ_CRASH(); }
-+  bool appendRawCode(const uint8_t* code, size_t numBytes) { MOZ_CRASH(); }
-+  bool swapBuffer(wasm::Bytes& bytes) { MOZ_CRASH(); }
-+
-+  void assertNoGCThings() const { MOZ_CRASH(); }
-+
-+  static bool SupportsFloatingPoint() { return false; }
-+  static bool SupportsUnalignedAccesses() { return false; }
-+  static bool SupportsFastUnalignedFPAccesses() { return false; }
-+
-+  void executableCopy(void*, bool = true) { MOZ_CRASH(); }
-+  void copyJumpRelocationTable(uint8_t*) { MOZ_CRASH(); }
-+  void copyDataRelocationTable(uint8_t*) { MOZ_CRASH(); }
-+  void copyPreBarrierTable(uint8_t*) { MOZ_CRASH(); }
-+  void processCodeLabels(uint8_t*) { MOZ_CRASH(); }
-+
-+  void flushBuffer() {}
-+
-+  template <typename T>
-+  void bind(T) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void j(Condition, T) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void jump(T) {
-+    MOZ_CRASH();
-+  }
-+  void writeCodePointer(CodeLabel* label) {
-+    MOZ_CRASH();
-+  }
-+  void haltingAlign(size_t) { MOZ_CRASH(); }
-+  void nopAlign(size_t) { MOZ_CRASH(); }
-+  void checkStackAlignment() { MOZ_CRASH(); }
-+  uint32_t currentOffset() { return nextOffset().getOffset(); }
-+
-+  void nop() { MOZ_CRASH(); }
-+  void breakpoint() { MOZ_CRASH(); }
-+  void abiret() { MOZ_CRASH(); }
-+  void ret() { MOZ_CRASH(); }
-+
-+  CodeOffset toggledJump(Label*) { MOZ_CRASH(); }
-+  CodeOffset toggledCall(JitCode*, bool) { MOZ_CRASH(); }
-+  static size_t ToggledCallSize(uint8_t*) { MOZ_CRASH(); }
-+
-+  void finish() { MOZ_CRASH(); }
-+
-+  template <typename T, typename S>
-+  void moveValue(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S, typename U>
-+  void moveValue(T, S, U) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void storeValue(const T&, const S&) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S, typename U>
-+  void storeValue(T, S, U) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void storePrivateValue(const T&, const S&) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void loadValue(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void loadUnalignedValue(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void pushValue(const T&) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void pushValue(T, S) {
-+    MOZ_CRASH();
-+  }
-+  void popValue(ValueOperand) { MOZ_CRASH(); }
-+  void tagValue(JSValueType, Register, ValueOperand) { MOZ_CRASH(); }
-+  void retn(Imm32 n) { MOZ_CRASH(); }
-+  template <typename T>
-+  void push(const T&) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void Push(T) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void pop(T) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void Pop(T) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  CodeOffset pushWithPatch(T) {
-+    MOZ_CRASH();
-+  }
-+
-+  void testNullSet(Condition, ValueOperand, Register) { MOZ_CRASH(); }
-+  void testObjectSet(Condition, ValueOperand, Register) { MOZ_CRASH(); }
-+  void testUndefinedSet(Condition, ValueOperand, Register) { MOZ_CRASH(); }
-+
-+  template <typename T, typename S>
-+  void cmpPtrSet(Condition, T, S, Register) {
-+    MOZ_CRASH();
-+  }
-+  void cmp8Set(Condition, Address, Imm32, Register) { MOZ_CRASH(); }
-+  void cmp16Set(Condition, Address, Imm32, Register) { MOZ_CRASH(); }
-+  template <typename T, typename S>
-+  void cmp32Set(Condition, T, S, Register) {
-+    MOZ_CRASH();
-+  }
-+  void cmp64Set(Condition, Address, Imm64, Register) { MOZ_CRASH(); }
-+
-+  template <typename T>
-+  void mov(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void movePtr(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void move32(const T&, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void movq(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void moveFloat32(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void moveDouble(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void move64(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  CodeOffset movWithPatch(T, Register) {
-+    MOZ_CRASH();
-+  }
-+
-+  template <typename T>
-+  void loadPtr(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load32(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load32Unaligned(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void loadFloat32(T, FloatRegister) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void loadDouble(T, FloatRegister) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void loadPrivate(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load8SignExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load8ZeroExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load16SignExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load16UnalignedSignExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load16ZeroExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load16UnalignedZeroExtend(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load64(T, Register64) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void load64Unaligned(T, Register64) {
-+    MOZ_CRASH();
-+  }
-+
-+  template <typename T, typename S>
-+  void storePtr(const T&, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store32(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store32_NoSecondScratch(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store32Unaligned(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void storeFloat32(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void storeDouble(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store8(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store16(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store16Unaligned(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store64(T, S) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T, typename S>
-+  void store64Unaligned(T, S) {
-+    MOZ_CRASH();
-+  }
-+
-+  template <typename T>
-+  void computeEffectiveAddress(T, Register) {
-+    MOZ_CRASH();
-+  }
-+
-+  void splitTagForTest(ValueOperand, ScratchTagScope&) { MOZ_CRASH(); }
-+
-+  void boxDouble(FloatRegister, ValueOperand, FloatRegister) { MOZ_CRASH(); }
-+  void boxNonDouble(JSValueType, Register, ValueOperand) { MOZ_CRASH(); }
-+  template <typename T>
-+  void boxDouble(FloatRegister src, const T& dest) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxInt32(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxBoolean(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxString(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxSymbol(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxBigInt(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxObject(T, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxDouble(T, FloatRegister) {
-+    MOZ_CRASH();
-+  }
-+  void unboxValue(const ValueOperand&, AnyRegister, JSValueType) {
-+    MOZ_CRASH();
-+  }
-+  void unboxNonDouble(const ValueOperand&, Register, JSValueType) {
-+    MOZ_CRASH();
-+  }
-+  void unboxNonDouble(const Address&, Register, JSValueType) { MOZ_CRASH(); }
-+  template <typename T>
-+  void unboxGCThingForGCBarrier(const T&, Register) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void unboxObjectOrNull(const T& src, Register dest) {
-+    MOZ_CRASH();
-+  }
-+  void notBoolean(ValueOperand) { MOZ_CRASH(); }
-+  [[nodiscard]] Register extractObject(Address, Register) { MOZ_CRASH(); }
-+  [[nodiscard]] Register extractObject(ValueOperand, Register) { MOZ_CRASH(); }
-+  [[nodiscard]] Register extractSymbol(ValueOperand, Register) { MOZ_CRASH(); }
-+  [[nodiscard]] Register extractInt32(ValueOperand, Register) { MOZ_CRASH(); }
-+  [[nodiscard]] Register extractBoolean(ValueOperand, Register) { MOZ_CRASH(); }
-+  template <typename T>
-+  [[nodiscard]] Register extractTag(T, Register) {
-+    MOZ_CRASH();
-+  }
-+
-+  void convertFloat32ToInt32(FloatRegister, Register, Label*, bool v = true) {
-+    MOZ_CRASH();
-+  }
-+  void convertDoubleToInt32(FloatRegister, Register, Label*, bool v = true) {
-+    MOZ_CRASH();
-+  }
-+  void convertDoubleToPtr(FloatRegister, Register, Label*, bool v = true) {
-+    MOZ_CRASH();
-+  }
-+  void convertBoolToInt32(Register, Register) { MOZ_CRASH(); }
-+
-+  void convertDoubleToFloat32(FloatRegister, FloatRegister) { MOZ_CRASH(); }
-+  void convertInt32ToFloat32(Register, FloatRegister) { MOZ_CRASH(); }
-+
-+  template <typename T>
-+  void convertInt32ToDouble(T, FloatRegister) {
-+    MOZ_CRASH();
-+  }
-+  void convertFloat32ToDouble(FloatRegister, FloatRegister) { MOZ_CRASH(); }
-+
-+  void boolValueToDouble(ValueOperand, FloatRegister) { MOZ_CRASH(); }
-+  void boolValueToFloat32(ValueOperand, FloatRegister) { MOZ_CRASH(); }
-+  void int32ValueToDouble(ValueOperand, FloatRegister) { MOZ_CRASH(); }
-+  void int32ValueToFloat32(ValueOperand, FloatRegister) { MOZ_CRASH(); }
-+
-+  void loadConstantDouble(double, FloatRegister) { MOZ_CRASH(); }
-+  void loadConstantFloat32(float, FloatRegister) { MOZ_CRASH(); }
-+  Condition testInt32Truthy(bool, ValueOperand) { MOZ_CRASH(); }
-+  Condition testStringTruthy(bool, ValueOperand) { MOZ_CRASH(); }
-+  Condition testBigIntTruthy(bool, ValueOperand) { MOZ_CRASH(); }
-+
-+  template <typename T>
-+  void loadUnboxedValue(T, MIRType, AnyRegister) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void storeUnboxedValue(const ConstantOrRegister&, MIRType, T, MIRType) {
-+    MOZ_CRASH();
-+  }
-+  template <typename T>
-+  void storeUnboxedPayload(ValueOperand value, T, size_t, JSValueType) {
-+    MOZ_CRASH();
-+  }
-+
-+  void convertUInt32ToDouble(Register, FloatRegister) { MOZ_CRASH(); }
-+  void convertUInt32ToFloat32(Register, FloatRegister) { MOZ_CRASH(); }
-+  void incrementInt32Value(Address) { MOZ_CRASH(); }
-+  void ensureDouble(ValueOperand, FloatRegister, Label*) { MOZ_CRASH(); }
-+
-+  void buildFakeExitFrame(Register, uint32_t*) { MOZ_CRASH(); }
-+  bool buildOOLFakeExitFrame(void*) { MOZ_CRASH(); }
-+
-+  void setPrinter(Sprinter*) { MOZ_CRASH(); }
-+  Operand ToPayload(Operand base) { MOZ_CRASH(); }
-+  Address ToPayload(Address) { MOZ_CRASH(); }
-+
-+  Register getStackPointer() const { MOZ_CRASH(); }
-+
-+  void handleFailureWithHandlerTail(Label* profilerExitTail,
-+                                    Label* bailoutTail) { MOZ_CRASH(); }
-+
-+  // Instrumentation for entering and leaving the profiler.
-+  void profilerEnterFrame(Register, Register) { MOZ_CRASH(); }
-+  void profilerExitFrame() { MOZ_CRASH(); }
-+};
-+
-+typedef MacroAssemblerRiscv64 MacroAssemblerSpecific;
-+
-+static inline bool GetTempRegForIntArg(uint32_t, uint32_t, Register*) {
-+  MOZ_CRASH();
-+}
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_MacroAssembler_riscv64_h */
-diff --git a/js/src/jit/riscv64/MoveEmitter-riscv64.h b/js/src/jit/riscv64/MoveEmitter-riscv64.h
-new file mode 100644
-index 0000000000..24ca3aebb2
---- /dev/null
-+++ b/js/src/jit/riscv64/MoveEmitter-riscv64.h
-@@ -0,0 +1,32 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_MoveEmitter_riscv64_h
-+#define jit_riscv64_MoveEmitter_riscv64_h
-+
-+#include "mozilla/Assertions.h"
-+
-+namespace js {
-+namespace jit {
-+
-+class MacroAssemblerRiscv64;
-+class MoveResolver;
-+struct Register;
-+
-+class MoveEmitterRiscv64 {
-+ public:
-+  explicit MoveEmitterRiscv64(MacroAssemblerRiscv64&) { MOZ_CRASH(); }
-+  void emit(const MoveResolver&) { MOZ_CRASH(); }
-+  void finish() { MOZ_CRASH(); }
-+  void setScratchRegister(Register) { MOZ_CRASH(); }
-+};
-+
-+typedef MoveEmitterRiscv64 MoveEmitter;
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_MoveEmitter_riscv64_h */
-diff --git a/js/src/jit/riscv64/SharedICHelpers-riscv64-inl.h b/js/src/jit/riscv64/SharedICHelpers-riscv64-inl.h
-new file mode 100644
-index 0000000000..7c6f7b7c20
---- /dev/null
-+++ b/js/src/jit/riscv64/SharedICHelpers-riscv64-inl.h
-@@ -0,0 +1,34 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_SharedICHelpers_riscv64_inl_h
-+#define jit_riscv64_SharedICHelpers_riscv64_inl_h
-+
-+#include "jit/SharedICHelpers.h"
-+
-+namespace js {
-+namespace jit {
-+
-+inline void EmitBaselineTailCallVM(TrampolinePtr, MacroAssembler&, uint32_t) {
-+  MOZ_CRASH();
-+}
-+inline void EmitBaselineCreateStubFrameDescriptor(MacroAssembler&, Register,
-+                                                  uint32_t) {
-+  MOZ_CRASH();
-+}
-+inline void EmitBaselineCallVM(TrampolinePtr, MacroAssembler&) { MOZ_CRASH(); }
-+
-+static const uint32_t STUB_FRAME_SIZE = 0;
-+static const uint32_t STUB_FRAME_SAVED_STUB_OFFSET = 0;
-+
-+inline void EmitBaselineEnterStubFrame(MacroAssembler&, Register) {
-+  MOZ_CRASH();
-+}
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_SharedICHelpers_riscv64_inl_h */
-diff --git a/js/src/jit/riscv64/SharedICHelpers-riscv64.h b/js/src/jit/riscv64/SharedICHelpers-riscv64.h
-new file mode 100644
-index 0000000000..205b6615da
---- /dev/null
-+++ b/js/src/jit/riscv64/SharedICHelpers-riscv64.h
-@@ -0,0 +1,35 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_SharedICHelpers_riscv64_h
-+#define jit_riscv64_SharedICHelpers_riscv64_h
-+
-+#include "jit/MacroAssembler.h"
-+#include "jit/SharedICRegisters.h"
-+
-+namespace js {
-+namespace jit {
-+
-+static const size_t ICStackValueOffset = 0;
-+
-+inline void EmitRestoreTailCallReg(MacroAssembler&) { MOZ_CRASH(); }
-+inline void EmitRepushTailCallReg(MacroAssembler&) { MOZ_CRASH(); }
-+inline void EmitCallIC(MacroAssembler&, CodeOffset*) { MOZ_CRASH(); }
-+inline void EmitReturnFromIC(MacroAssembler&) { MOZ_CRASH(); }
-+inline void EmitBaselineLeaveStubFrame(MacroAssembler&, bool v = false) {
-+  MOZ_CRASH();
-+}
-+inline void EmitStubGuardFailure(MacroAssembler&) { MOZ_CRASH(); }
-+
-+template <typename T>
-+inline void EmitPreBarrier(MacroAssembler&, T, MIRType) {
-+  MOZ_CRASH();
-+}
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_SharedICHelpers_riscv64_h */
-diff --git a/js/src/jit/riscv64/SharedICRegisters-riscv64.h b/js/src/jit/riscv64/SharedICRegisters-riscv64.h
-new file mode 100644
-index 0000000000..f1d5f165d8
---- /dev/null
-+++ b/js/src/jit/riscv64/SharedICRegisters-riscv64.h
-@@ -0,0 +1,38 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#ifndef jit_riscv64_SharedICRegisters_riscv64_h
-+#define jit_riscv64_SharedICRegisters_riscv64_h
-+
-+#include "jit/riscv64/Assembler-riscv64.h"
-+#include "jit/Registers.h"
-+#include "jit/RegisterSets.h"
-+
-+namespace js {
-+namespace jit {
-+
-+static constexpr Register BaselineFrameReg{Registers::invalid_reg};
-+static constexpr Register BaselineStackReg{Registers::invalid_reg};
-+
-+static constexpr ValueOperand R0 = JSReturnOperand;
-+static constexpr ValueOperand R1 = JSReturnOperand;
-+static constexpr ValueOperand R2 = JSReturnOperand;
-+
-+static constexpr Register ICTailCallReg{Registers::invalid_reg};
-+static constexpr Register ICStubReg{Registers::invalid_reg};
-+
-+static constexpr Register ExtractTemp0{Registers::invalid_reg};
-+static constexpr Register ExtractTemp1{Registers::invalid_reg};
-+
-+static constexpr FloatRegister FloatReg0;
-+static constexpr FloatRegister FloatReg1;
-+static constexpr FloatRegister FloatReg2;
-+static constexpr FloatRegister FloatReg3;
-+
-+}  // namespace jit
-+}  // namespace js
-+
-+#endif /* jit_riscv64_SharedICRegisters_riscv64_h */
-diff --git a/js/src/jit/riscv64/Trampoline-riscv64.cpp b/js/src/jit/riscv64/Trampoline-riscv64.cpp
-new file mode 100644
-index 0000000000..0774254cf4
---- /dev/null
-+++ b/js/src/jit/riscv64/Trampoline-riscv64.cpp
-@@ -0,0 +1,67 @@
-+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-+ * vim: set ts=8 sts=2 et sw=2 tw=80:
-+ * This Source Code Form is subject to the terms of the Mozilla Public
-+ * License, v. 2.0. If a copy of the MPL was not distributed with this
-+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-+
-+#include "jit/Bailouts.h"
-+#include "jit/BaselineIC.h"
-+#include "jit/JitRuntime.h"
-+#include "vm/Realm.h"
-+
-+using namespace js;
-+using namespace js::jit;
-+
-+// This file includes stubs for generating the JIT trampolines when there is no
-+// JIT backend, and also includes implementations for assorted random things
-+// which can't be implemented in headers.
-+
-+void JitRuntime::generateEnterJIT(JSContext*, MacroAssembler&) { MOZ_CRASH(); }
-+// static
-+mozilla::Maybe<::JS::ProfilingFrameIterator::RegisterState>
-+JitRuntime::getCppEntryRegisters(JitFrameLayout* frameStackAddress) {
-+  return mozilla::Nothing{};
-+}
-+void JitRuntime::generateInvalidator(MacroAssembler&, Label*) { MOZ_CRASH(); }
-+void JitRuntime::generateArgumentsRectifier(MacroAssembler&,
-+                                            ArgumentsRectifierKind kind) {
-+  MOZ_CRASH();
-+}
-+JitRuntime::BailoutTable JitRuntime::generateBailoutTable(MacroAssembler&,
-+                                                          Label*, uint32_t) {
-+  MOZ_CRASH();
-+}
-+void JitRuntime::generateBailoutHandler(MacroAssembler&, Label*) {
-+  MOZ_CRASH();
-+}
-+uint32_t JitRuntime::generatePreBarrier(JSContext*, MacroAssembler&, MIRType) {
-+  MOZ_CRASH();
-+}
-+void JitRuntime::generateExceptionTailStub(MacroAssembler&, Label*) {
-+  MOZ_CRASH();
-+}
-+void JitRuntime::generateBailoutTailStub(MacroAssembler&, Label*) {
-+  MOZ_CRASH();
-+}
-+void JitRuntime::generateProfilerExitFrameTailStub(MacroAssembler&, Label*) {
-+  MOZ_CRASH();
-+}
-+
-+bool JitRuntime::generateVMWrapper(JSContext*, MacroAssembler&,
-+                                   const VMFunctionData&, DynFn, uint32_t*) {
-+  MOZ_CRASH();
-+}
-+
-+FrameSizeClass FrameSizeClass::FromDepth(uint32_t) { MOZ_CRASH(); }
-+FrameSizeClass FrameSizeClass::ClassLimit() { MOZ_CRASH(); }
-+uint32_t FrameSizeClass::frameSize() const { MOZ_CRASH(); }
-+
-+BailoutFrameInfo::BailoutFrameInfo(const JitActivationIterator& iter,
-+                                   BailoutStack* bailout) {
-+  MOZ_CRASH();
-+}
-+
-+BailoutFrameInfo::BailoutFrameInfo(const JitActivationIterator& iter,
-+                                   InvalidationBailoutStack* bailout) {
-+  MOZ_CRASH();
-+}
-diff --git a/js/src/jit/shared/Assembler-shared.h b/js/src/jit/shared/Assembler-shared.h
-index fcabddd98b..19cf397df1 100644
---- a/js/src/jit/shared/Assembler-shared.h
-+++ b/js/src/jit/shared/Assembler-shared.h
-@@ -26,13 +26,14 @@
- 
- #if defined(JS_CODEGEN_ARM) || defined(JS_CODEGEN_ARM64) ||     \
-     defined(JS_CODEGEN_MIPS32) || defined(JS_CODEGEN_MIPS64) || \
--    defined(JS_CODEGEN_LOONG64)
-+    defined(JS_CODEGEN_LOONG64) || defined(JS_CODEGEN_RISCV64)
- // Push return addresses callee-side.
- #  define JS_USE_LINK_REGISTER
- #endif
- 
- #if defined(JS_CODEGEN_MIPS32) || defined(JS_CODEGEN_MIPS64) || \
--    defined(JS_CODEGEN_ARM64) || defined(JS_CODEGEN_LOONG64)
-+    defined(JS_CODEGEN_ARM64) || defined(JS_CODEGEN_LOONG64) || \
-+    defined(JS_CODEGEN_RISCV64)
- // JS_CODELABEL_LINKMODE gives labels additional metadata
- // describing how Bind() should patch them.
- #  define JS_CODELABEL_LINKMODE
-diff --git a/js/src/util/Poison.h b/js/src/util/Poison.h
-index cb8e1abc64..a6a2d2f12b 100644
---- a/js/src/util/Poison.h
-+++ b/js/src/util/Poison.h
-@@ -95,6 +95,8 @@ const uint8_t JS_SCOPE_DATA_TRAILING_NAMES_PATTERN = 0xCC;
- #  define JS_SWEPT_CODE_PATTERN 0x01  // undefined instruction
- #elif defined(JS_CODEGEN_LOONG64)
- #  define JS_SWEPT_CODE_PATTERN 0x01  // undefined instruction
-+#elif defined(JS_CODEGEN_RISCV64)
-+#  define JS_SWEPT_CODE_PATTERN 0x01  // undefined instruction
- #else
- #  error "JS_SWEPT_CODE_PATTERN not defined for this platform"
- #endif
-diff --git a/js/src/wasm/WasmBCMemory.cpp b/js/src/wasm/WasmBCMemory.cpp
-index 94e739090b..2c226dadd5 100644
---- a/js/src/wasm/WasmBCMemory.cpp
-+++ b/js/src/wasm/WasmBCMemory.cpp
-@@ -1214,6 +1214,22 @@ static void Deallocate(BaseCompiler* bc, RegI32 rv, const Temps& temps) {
-   bc->maybeFree(temps.t2);
- }
- 
-+#elif defined(JS_CODEGEN_RISCV64)
-+
-+struct Temps {
-+  RegI32 t0;
-+};
-+
-+static void PopAndAllocate(BaseCompiler* bc, ValType type,
-+                           Scalar::Type viewType, AtomicOp op, RegI32* rd,
-+                           RegI32* rv, Temps* temps) {}
-+
-+static void Perform(BaseCompiler* bc, const MemoryAccessDesc& access,
-+                    BaseIndex srcAddr, AtomicOp op, RegI32 rv, RegI32 rd,
-+                    const Temps& temps) {}
-+
-+static void Deallocate(BaseCompiler*, RegI32, const Temps&) {}
-+
- #elif defined(JS_CODEGEN_NONE)
- 
- using Temps = Nothing;
-@@ -1375,6 +1391,17 @@ static void Deallocate(BaseCompiler* bc, AtomicOp op, RegI64 rv, RegI64 temp) {
-   bc->freeI64(temp);
- }
- 
-+#elif defined(JS_CODEGEN_RISCV64)
-+
-+static void PopAndAllocate(BaseCompiler* bc, AtomicOp op, RegI64* rd,
-+                           RegI64* rv, RegI64* temp) {}
-+
-+static void Perform(BaseCompiler* bc, const MemoryAccessDesc& access,
-+                    BaseIndex srcAddr, AtomicOp op, RegI64 rv, RegI64 temp,
-+                    RegI64 rd) {}
-+
-+static void Deallocate(BaseCompiler* bc, AtomicOp op, RegI64 rv, RegI64 temp) {}
-+
- #elif defined(JS_CODEGEN_NONE)
- 
- static void PopAndAllocate(BaseCompiler*, AtomicOp, RegI64*, RegI64*, RegI64*) {
-diff --git a/js/src/wasm/WasmCompile.cpp b/js/src/wasm/WasmCompile.cpp
-index 26534bca4e..403e26414b 100644
---- a/js/src/wasm/WasmCompile.cpp
-+++ b/js/src/wasm/WasmCompile.cpp
-@@ -74,6 +74,8 @@ uint32_t wasm::ObservedCPUFeatures() {
- #elif defined(JS_CODEGEN_LOONG64)
-   MOZ_ASSERT(jit::GetLOONG64Flags() <= (UINT32_MAX >> ARCH_BITS));
-   return LOONG64 | (jit::GetLOONG64Flags() << ARCH_BITS);
-+#elif defined(JS_CODEGEN_RISCV64)
-+  return 0;
- #elif defined(JS_CODEGEN_NONE)
-   return 0;
- #else
-diff --git a/js/src/wasm/WasmFrameIter.cpp b/js/src/wasm/WasmFrameIter.cpp
-index e612e05704..0ce3453287 100644
---- a/js/src/wasm/WasmFrameIter.cpp
-+++ b/js/src/wasm/WasmFrameIter.cpp
-@@ -384,6 +384,12 @@ static const unsigned PushedFP = 16;
- static const unsigned SetFP = 20;
- static const unsigned PoppedFP = 4;
- static const unsigned PoppedFPJitEntry = 0;
-+#elif defined(JS_CODEGEN_RISCV64)
-+static const unsigned PushedRetAddr = 0;
-+static const unsigned PushedFP = 1;
-+static const unsigned SetFP = 2;
-+static const unsigned PoppedFP = 3;
-+static const unsigned PoppedFPJitEntry = 4;
- #elif defined(JS_CODEGEN_NONE)
- // Synthetic values to satisfy asserts and avoid compiler warnings.
- static const unsigned PushedRetAddr = 0;
-diff --git a/js/src/wasm/WasmSignalHandlers.cpp b/js/src/wasm/WasmSignalHandlers.cpp
-index f74368b954..9521441f02 100644
---- a/js/src/wasm/WasmSignalHandlers.cpp
-+++ b/js/src/wasm/WasmSignalHandlers.cpp
-@@ -157,6 +157,11 @@ using mozilla::DebugOnly;
- #      define R01_sig(p) ((p)->uc_mcontext.gp_regs[1])
- #      define R32_sig(p) ((p)->uc_mcontext.gp_regs[32])
- #    endif
-+#    if defined(__linux__) && defined(__riscv) && __riscv_xlen == 64
-+#      define EPC_sig(p) ((p)->uc_mcontext.__gregs[0])
-+#      define X02_sig(p) ((p)->uc_mcontext.__gregs[2])
-+#      define X08_sig(p) ((p)->uc_mcontext.__gregs[8])
-+#    endif
- #    if defined(__linux__) && defined(__loongarch__)
- #      define EPC_sig(p) ((p)->uc_mcontext.pc)
- #      define RRA_sig(p) ((p)->uc_mcontext.gregs[1])
-@@ -405,6 +410,10 @@ struct macos_aarch64_context {
- #    define FP_sig(p) RFP_sig(p)
- #    define SP_sig(p) RSP_sig(p)
- #    define LR_sig(p) RRA_sig(p)
-+#  elif defined(__riscv) && __riscv_xlen == 64
-+#    define PC_sig(p) EPC_sig(p)
-+#    define SP_sig(p) X02_sig(p)
-+#    define FP_sig(p) X08_sig(p)
- #  endif
- 
- static void SetContextPC(CONTEXT* context, uint8_t* pc) {
-diff --git a/python/mozbuild/mozbuild/vendor/vendor_rust.py b/python/mozbuild/mozbuild/vendor/vendor_rust.py
-index 31baea4290..7394ccaf40 100644
---- a/python/mozbuild/mozbuild/vendor/vendor_rust.py
-+++ b/python/mozbuild/mozbuild/vendor/vendor_rust.py
-@@ -98,6 +98,7 @@ TOLERATED_DUPES = {
-     "libloading": 2,
-     "memoffset": 2,
-     "mio": 2,
-+    "nix": 2,
-     # Transition from time 0.1 to 0.3 underway, but chrono is stuck on 0.1
-     # and hasn't been updated in 1.5 years (an hypothetical update is
-     # expected to remove the dependency on time altogether).
-diff --git a/supply-chain/config.toml b/supply-chain/config.toml
-index bb3dd733e8..371cbca809 100644
---- a/supply-chain/config.toml
-+++ b/supply-chain/config.toml
-@@ -1,6 +1,10 @@
- 
- # cargo-vet config file
- 
-+[policy.viaduct]
-+audit-as-crates-io = true
-+notes = "I don't know, do as what rust-vet tells me to do"
-+
- [policy.async-task]
- audit-as-crates-io = true
- notes = "This is the upstream code plus an extra fix that hasn't been released yet, see bug 1746533."
-diff --git a/toolkit/library/rust/shared/Cargo.toml b/toolkit/library/rust/shared/Cargo.toml
-index dbd7770326..ffbadcb14c 100644
---- a/toolkit/library/rust/shared/Cargo.toml
-+++ b/toolkit/library/rust/shared/Cargo.toml
-@@ -38,7 +38,7 @@ tokio-reactor = { version = "=0.1.3", optional = true }
- # audioipc2-client and audioipc2-server.
- tokio-threadpool = { version = "=0.1.17", optional = true }
- encoding_glue = { path = "../../../../intl/encoding_glue" }
--authenticator = "0.3.1"
-+authenticator = { git = "https://github.com/mozilla/authenticator-rs", rev = "b85bccf0527e42c877573029e8d35ff13ef06f9d" }
- gkrust_utils = { path = "../../../../xpcom/rust/gkrust_utils" }
- gecko_logger = { path = "../../../../xpcom/rust/gecko_logger" }
- rsdparsa_capi = { path = "../../../../dom/media/webrtc/sdp/rsdparsa_capi" }
-@@ -72,6 +72,7 @@ midir_impl = { path = "../../../../dom/midi/midir_impl", optional = true }
- dom = { path = "../../../../dom/base/rust" }
- origin-trials-ffi = { path = "../../../../dom/origin-trials/ffi" }
- jog = { path = "../../../components/glean/bindings/jog" }
-+midir = { version = "0.8.0" }
- 
- # Note: `modern_sqlite` means rusqlite's bindings file be for a sqlite with
- # version less than or equal to what we link to. This isn't a problem because we

diff --git a/www-client/firefox/files/gentoo-default-prefs.js b/www-client/firefox/files/gentoo-default-prefs.js
deleted file mode 100644
index 0407f5d..0000000
--- a/www-client/firefox/files/gentoo-default-prefs.js
+++ /dev/null
@@ -1,12 +0,0 @@
-pref("general.smoothScroll",               true);
-pref("general.autoScroll",                 false);
-pref("browser.urlbar.hideGoButton",        true);
-pref("accessibility.typeaheadfind",        true);
-pref("browser.shell.checkDefaultBrowser",  false);
-pref("browser.EULA.override",              true);
-pref("general.useragent.locale",           "chrome://global/locale/intl.properties");
-pref("intl.locale.requested",              "");
-/* Disable DoH by default */
-pref("network.trr.mode",                   5);
-/* Disable use of Mozilla Normandy service by default */
-pref("app.normandy.enabled",               false);

diff --git a/www-client/firefox/files/gentoo-hwaccel-prefs.js b/www-client/firefox/files/gentoo-hwaccel-prefs.js
deleted file mode 100644
index a00144a..0000000
--- a/www-client/firefox/files/gentoo-hwaccel-prefs.js
+++ /dev/null
@@ -1,3 +0,0 @@
-/* Force hardware accelerated rendering due to USE=hwaccel */
-pref("layers.acceleration.force-enabled",  true);
-pref("webgl.force-enabled",                true);

diff --git a/www-client/firefox/files/gentoo-hwaccel-prefs.js-r2 b/www-client/firefox/files/gentoo-hwaccel-prefs.js-r2
deleted file mode 100644
index 48025ca..0000000
--- a/www-client/firefox/files/gentoo-hwaccel-prefs.js-r2
+++ /dev/null
@@ -1,5 +0,0 @@
-/* Force hardware accelerated rendering due to USE=hwaccel */
-pref("gfx.webrender.all",                  true);
-pref("layers.acceleration.force-enabled",  true);
-pref("media.hardware-video-decoding.enabled", true);
-pref("webgl.force-enabled",                true);

diff --git a/www-client/firefox/files/icon/firefox-r2.desktop b/www-client/firefox/files/icon/firefox-r2.desktop
deleted file mode 100644
index 45d5f11..0000000
--- a/www-client/firefox/files/icon/firefox-r2.desktop
+++ /dev/null
@@ -1,236 +0,0 @@
-[Desktop Entry]
-Version=1.0
-Name=@NAME@
-GenericName=Web Browser
-Comment=Browse the Web
-Exec=@EXEC@ %u
-Icon=@ICON@
-Terminal=false
-Type=Application
-MimeType=application/pdf;application/vnd.mozilla.xul+xml;application/xhtml+xml;text/html;text/mml;text/xml;x-scheme-handler/ftp;x-scheme-handler/http;x-scheme-handler/https;
-StartupNotify=true
-Categories=Network;WebBrowser;
-Keywords=web;browser;internet;
-Actions=new-window;new-private-window;profile-manager-window;
-
-[Desktop Action new-window]
-Name=Open a New Window
-Name[ach]=Dirica manyen
-Name[af]=Nuwe venster
-Name[an]=Nueva finestra
-Name[ar]=نافذة جديدة
-Name[as]=নতুন উইন্ডো
-Name[ast]=Ventana nueva
-Name[az]=Yeni Pəncərə
-Name[be]=Новае акно
-Name[bg]=Нов прозорец
-Name[bn_BD]=নতুন উইন্ডো (N)
-Name[bn_IN]=নতুন উইন্ডো
-Name[br]=Prenestr nevez
-Name[brx]=गोदान उइन्ड'(N)
-Name[bs]=Novi prozor
-Name[ca]=Finestra nova
-Name[cak]=K'ak'a' tzuwäch
-Name[cs]=Nové okno
-Name[cy]=Ffenestr Newydd
-Name[da]=Nyt vindue
-Name[de]=Neues Fenster
-Name[dsb]=Nowe wokno
-Name[el]=Νέο παράθυρο
-Name[en_GB]=New Window
-Name[en_US]=New Window
-Name[en_ZA]=New Window
-Name[eo]=Nova fenestro
-Name[es_AR]=Nueva ventana
-Name[es_CL]=Nueva ventana
-Name[es_ES]=Nueva ventana
-Name[es_MX]=Nueva ventana
-Name[et]=Uus aken
-Name[eu]=Leiho berria
-Name[fa]=پنجره جدید‌
-Name[ff]=Henorde Hesere
-Name[fi]=Uusi ikkuna
-Name[fr]=Nouvelle fenêtre
-Name[fy_NL]=Nij finster
-Name[ga_IE]=Fuinneog Nua
-Name[gd]=Uinneag ùr
-Name[gl]=Nova xanela
-Name[gn]=Ovetã pyahu
-Name[gu_IN]=નવી વિન્ડો
-Name[he]=חלון חדש
-Name[hi_IN]=नया विंडो
-Name[hr]=Novi prozor
-Name[hsb]=Nowe wokno
-Name[hu]=Új ablak
-Name[hy_AM]=Նոր Պատուհան
-Name[id]=Jendela Baru
-Name[is]=Nýr gluggi
-Name[it]=Nuova finestra
-Name[ja]=新しいウィンドウ
-Name[ja_JP-mac]=新規ウインドウ
-Name[ka]=ახალი ფანჯარა
-Name[kk]=Жаңа терезе
-Name[km]=បង្អួច​​​ថ្មី
-Name[kn]=ಹೊಸ ಕಿಟಕಿ
-Name[ko]=새 창
-Name[kok]=नवें जनेल
-Name[ks]=نئئ وِنڈو
-Name[lij]=Neuvo barcon
-Name[lo]=ຫນ້າຕ່າງໃຫມ່
-Name[lt]=Naujas langas
-Name[ltg]=Jauns lūgs
-Name[lv]=Jauns logs
-Name[mai]=नव विंडो
-Name[mk]=Нов прозорец
-Name[ml]=പുതിയ ജാലകം
-Name[mr]=नवीन पटल
-Name[ms]=Tetingkap Baru
-Name[my]=ဝင်းဒိုးအသစ်
-Name[nb_NO]=Nytt vindu
-Name[ne_NP]=नयाँ सञ्झ्याल
-Name[nl]=Nieuw venster
-Name[nn_NO]=Nytt vindauge
-Name[or]=ନୂତନ ୱିଣ୍ଡୋ
-Name[pa_IN]=ਨਵੀਂ ਵਿੰਡੋ
-Name[pl]=Nowe okno
-Name[pt_BR]=Nova janela
-Name[pt_PT]=Nova janela
-Name[rm]=Nova fanestra
-Name[ro]=Fereastră nouă
-Name[ru]=Новое окно
-Name[sat]=नावा विंडो (N)
-Name[si]=නව කවුළුවක්
-Name[sk]=Nové okno
-Name[sl]=Novo okno
-Name[son]=Zanfun taaga
-Name[sq]=Dritare e Re
-Name[sr]=Нови прозор
-Name[sv_SE]=Nytt fönster
-Name[ta]=புதிய சாளரம்
-Name[te]=కొత్త విండో
-Name[th]=หน้าต่างใหม่
-Name[tr]=Yeni pencere
-Name[tsz]=Eraatarakua jimpani
-Name[uk]=Нове вікно
-Name[ur]=نیا دریچہ
-Name[uz]=Yangi oyna
-Name[vi]=Cửa sổ mới
-Name[wo]=Palanteer bu bees
-Name[xh]=Ifestile entsha
-Name[zh_CN]=新建窗口
-Name[zh_TW]=開新視窗
-Exec=@EXEC@ --new-window %u
-
-[Desktop Action new-private-window]
-Name=Open a New Private Window
-Name[ach]=Dirica manyen me mung
-Name[af]=Nuwe privaatvenster
-Name[an]=Nueva finestra privada
-Name[ar]=نافذة خاصة جديدة
-Name[as]=নতুন ব্যক্তিগত উইন্ডো
-Name[ast]=Ventana privada nueva
-Name[az]=Yeni Məxfi Pəncərə
-Name[be]=Новае акно адасаблення
-Name[bg]=Нов прозорец за поверително сърфиране
-Name[bn_BD]=নতুন ব্যক্তিগত উইন্ডো
-Name[bn_IN]=নতুন ব্যক্তিগত উইন্ডো
-Name[br]=Prenestr merdeiñ prevez nevez
-Name[brx]=गोदान प्राइभेट उइन्ड'
-Name[bs]=Novi privatni prozor
-Name[ca]=Finestra privada nova
-Name[cak]=K'ak'a' ichinan tzuwäch
-Name[cs]=Nové anonymní okno
-Name[cy]=Ffenestr Breifat Newydd
-Name[da]=Nyt privat vindue
-Name[de]=Neues privates Fenster
-Name[dsb]=Nowe priwatne wokno
-Name[el]=Νέο παράθυρο ιδιωτικής περιήγησης
-Name[en_GB]=New Private Window
-Name[en_US]=New Private Window
-Name[en_ZA]=New Private Window
-Name[eo]=Nova privata fenestro
-Name[es_AR]=Nueva ventana privada
-Name[es_CL]=Nueva ventana privada
-Name[es_ES]=Nueva ventana privada
-Name[es_MX]=Nueva ventana privada
-Name[et]=Uus privaatne aken
-Name[eu]=Leiho pribatu berria
-Name[fa]=پنجره ناشناس جدید
-Name[ff]=Henorde Suturo Hesere
-Name[fi]=Uusi yksityinen ikkuna
-Name[fr]=Nouvelle fenêtre de navigation privée
-Name[fy_NL]=Nij priveefinster
-Name[ga_IE]=Fuinneog Nua Phríobháideach
-Name[gd]=Uinneag phrìobhaideach ùr
-Name[gl]=Nova xanela privada
-Name[gn]=Ovetã ñemi pyahu
-Name[gu_IN]=નવી ખાનગી વિન્ડો
-Name[he]=חלון פרטי חדש
-Name[hi_IN]=नयी निजी विंडो
-Name[hr]=Novi privatni prozor
-Name[hsb]=Nowe priwatne wokno
-Name[hu]=Új privát ablak
-Name[hy_AM]=Սկսել Գաղտնի դիտարկում
-Name[id]=Jendela Mode Pribadi Baru
-Name[is]=Nýr huliðsgluggi
-Name[it]=Nuova finestra anonima
-Name[ja]=新しいプライベートウィンドウ
-Name[ja_JP-mac]=新規プライベートウインドウ
-Name[ka]=ახალი პირადი ფანჯარა
-Name[kk]=Жаңа жекелік терезе
-Name[km]=បង្អួច​ឯកជន​ថ្មី
-Name[kn]=ಹೊಸ ಖಾಸಗಿ ಕಿಟಕಿ
-Name[ko]=새 사생활 보호 모드
-Name[kok]=नवो खाजगी विंडो
-Name[ks]=نْو پرایوٹ وینڈو&amp;
-Name[lij]=Neuvo barcon privou
-Name[lo]=ເປີດຫນ້າຕ່າງສວນຕົວຂື້ນມາໃຫມ່
-Name[lt]=Naujas privataus naršymo langas
-Name[ltg]=Jauns privatais lūgs
-Name[lv]=Jauns privātais logs
-Name[mai]=नया निज विंडो (W)
-Name[mk]=Нов приватен прозорец
-Name[ml]=പുതിയ സ്വകാര്യ ജാലകം
-Name[mr]=नवीन वैयक्तिक पटल
-Name[ms]=Tetingkap Persendirian Baharu
-Name[my]=New Private Window
-Name[nb_NO]=Nytt privat vindu
-Name[ne_NP]=नयाँ निजी सञ्झ्याल
-Name[nl]=Nieuw privévenster
-Name[nn_NO]=Nytt privat vindauge
-Name[or]=ନୂତନ ବ୍ୟକ୍ତିଗତ ୱିଣ୍ଡୋ
-Name[pa_IN]=ਨਵੀਂ ਪ੍ਰਾਈਵੇਟ ਵਿੰਡੋ
-Name[pl]=Nowe okno prywatne
-Name[pt_BR]=Nova janela privativa
-Name[pt_PT]=Nova janela privada
-Name[rm]=Nova fanestra privata
-Name[ro]=Fereastră privată nouă
-Name[ru]=Новое приватное окно
-Name[sat]=नावा निजेराक् विंडो (W )
-Name[si]=නව පුද්ගලික කවුළුව (W)
-Name[sk]=Nové okno v režime Súkromné prehliadanie
-Name[sl]=Novo zasebno okno
-Name[son]=Sutura zanfun taaga
-Name[sq]=Dritare e Re Private
-Name[sr]=Нови приватан прозор
-Name[sv_SE]=Nytt privat fönster
-Name[ta]=புதிய தனிப்பட்ட சாளரம்
-Name[te]=కొత్త ఆంతరంగిక విండో
-Name[th]=หน้าต่างส่วนตัวใหม่
-Name[tr]=Yeni gizli pencere
-Name[tsz]=Juchiiti eraatarakua jimpani
-Name[uk]=Приватне вікно
-Name[ur]=نیا نجی دریچہ
-Name[uz]=Yangi maxfiy oyna
-Name[vi]=Cửa sổ riêng tư mới
-Name[wo]=Panlanteeru biir bu bees
-Name[xh]=Ifestile yangasese entsha
-Name[zh_CN]=新建隐私浏览窗口
-Name[zh_TW]=新增隱私視窗
-Exec=@EXEC@ --private-window %u
-
-[Desktop Action profile-manager-window]
-Name=Open the Profile Manager
-Name[de]=Profilverwaltung öffnen
-Name[cs]=Správa profilů
-Exec=@EXEC@ --ProfileManager

diff --git a/www-client/firefox/files/icon/firefox-r3.desktop b/www-client/firefox/files/icon/firefox-r3.desktop
deleted file mode 100644
index 8219e93..0000000
--- a/www-client/firefox/files/icon/firefox-r3.desktop
+++ /dev/null
@@ -1,236 +0,0 @@
-[Desktop Entry]
-Version=1.0
-Name=@NAME@
-GenericName=Web Browser
-Comment=Browse the Web
-Exec=@EXEC@ %u
-Icon=@ICON@
-Terminal=false
-Type=Application
-MimeType=application/pdf;application/vnd.mozilla.xul+xml;application/xhtml+xml;text/html;text/mml;text/xml;x-scheme-handler/http;x-scheme-handler/https;
-StartupNotify=true
-Categories=Network;WebBrowser;
-Keywords=web;browser;internet;
-Actions=new-window;new-private-window;profile-manager-window;
-
-[Desktop Action new-window]
-Name=Open a New Window
-Name[ach]=Dirica manyen
-Name[af]=Nuwe venster
-Name[an]=Nueva finestra
-Name[ar]=نافذة جديدة
-Name[as]=নতুন উইন্ডো
-Name[ast]=Ventana nueva
-Name[az]=Yeni Pəncərə
-Name[be]=Новае акно
-Name[bg]=Нов прозорец
-Name[bn_BD]=নতুন উইন্ডো (N)
-Name[bn_IN]=নতুন উইন্ডো
-Name[br]=Prenestr nevez
-Name[brx]=गोदान उइन्ड'(N)
-Name[bs]=Novi prozor
-Name[ca]=Finestra nova
-Name[cak]=K'ak'a' tzuwäch
-Name[cs]=Nové okno
-Name[cy]=Ffenestr Newydd
-Name[da]=Nyt vindue
-Name[de]=Neues Fenster
-Name[dsb]=Nowe wokno
-Name[el]=Νέο παράθυρο
-Name[en_GB]=New Window
-Name[en_US]=New Window
-Name[en_ZA]=New Window
-Name[eo]=Nova fenestro
-Name[es_AR]=Nueva ventana
-Name[es_CL]=Nueva ventana
-Name[es_ES]=Nueva ventana
-Name[es_MX]=Nueva ventana
-Name[et]=Uus aken
-Name[eu]=Leiho berria
-Name[fa]=پنجره جدید‌
-Name[ff]=Henorde Hesere
-Name[fi]=Uusi ikkuna
-Name[fr]=Nouvelle fenêtre
-Name[fy_NL]=Nij finster
-Name[ga_IE]=Fuinneog Nua
-Name[gd]=Uinneag ùr
-Name[gl]=Nova xanela
-Name[gn]=Ovetã pyahu
-Name[gu_IN]=નવી વિન્ડો
-Name[he]=חלון חדש
-Name[hi_IN]=नया विंडो
-Name[hr]=Novi prozor
-Name[hsb]=Nowe wokno
-Name[hu]=Új ablak
-Name[hy_AM]=Նոր Պատուհան
-Name[id]=Jendela Baru
-Name[is]=Nýr gluggi
-Name[it]=Nuova finestra
-Name[ja]=新しいウィンドウ
-Name[ja_JP-mac]=新規ウインドウ
-Name[ka]=ახალი ფანჯარა
-Name[kk]=Жаңа терезе
-Name[km]=បង្អួច​​​ថ្មី
-Name[kn]=ಹೊಸ ಕಿಟಕಿ
-Name[ko]=새 창
-Name[kok]=नवें जनेल
-Name[ks]=نئئ وِنڈو
-Name[lij]=Neuvo barcon
-Name[lo]=ຫນ້າຕ່າງໃຫມ່
-Name[lt]=Naujas langas
-Name[ltg]=Jauns lūgs
-Name[lv]=Jauns logs
-Name[mai]=नव विंडो
-Name[mk]=Нов прозорец
-Name[ml]=പുതിയ ജാലകം
-Name[mr]=नवीन पटल
-Name[ms]=Tetingkap Baru
-Name[my]=ဝင်းဒိုးအသစ်
-Name[nb_NO]=Nytt vindu
-Name[ne_NP]=नयाँ सञ्झ्याल
-Name[nl]=Nieuw venster
-Name[nn_NO]=Nytt vindauge
-Name[or]=ନୂତନ ୱିଣ୍ଡୋ
-Name[pa_IN]=ਨਵੀਂ ਵਿੰਡੋ
-Name[pl]=Nowe okno
-Name[pt_BR]=Nova janela
-Name[pt_PT]=Nova janela
-Name[rm]=Nova fanestra
-Name[ro]=Fereastră nouă
-Name[ru]=Новое окно
-Name[sat]=नावा विंडो (N)
-Name[si]=නව කවුළුවක්
-Name[sk]=Nové okno
-Name[sl]=Novo okno
-Name[son]=Zanfun taaga
-Name[sq]=Dritare e Re
-Name[sr]=Нови прозор
-Name[sv_SE]=Nytt fönster
-Name[ta]=புதிய சாளரம்
-Name[te]=కొత్త విండో
-Name[th]=หน้าต่างใหม่
-Name[tr]=Yeni pencere
-Name[tsz]=Eraatarakua jimpani
-Name[uk]=Нове вікно
-Name[ur]=نیا دریچہ
-Name[uz]=Yangi oyna
-Name[vi]=Cửa sổ mới
-Name[wo]=Palanteer bu bees
-Name[xh]=Ifestile entsha
-Name[zh_CN]=新建窗口
-Name[zh_TW]=開新視窗
-Exec=@EXEC@ --new-window %u
-
-[Desktop Action new-private-window]
-Name=Open a New Private Window
-Name[ach]=Dirica manyen me mung
-Name[af]=Nuwe privaatvenster
-Name[an]=Nueva finestra privada
-Name[ar]=نافذة خاصة جديدة
-Name[as]=নতুন ব্যক্তিগত উইন্ডো
-Name[ast]=Ventana privada nueva
-Name[az]=Yeni Məxfi Pəncərə
-Name[be]=Новае акно адасаблення
-Name[bg]=Нов прозорец за поверително сърфиране
-Name[bn_BD]=নতুন ব্যক্তিগত উইন্ডো
-Name[bn_IN]=নতুন ব্যক্তিগত উইন্ডো
-Name[br]=Prenestr merdeiñ prevez nevez
-Name[brx]=गोदान प्राइभेट उइन्ड'
-Name[bs]=Novi privatni prozor
-Name[ca]=Finestra privada nova
-Name[cak]=K'ak'a' ichinan tzuwäch
-Name[cs]=Nové anonymní okno
-Name[cy]=Ffenestr Breifat Newydd
-Name[da]=Nyt privat vindue
-Name[de]=Neues privates Fenster
-Name[dsb]=Nowe priwatne wokno
-Name[el]=Νέο παράθυρο ιδιωτικής περιήγησης
-Name[en_GB]=New Private Window
-Name[en_US]=New Private Window
-Name[en_ZA]=New Private Window
-Name[eo]=Nova privata fenestro
-Name[es_AR]=Nueva ventana privada
-Name[es_CL]=Nueva ventana privada
-Name[es_ES]=Nueva ventana privada
-Name[es_MX]=Nueva ventana privada
-Name[et]=Uus privaatne aken
-Name[eu]=Leiho pribatu berria
-Name[fa]=پنجره ناشناس جدید
-Name[ff]=Henorde Suturo Hesere
-Name[fi]=Uusi yksityinen ikkuna
-Name[fr]=Nouvelle fenêtre de navigation privée
-Name[fy_NL]=Nij priveefinster
-Name[ga_IE]=Fuinneog Nua Phríobháideach
-Name[gd]=Uinneag phrìobhaideach ùr
-Name[gl]=Nova xanela privada
-Name[gn]=Ovetã ñemi pyahu
-Name[gu_IN]=નવી ખાનગી વિન્ડો
-Name[he]=חלון פרטי חדש
-Name[hi_IN]=नयी निजी विंडो
-Name[hr]=Novi privatni prozor
-Name[hsb]=Nowe priwatne wokno
-Name[hu]=Új privát ablak
-Name[hy_AM]=Սկսել Գաղտնի դիտարկում
-Name[id]=Jendela Mode Pribadi Baru
-Name[is]=Nýr huliðsgluggi
-Name[it]=Nuova finestra anonima
-Name[ja]=新しいプライベートウィンドウ
-Name[ja_JP-mac]=新規プライベートウインドウ
-Name[ka]=ახალი პირადი ფანჯარა
-Name[kk]=Жаңа жекелік терезе
-Name[km]=បង្អួច​ឯកជន​ថ្មី
-Name[kn]=ಹೊಸ ಖಾಸಗಿ ಕಿಟಕಿ
-Name[ko]=새 사생활 보호 모드
-Name[kok]=नवो खाजगी विंडो
-Name[ks]=نْو پرایوٹ وینڈو&amp;
-Name[lij]=Neuvo barcon privou
-Name[lo]=ເປີດຫນ້າຕ່າງສວນຕົວຂື້ນມາໃຫມ່
-Name[lt]=Naujas privataus naršymo langas
-Name[ltg]=Jauns privatais lūgs
-Name[lv]=Jauns privātais logs
-Name[mai]=नया निज विंडो (W)
-Name[mk]=Нов приватен прозорец
-Name[ml]=പുതിയ സ്വകാര്യ ജാലകം
-Name[mr]=नवीन वैयक्तिक पटल
-Name[ms]=Tetingkap Persendirian Baharu
-Name[my]=New Private Window
-Name[nb_NO]=Nytt privat vindu
-Name[ne_NP]=नयाँ निजी सञ्झ्याल
-Name[nl]=Nieuw privévenster
-Name[nn_NO]=Nytt privat vindauge
-Name[or]=ନୂତନ ବ୍ୟକ୍ତିଗତ ୱିଣ୍ଡୋ
-Name[pa_IN]=ਨਵੀਂ ਪ੍ਰਾਈਵੇਟ ਵਿੰਡੋ
-Name[pl]=Nowe okno prywatne
-Name[pt_BR]=Nova janela privativa
-Name[pt_PT]=Nova janela privada
-Name[rm]=Nova fanestra privata
-Name[ro]=Fereastră privată nouă
-Name[ru]=Новое приватное окно
-Name[sat]=नावा निजेराक् विंडो (W )
-Name[si]=නව පුද්ගලික කවුළුව (W)
-Name[sk]=Nové okno v režime Súkromné prehliadanie
-Name[sl]=Novo zasebno okno
-Name[son]=Sutura zanfun taaga
-Name[sq]=Dritare e Re Private
-Name[sr]=Нови приватан прозор
-Name[sv_SE]=Nytt privat fönster
-Name[ta]=புதிய தனிப்பட்ட சாளரம்
-Name[te]=కొత్త ఆంతరంగిక విండో
-Name[th]=หน้าต่างส่วนตัวใหม่
-Name[tr]=Yeni gizli pencere
-Name[tsz]=Juchiiti eraatarakua jimpani
-Name[uk]=Приватне вікно
-Name[ur]=نیا نجی دریچہ
-Name[uz]=Yangi maxfiy oyna
-Name[vi]=Cửa sổ riêng tư mới
-Name[wo]=Panlanteeru biir bu bees
-Name[xh]=Ifestile yangasese entsha
-Name[zh_CN]=新建隐私浏览窗口
-Name[zh_TW]=新增隱私視窗
-Exec=@EXEC@ --private-window %u
-
-[Desktop Action profile-manager-window]
-Name=Open the Profile Manager
-Name[de]=Profilverwaltung öffnen
-Name[cs]=Správa profilů
-Exec=@EXEC@ --ProfileManager

diff --git a/www-client/firefox/files/icon/firefox-symbolic.svg b/www-client/firefox/files/icon/firefox-symbolic.svg
deleted file mode 100644
index 2078eea..0000000
--- a/www-client/firefox/files/icon/firefox-symbolic.svg
+++ /dev/null
@@ -1,64 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<svg
-   xmlns:dc="http://purl.org/dc/elements/1.1/"
-   xmlns:cc="http://creativecommons.org/ns#"
-   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
-   xmlns:svg="http://www.w3.org/2000/svg"
-   xmlns="http://www.w3.org/2000/svg"
-   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
-   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
-   width="16"
-   height="16"
-   viewBox="0 0 16 16"
-   version="1.1"
-   id="svg3758"
-   sodipodi:docname="firefox-symbolic-quantum.svg"
-   inkscape:version="0.92.2 5c3e80d, 2017-08-06">
-  <metadata
-     id="metadata3764">
-    <rdf:RDF>
-      <cc:Work
-         rdf:about="">
-        <dc:format>image/svg+xml</dc:format>
-        <dc:type
-           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
-        <dc:title>Gnome Symbolic Icon Theme</dc:title>
-      </cc:Work>
-    </rdf:RDF>
-  </metadata>
-  <defs
-     id="defs3762" />
-  <sodipodi:namedview
-     pagecolor="#555753"
-     bordercolor="#666666"
-     borderopacity="1"
-     objecttolerance="10"
-     gridtolerance="10"
-     guidetolerance="10"
-     inkscape:pageopacity="1"
-     inkscape:pageshadow="2"
-     inkscape:window-width="1591"
-     inkscape:window-height="909"
-     id="namedview3760"
-     showgrid="false"
-     showborder="false"
-     inkscape:snap-global="false"
-     inkscape:zoom="1"
-     inkscape:cx="3.8851213"
-     inkscape:cy="12.517918"
-     inkscape:window-x="143"
-     inkscape:window-y="60"
-     inkscape:window-maximized="0"
-     inkscape:current-layer="svg3758">
-    <inkscape:grid
-       type="xygrid"
-       id="grid3768" />
-  </sodipodi:namedview>
-  <title
-     id="title3754">Gnome Symbolic Icon Theme</title>
-  <path
-     d="m 15.054715,6.9884649 v 0 c -0.02034,-0.133652 -0.04071,-0.2122775 -0.04071,-0.2122775 0,0 -0.05225,0.060583 -0.138743,0.1748124 A 4.9808937,4.9808937 0 0 0 14.703694,6.0103229 6.4034781,6.4034781 0 0 0 14.270352,4.895288 4.6469845,4.6469845 0 0 0 13.87447,4.2163686 Q 13.793063,4.0947376 13.708437,3.9805045 C 13.444828,3.5499376 13.142365,3.2867867 12.792269,2.7891599 A 3.6101075,3.6101075 0 0 1 12.333953,1.5474054 5.0151173,5.0151173 0 0 0 12.113814,2.3599798 C 11.754468,1.997397 11.441832,1.7397963 11.253142,1.5640539 10.322171,0.69459485 10.430396,0.24367816 10.430396,0.24367816 v 0 c 0,0 -1.7389294,1.94102274 -0.9855522,3.96297904 a 3.8848199,3.8848199 0 0 0 1.2949452,1.726432 c 0.728868,0.6012222 1.513693,1.0743371 1.927612,2.2832561 A 3.8741829,3.8741829 0 0 0 11.21337,6.6823034 3.5023502,3.5023502 0 0 1 11.490854,8.0697401 3.2946971,3.2946971 0 0 1 7.4621982,11.27934 3.0343219,3.0343219 0 0 1 6.6459244,11.001852 3.3219834,3.3219834 0 0 1 5.667782,10.09771 l -0.00463,-
 0.0078 0.058274,0.02125 a 3.0061106,3.0061106 0 0 0 0.4162344,0.111409 2.6028293,2.6028293 0 0 0 1.6570605,-0.195631 C 8.3154732,9.7379218 8.6308831,9.5237932 8.8866339,9.6084266 h 0.0046 c 0.24974,0.079514 0.446755,-0.1628244 0.2682391,-0.4162632 A 1.3596868,1.3596868 0 0 0 7.8423564,8.6778985 C 7.3211426,8.7537416 6.8434027,9.1241907 6.1603222,8.7653097 a 1.4470953,1.4470953 0 0 1 -0.128107,-0.075371 c -0.04625,-0.026369 0.146605,0.040234 0.1017455,0.010233 A 3.3899676,3.3899676 0 0 1 5.7047808,8.4439577 c -0.010172,-0.00822 0.103133,0.032367 0.092497,0.024039 A 1.6561356,1.6561356 0 0 1 5.3495968,8.015168 0.80517516,0.80517516 0 0 1 5.3190728,7.2964766 0.63405807,0.63405807 0 0 1 5.5965603,7.0356384 c 0.088333,0.043485 0.1429059,0.076305 0.1429059,0.076305 0,0 -0.040235,-0.073997 -0.061972,-0.1128365 0.00786,-0.0027 0.014794,0 0.022662,-0.00513 0.077233,0.033293 0.248351,0.1202544 0.3385341,0.1734358 A 0.46987818,0.46987818 0 0 1 6.19362,7.3061637 c 0,0 0.030994,-0.015351 0.0079,
 -0.079998 A 0.41623066,0.41623066 0 0 0 6.0414753,7.0300927 h 0.0074 a 1.3596868,1.3596868 0 0 1 0.1970213,0.1225561 0.96149289,0.96149289 0 0 0 0.078625,-0.416232 0.54479973,0.54479973 0 0 0 -0.031914,-0.2312396 c -0.024511,-0.046254 0.013876,-0.064746 0.056885,-0.016135 A 0.45137905,0.45137905 0 0 0 6.3129456,6.378979 v -0.00372 0 c 0,0 0.024511,-0.031916 0.035615,-0.043486 A 0.66134433,0.66134433 0 0 1 6.4484481,6.2503678 4.6122987,4.6122987 0 0 1 7.1259793,5.9048971 C 7.3174429,5.8211545 7.4760733,5.7573477 7.5084475,5.7388339 a 1.0637007,1.0637007 0 0 0 0.1355052,-0.1040612 0.91015778,0.91015778 0 0 0 0.3052354,-0.5272274 0.73996569,0.73996569 0 0 0 0.0079,-0.082324 v -0.023118 -0.013967 0 -0.00552 0 -0.00611 0 C 7.9293085,4.872475 7.749868,4.7943251 6.8119611,4.7064478 A 0.81997449,0.81997449 0 0 1 6.1413599,4.0776254 v 0.0042 c -0.013416,0.034225 -0.025431,0.068909 -0.037456,0.1040572 0.012025,-0.034685 0.024051,-0.069373 0.037456,-0.1040572 v -0.00742 A 2.3762148,2.3762148 0
  0 1 7.0598423,2.9339361 c 0.024051,-0.019416 -0.096192,0.00512 -0.072152,-0.014798 A 2.3845397,2.3845397 0 0 1 7.2328039,2.8155414 C 7.2748921,2.7979724 7.0524371,2.7128704 6.8558842,2.7336774 a 1.0174527,1.0174527 0 0 0 -0.3496338,0.082324 c 0.046253,-0.039773 0.1849968,-0.092498 0.1521605,-0.092498 a 2.2499581,2.2499581 0 0 0 -0.713142,0.2696255 0.14521828,0.14521828 0 0 1 0.01387,-0.064747 1.1099484,1.1099484 0 0 0 -0.4458297,0.3440843 0.58966016,0.58966016 0 0 0 0.00462,-0.080469 1.3300881,1.3300881 0 0 0 -0.2187525,0.2053404 l -0.00417,0.00321 A 2.9066776,2.9066776 0 0 0 3.6684873,3.2618132 l -0.00463,-0.0042 h 0.00554 A 1.3610743,1.3610743 0 0 1 3.3803631,2.9339159 l -0.0074,0.0018 -0.00877,-0.010174 C 3.3285694,2.8728322 3.2920343,2.813172 3.2545731,2.7465739 3.2277502,2.7003291 3.2004619,2.646216 3.1731756,2.5902563 c 0,-0.00372 -0.00416,-0.00513 -0.006,-0.00552 -0.0111,0 -0.01896,0.05133 -0.028212,0.037927 v -0.0028 A 1.9923577,1.9923577 0 0 1 3.0080744,1.8396896 l -0.0074
 ,0.00372 A 0.87130958,0.87130958 0 0 0 2.6704677,2.2753541 c -0.028212,0.063362 -0.046248,0.098047 -0.064746,0.1327329 0,0.0028 0,-0.00461 0,-0.016194 0.00416,-0.031916 0.018037,-0.097585 0.014799,-0.092497 -0.00323,0.00513 -0.00553,0.00882 -0.00877,0.013415 A 0.80147532,0.80147532 0 0 0 2.4956586,2.4848515 1.0891367,1.0891367 0 0 0 2.4262868,2.661518 c -0.00276,0.00973 0,-0.00832 0,-0.029599 0,-0.02127 0.00416,-0.059199 0,-0.051331 L 2.4161148,2.600475 A 4.3935464,4.3935464 0 0 0 2.0461275,4.0040946 1.3976101,1.3976101 0 0 0 2.031791,4.252909 v 0.00742 A 3.0653076,3.0653076 0 0 0 1.6539417,4.7690529 7.2174403,7.2174403 0 0 0 0.85524217,6.725337 4.7871157,4.7871157 0 0 1 1.2830334,5.9756593 6.9371784,6.9371784 0 0 0 0.79974461,8.5192901 6.582457,6.582457 0 0 1 1.0078598,7.7659142 6.3854411,6.3854411 0 0 0 1.585032,10.755373 6.9542899,6.9542899 0 0 0 4.3372422,13.87618 v 0 a 6.0196208,6.0196208 0 0 0 1.6038754,0.768639 c 0.07492,0.02728 0.1507676,0.0541 0.2284646,0.08 -0.024511,-0.00
 96 -0.04625,-0.02034 -0.070761,-0.03098 A 7.2609132,7.2609132 0 0 0 8.179966,15 c 2.494615,0 3.318287,-0.949928 3.394136,-1.044738 v 0 A 1.2625664,1.2625664 0 0 0 11.8687,13.559386 v 0 q 0.07216,-0.02958 0.145679,-0.06335 l 0.03097,-0.01397 0.05597,-0.02635 a 5.2315572,5.2315572 0 0 0 1.053064,-0.659489 2.5436321,2.5436321 0 0 0 0.98184,-1.433687 v 0 a 0.89628343,0.89628343 0 0 0 0.01343,-0.660421 q 0.03838,-0.0606 0.0791,-0.129501 A 5.8762526,5.8762526 0 0 0 15.1107,7.7140393 v -0.0027 c 0,-0.027291 0,-0.054583 0,-0.081863 A 3.5754215,3.5754215 0 0 0 15.05473,6.9884887 Z"
-     id="path3756"
-     inkscape:connector-curvature="0"
-     style="fill:#bebebe;fill-opacity:1;stroke-width:0.46247858" />
-</svg>

diff --git a/www-client/firefox/firefox-103.0.1.ebuild b/www-client/firefox/firefox-103.0.1.ebuild
deleted file mode 100644
index d0494bb..0000000
--- a/www-client/firefox/firefox-103.0.1.ebuild
+++ /dev/null
@@ -1,1301 +0,0 @@
-# Copyright 1999-2022 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI="8"
-
-FIREFOX_PATCHSET="firefox-103-patches-03j.tar.xz"
-
-LLVM_MAX_SLOT=14
-
-PYTHON_COMPAT=( python3_{8..11} )
-PYTHON_REQ_USE="ncurses,sqlite,ssl"
-
-WANT_AUTOCONF="2.1"
-
-VIRTUALX_REQUIRED="pgo"
-
-MOZ_ESR=
-
-MOZ_PV=${PV}
-MOZ_PV_SUFFIX=
-if [[ ${PV} =~ (_(alpha|beta|rc).*)$ ]] ; then
-	MOZ_PV_SUFFIX=${BASH_REMATCH[1]}
-
-	# Convert the ebuild version to the upstream Mozilla version
-	MOZ_PV="${MOZ_PV/_alpha/a}" # Handle alpha for SRC_URI
-	MOZ_PV="${MOZ_PV/_beta/b}"  # Handle beta for SRC_URI
-	MOZ_PV="${MOZ_PV%%_rc*}"    # Handle rc for SRC_URI
-fi
-
-if [[ -n ${MOZ_ESR} ]] ; then
-	# ESR releases have slightly different version numbers
-	MOZ_PV="${MOZ_PV}esr"
-fi
-
-MOZ_PN="${PN%-bin}"
-MOZ_P="${MOZ_PN}-${MOZ_PV}"
-MOZ_PV_DISTFILES="${MOZ_PV}${MOZ_PV_SUFFIX}"
-MOZ_P_DISTFILES="${MOZ_PN}-${MOZ_PV_DISTFILES}"
-
-inherit autotools check-reqs desktop flag-o-matic gnome2-utils linux-info \
-	llvm multiprocessing pax-utils python-any-r1 toolchain-funcs \
-	virtualx xdg
-
-MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/releases/${MOZ_PV}"
-
-if [[ ${PV} == *_rc* ]] ; then
-	MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/candidates/${MOZ_PV}-candidates/build${PV##*_rc}"
-fi
-
-PATCH_URIS=(
-	https://dev.gentoo.org/~{juippis,whissi,slashbeast}/mozilla/patchsets/${FIREFOX_PATCHSET}
-)
-
-SRC_URI="${MOZ_SRC_BASE_URI}/source/${MOZ_P}.source.tar.xz -> ${MOZ_P_DISTFILES}.source.tar.xz
-	${PATCH_URIS[@]}"
-
-DESCRIPTION="Firefox Web Browser"
-HOMEPAGE="https://www.mozilla.com/firefox"
-
-KEYWORDS="~amd64 ~arm64 ~ppc64 ~riscv ~x86"
-
-SLOT="rapid"
-LICENSE="MPL-2.0 GPL-2 LGPL-2.1"
-
-# make clang non-default for now, as lld's relocation relax support is comming in llvm 15 release
-# https://reviews.llvm.org/D127611
-IUSE="clang cpu_flags_arm_neon dbus debug eme-free hardened hwaccel"
-IUSE+=" jack libproxy lto +openh264 pgo pulseaudio sndio selinux"
-IUSE+=" +system-av1 +system-harfbuzz +system-icu +system-jpeg +system-libevent +system-libvpx system-png system-python-libs +system-webp"
-IUSE+=" wayland wifi"
-
-# Firefox-only IUSE
-IUSE+=" geckodriver +gmp-autoupdate screencast +X"
-
-REQUIRED_USE="debug? ( !system-av1 )
-	pgo? ( lto )
-	wifi? ( dbus )"
-
-# Firefox-only REQUIRED_USE flags
-REQUIRED_USE+=" || ( X wayland )"
-REQUIRED_USE+=" pgo? ( X )"
-REQUIRED_USE+=" screencast? ( wayland )"
-
-BDEPEND="${PYTHON_DEPS}
-	app-arch/unzip
-	app-arch/zip
-	>=dev-util/cbindgen-0.24.3
-	net-libs/nodejs
-	virtual/pkgconfig
-	virtual/rust
-	|| (
-		(
-			sys-devel/clang:14
-			sys-devel/llvm:14
-			clang? (
-				=sys-devel/lld-14*
-				pgo? ( =sys-libs/compiler-rt-sanitizers-14*[profile] )
-			)
-		)
-		(
-			sys-devel/clang:13
-			sys-devel/llvm:13
-			clang? (
-				=sys-devel/lld-13*
-				pgo? ( =sys-libs/compiler-rt-sanitizers-13*[profile] )
-			)
-		)
-	)
-	amd64? ( >=dev-lang/nasm-2.14 )
-	x86? ( >=dev-lang/nasm-2.14 )"
-
-COMMON_DEPEND="
-	dev-libs/atk
-	dev-libs/expat
-	dev-libs/glib:2
-	dev-libs/libffi:=
-	>=dev-libs/nss-3.80
-	>=dev-libs/nspr-4.34
-	media-libs/alsa-lib
-	media-libs/fontconfig
-	media-libs/freetype
-	media-libs/mesa
-	media-video/ffmpeg
-	sys-libs/zlib
-	virtual/freedesktop-icon-theme
-	x11-libs/cairo
-	x11-libs/gdk-pixbuf
-	x11-libs/pango
-	x11-libs/pixman
-	dbus? (
-		dev-libs/dbus-glib
-		sys-apps/dbus
-	)
-	jack? ( virtual/jack )
-	libproxy? ( net-libs/libproxy )
-	selinux? ( sec-policy/selinux-mozilla )
-	sndio? ( >=media-sound/sndio-1.8.0-r1 )
-	screencast? ( media-video/pipewire:= )
-	system-av1? (
-		>=media-libs/dav1d-0.9.3:=
-		>=media-libs/libaom-1.0.0:=
-	)
-	system-harfbuzz? (
-		>=media-gfx/graphite2-1.3.13
-		>=media-libs/harfbuzz-2.8.1:0=
-	)
-	system-icu? ( >=dev-libs/icu-71.1:= )
-	system-jpeg? ( >=media-libs/libjpeg-turbo-1.2.1 )
-	system-libevent? ( >=dev-libs/libevent-2.0:0=[threads] )
-	system-libvpx? ( >=media-libs/libvpx-1.8.2:0=[postproc] )
-	system-png? ( >=media-libs/libpng-1.6.35:0=[apng] )
-	system-webp? ( >=media-libs/libwebp-1.1.0:0= )
-	wayland? (
-		>=media-libs/libepoxy-1.5.10-r1
-		x11-libs/gtk+:3[wayland]
-		x11-libs/libdrm
-		x11-libs/libxkbcommon[wayland]
-	)
-	wifi? (
-		kernel_linux? (
-			dev-libs/dbus-glib
-			net-misc/networkmanager
-			sys-apps/dbus
-		)
-	)
-	X? (
-		virtual/opengl
-		x11-libs/cairo[X]
-		x11-libs/gtk+:3[X]
-		x11-libs/libX11
-		x11-libs/libXcomposite
-		x11-libs/libXdamage
-		x11-libs/libXext
-		x11-libs/libXfixes
-		x11-libs/libxkbcommon[X]
-		x11-libs/libXrandr
-		x11-libs/libXtst
-		x11-libs/libxcb:=
-	)"
-
-RDEPEND="${COMMON_DEPEND}
-	!www-client/firefox:0
-	!www-client/firefox:esr
-	jack? ( virtual/jack )
-	openh264? ( media-libs/openh264:*[plugin] )
-	pulseaudio? (
-		|| (
-			media-sound/pulseaudio
-			>=media-sound/apulse-0.1.12-r4
-		)
-	)
-	selinux? ( sec-policy/selinux-mozilla )"
-
-DEPEND="${COMMON_DEPEND}
-	pulseaudio? (
-		|| (
-			media-sound/pulseaudio
-			>=media-sound/apulse-0.1.12-r4[sdk]
-		)
-	)
-	X? (
-		x11-libs/libICE
-		x11-libs/libSM
-	)"
-
-S="${WORKDIR}/${PN}-${PV%_*}"
-RESTRICT=network-sandbox
-
-# Allow MOZ_GMP_PLUGIN_LIST to be set in an eclass or
-# overridden in the enviromnent (advanced hackers only)
-if [[ -z "${MOZ_GMP_PLUGIN_LIST+set}" ]] ; then
-	MOZ_GMP_PLUGIN_LIST=( gmp-gmpopenh264 gmp-widevinecdm )
-fi
-
-llvm_check_deps() {
-	if ! has_version -b "sys-devel/clang:${LLVM_SLOT}" ; then
-		einfo "sys-devel/clang:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
-		return 1
-	fi
-
-	if use clang ; then
-		if ! has_version -b "=sys-devel/lld-${LLVM_SLOT}*" ; then
-			einfo "=sys-devel/lld-${LLVM_SLOT}* is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
-			return 1
-		fi
-
-		if use pgo ; then
-			if ! has_version -b "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}*" ; then
-				einfo "=sys-libs/compiler-rt-sanitizers-${LLVM_SLOT}* is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2
-				return 1
-			fi
-		fi
-	fi
-
-	einfo "Using LLVM slot ${LLVM_SLOT} to build" >&2
-}
-
-MOZ_LANGS=(
-	af ar ast be bg br ca cak cs cy da de dsb
-	el en-CA en-GB en-US es-AR es-ES et eu
-	fi fr fy-NL ga-IE gd gl he hr hsb hu
-	id is it ja ka kab kk ko lt lv ms nb-NO nl nn-NO
-	pa-IN pl pt-BR pt-PT rm ro ru
-	sk sl sq sr sv-SE th tr uk uz vi zh-CN zh-TW
-)
-
-# Firefox-only LANGS
-MOZ_LANGS+=( ach )
-MOZ_LANGS+=( an )
-MOZ_LANGS+=( az )
-MOZ_LANGS+=( bn )
-MOZ_LANGS+=( bs )
-MOZ_LANGS+=( ca-valencia )
-MOZ_LANGS+=( eo )
-MOZ_LANGS+=( es-CL )
-MOZ_LANGS+=( es-MX )
-MOZ_LANGS+=( fa )
-MOZ_LANGS+=( ff )
-MOZ_LANGS+=( gn )
-MOZ_LANGS+=( gu-IN )
-MOZ_LANGS+=( hi-IN )
-MOZ_LANGS+=( hy-AM )
-MOZ_LANGS+=( ia )
-MOZ_LANGS+=( km )
-MOZ_LANGS+=( kn )
-MOZ_LANGS+=( lij )
-MOZ_LANGS+=( mk )
-MOZ_LANGS+=( mr )
-MOZ_LANGS+=( my )
-MOZ_LANGS+=( ne-NP )
-MOZ_LANGS+=( oc )
-MOZ_LANGS+=( sco )
-MOZ_LANGS+=( si )
-MOZ_LANGS+=( son )
-MOZ_LANGS+=( szl )
-MOZ_LANGS+=( ta )
-MOZ_LANGS+=( te )
-MOZ_LANGS+=( tl )
-MOZ_LANGS+=( trs )
-MOZ_LANGS+=( ur )
-MOZ_LANGS+=( xh )
-
-mozilla_set_globals() {
-	# https://bugs.gentoo.org/587334
-	local MOZ_TOO_REGIONALIZED_FOR_L10N=(
-		fy-NL ga-IE gu-IN hi-IN hy-AM nb-NO ne-NP nn-NO pa-IN sv-SE
-	)
-
-	local lang xflag
-	for lang in "${MOZ_LANGS[@]}" ; do
-		# en and en_US are handled internally
-		if [[ ${lang} == en ]] || [[ ${lang} == en-US ]] ; then
-			continue
-		fi
-
-		# strip region subtag if $lang is in the list
-		if has ${lang} "${MOZ_TOO_REGIONALIZED_FOR_L10N[@]}" ; then
-			xflag=${lang%%-*}
-		else
-			xflag=${lang}
-		fi
-
-		SRC_URI+=" l10n_${xflag/[_@]/-}? ("
-		SRC_URI+=" ${MOZ_SRC_BASE_URI}/linux-x86_64/xpi/${lang}.xpi -> ${MOZ_P_DISTFILES}-${lang}.xpi"
-		SRC_URI+=" )"
-		IUSE+=" l10n_${xflag/[_@]/-}"
-	done
-}
-mozilla_set_globals
-
-moz_clear_vendor_checksums() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -ne 1 ]] ; then
-		die "${FUNCNAME} requires exact one argument"
-	fi
-
-	einfo "Clearing cargo checksums for ${1} ..."
-
-	sed -i \
-		-e 's/\("files":{\)[^}]*/\1/' \
-		"${S}"/third_party/rust/${1}/.cargo-checksum.json \
-		|| die
-}
-
-moz_install_xpi() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -lt 2 ]] ; then
-		die "${FUNCNAME} requires at least two arguments"
-	fi
-
-	local DESTDIR=${1}
-	shift
-
-	insinto "${DESTDIR}"
-
-	local emid xpi_file xpi_tmp_dir
-	for xpi_file in "${@}" ; do
-		emid=
-		xpi_tmp_dir=$(mktemp -d --tmpdir="${T}")
-
-		# Unpack XPI
-		unzip -qq "${xpi_file}" -d "${xpi_tmp_dir}" || die
-
-		# Determine extension ID
-		if [[ -f "${xpi_tmp_dir}/install.rdf" ]] ; then
-			emid=$(sed -n -e '/install-manifest/,$ { /em:id/!d; s/.*[\">]\([^\"<>]*\)[\"<].*/\1/; p; q }' "${xpi_tmp_dir}/install.rdf")
-			[[ -z "${emid}" ]] && die "failed to determine extension id from install.rdf"
-		elif [[ -f "${xpi_tmp_dir}/manifest.json" ]] ; then
-			emid=$(sed -n -e 's/.*"id": "\([^"]*\)".*/\1/p' "${xpi_tmp_dir}/manifest.json")
-			[[ -z "${emid}" ]] && die "failed to determine extension id from manifest.json"
-		else
-			die "failed to determine extension id"
-		fi
-
-		einfo "Installing ${emid}.xpi into ${ED}${DESTDIR} ..."
-		newins "${xpi_file}" "${emid}.xpi"
-	done
-}
-
-mozconfig_add_options_ac() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -lt 2 ]] ; then
-		die "${FUNCNAME} requires at least two arguments"
-	fi
-
-	local reason=${1}
-	shift
-
-	local option
-	for option in ${@} ; do
-		echo "ac_add_options ${option} # ${reason}" >>${MOZCONFIG}
-	done
-}
-
-mozconfig_add_options_mk() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -lt 2 ]] ; then
-		die "${FUNCNAME} requires at least two arguments"
-	fi
-
-	local reason=${1}
-	shift
-
-	local option
-	for option in ${@} ; do
-		echo "mk_add_options ${option} # ${reason}" >>${MOZCONFIG}
-	done
-}
-
-mozconfig_use_enable() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -lt 1 ]] ; then
-		die "${FUNCNAME} requires at least one arguments"
-	fi
-
-	local flag=$(use_enable "${@}")
-	mozconfig_add_options_ac "$(use ${1} && echo +${1} || echo -${1})" "${flag}"
-}
-
-mozconfig_use_with() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	if [[ ${#} -lt 1 ]] ; then
-		die "${FUNCNAME} requires at least one arguments"
-	fi
-
-	local flag=$(use_with "${@}")
-	mozconfig_add_options_ac "$(use ${1} && echo +${1} || echo -${1})" "${flag}"
-}
-
-pkg_pretend() {
-	if [[ ${MERGE_TYPE} != binary ]] ; then
-		if use pgo ; then
-			if ! has usersandbox $FEATURES ; then
-				die "You must enable usersandbox as X server can not run as root!"
-			fi
-		fi
-
-		# Ensure we have enough disk space to compile
-		if use pgo || use lto || use debug ; then
-			CHECKREQS_DISK_BUILD="13500M"
-		else
-			CHECKREQS_DISK_BUILD="6600M"
-		fi
-
-		check-reqs_pkg_pretend
-	fi
-}
-
-pkg_setup() {
-	if [[ ${MERGE_TYPE} != binary ]] ; then
-		if use pgo ; then
-			if ! has userpriv ${FEATURES} ; then
-				eerror "Building ${PN} with USE=pgo and FEATURES=-userpriv is not supported!"
-			fi
-		fi
-
-		# Ensure we have enough disk space to compile
-		if use pgo || use lto || use debug ; then
-			CHECKREQS_DISK_BUILD="13500M"
-		else
-			CHECKREQS_DISK_BUILD="6400M"
-		fi
-
-		check-reqs_pkg_setup
-
-		llvm_pkg_setup
-
-		if use clang && use lto ; then
-			local version_lld=$(ld.lld --version 2>/dev/null | awk '{ print $2 }')
-			[[ -n ${version_lld} ]] && version_lld=$(ver_cut 1 "${version_lld}")
-			[[ -z ${version_lld} ]] && die "Failed to read ld.lld version!"
-
-			local version_llvm_rust=$(rustc -Vv 2>/dev/null | grep -F -- 'LLVM version:' | awk '{ print $3 }')
-			[[ -n ${version_llvm_rust} ]] && version_llvm_rust=$(ver_cut 1 "${version_llvm_rust}")
-			[[ -z ${version_llvm_rust} ]] && die "Failed to read used LLVM version from rustc!"
-
-			if ver_test "${version_lld}" -ne "${version_llvm_rust}" ; then
-				eerror "Rust is using LLVM version ${version_llvm_rust} but ld.lld version belongs to LLVM version ${version_lld}."
-				eerror "You will be unable to link ${CATEGORY}/${PN}. To proceed you have the following options:"
-				eerror "  - Manually switch rust version using 'eselect rust' to match used LLVM version"
-				eerror "  - Switch to dev-lang/rust[system-llvm] which will guarantee matching version"
-				eerror "  - Build ${CATEGORY}/${PN} without USE=lto"
-				eerror "  - Rebuild lld with llvm that was used to build rust (may need to rebuild the whole "
-				eerror "    llvm/clang/lld/rust chain depending on your @world updates)"
-				die "LLVM version used by Rust (${version_llvm_rust}) does not match with ld.lld version (${version_lld})!"
-			fi
-		fi
-
-		if ! use clang && [[ $(gcc-major-version) -eq 11 ]] \
-			&& ! has_version -b ">sys-devel/gcc-11.1.0:11" ; then
-			# bug 792705
-			eerror "Using GCC 11 to compile firefox is currently known to be broken (see bug #792705)."
-			die "Set USE=clang or select <gcc-11 to build ${CATEGORY}/${P}."
-		fi
-
-		python-any-r1_pkg_setup
-
-		# Avoid PGO profiling problems due to enviroment leakage
-		# These should *always* be cleaned up anyway
-		unset \
-			DBUS_SESSION_BUS_ADDRESS \
-			DISPLAY \
-			ORBIT_SOCKETDIR \
-			SESSION_MANAGER \
-			XAUTHORITY \
-			XDG_CACHE_HOME \
-			XDG_SESSION_COOKIE
-
-		# Build system is using /proc/self/oom_score_adj, bug #604394
-		addpredict /proc/self/oom_score_adj
-
-		if use pgo ; then
-			# Allow access to GPU during PGO run
-			local ati_cards mesa_cards nvidia_cards render_cards
-			shopt -s nullglob
-
-			ati_cards=$(echo -n /dev/ati/card* | sed 's/ /:/g')
-			if [[ -n "${ati_cards}" ]] ; then
-				addpredict "${ati_cards}"
-			fi
-
-			mesa_cards=$(echo -n /dev/dri/card* | sed 's/ /:/g')
-			if [[ -n "${mesa_cards}" ]] ; then
-				addpredict "${mesa_cards}"
-			fi
-
-			nvidia_cards=$(echo -n /dev/nvidia* | sed 's/ /:/g')
-			if [[ -n "${nvidia_cards}" ]] ; then
-				addpredict "${nvidia_cards}"
-			fi
-
-			render_cards=$(echo -n /dev/dri/renderD128* | sed 's/ /:/g')
-			if [[ -n "${render_cards}" ]] ; then
-				addpredict "${render_cards}"
-			fi
-
-			shopt -u nullglob
-		fi
-
-		if ! mountpoint -q /dev/shm ; then
-			# If /dev/shm is not available, configure is known to fail with
-			# a traceback report referencing /usr/lib/pythonN.N/multiprocessing/synchronize.py
-			ewarn "/dev/shm is not mounted -- expect build failures!"
-		fi
-
-		# Google API keys (see http://www.chromium.org/developers/how-tos/api-keys)
-		# Note: These are for Gentoo Linux use ONLY. For your own distribution, please
-		# get your own set of keys.
-		if [[ -z "${MOZ_API_KEY_GOOGLE+set}" ]] ; then
-			MOZ_API_KEY_GOOGLE="AIzaSyDEAOvatFogGaPi0eTgsV_ZlEzx0ObmepsMzfAc"
-		fi
-
-		if [[ -z "${MOZ_API_KEY_LOCATION+set}" ]] ; then
-			MOZ_API_KEY_LOCATION="AIzaSyB2h2OuRgGaPicUgy5N-5hsZqiPW6sH3n_rptiQ"
-		fi
-
-		# Mozilla API keys (see https://location.services.mozilla.com/api)
-		# Note: These are for Gentoo Linux use ONLY. For your own distribution, please
-		# get your own set of keys.
-		if [[ -z "${MOZ_API_KEY_MOZILLA+set}" ]] ; then
-			MOZ_API_KEY_MOZILLA="edb3d487-3a84-46m0ap1e3-9dfd-92b5efaaa005"
-		fi
-
-		# Ensure we use C locale when building, bug #746215
-		export LC_ALL=C
-	fi
-
-	CONFIG_CHECK="~SECCOMP"
-	WARNING_SECCOMP="CONFIG_SECCOMP not set! This system will be unable to play DRM-protected content."
-	linux-info_pkg_setup
-}
-
-src_unpack() {
-	local _lp_dir="${WORKDIR}/language_packs"
-	local _src_file
-
-	if [[ ! -d "${_lp_dir}" ]] ; then
-		mkdir "${_lp_dir}" || die
-	fi
-
-	for _src_file in ${A} ; do
-		if [[ ${_src_file} == *.xpi ]]; then
-			cp "${DISTDIR}/${_src_file}" "${_lp_dir}" || die "Failed to copy '${_src_file}' to '${_lp_dir}'!"
-		else
-			unpack ${_src_file}
-		fi
-	done
-}
-
-src_prepare() {
-	use lto && rm -v "${WORKDIR}"/firefox-patches/*-LTO-Only-enable-LTO-*.patch
-	eapply "${WORKDIR}/firefox-patches"
-	# riscv support from https://github.com/makotokato/gecko-dev
-	eapply "${FILESDIR}/firefox-riscv64-support.patch"
-	# disable cargo-vet check in order to do ./mach vendor rust
-	# https://bugzilla.mozilla.org/show_bug.cgi?id=1787601
-	# skip check_macroassembler_style.py
-	eapply "${FILESDIR}/firefox-riscv64-hack.patch"
-
-	# Allow user to apply any additional patches without modifing ebuild
-	eapply_user
-
-	# Make cargo respect MAKEOPTS
-	export CARGO_BUILD_JOBS="$(makeopts_jobs)"
-
-	# Make LTO respect MAKEOPTS
-	sed -i \
-		-e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \
-		"${S}"/build/moz.configure/lto-pgo.configure \
-		|| die "sed failed to set num_cores"
-
-	# Make ICU respect MAKEOPTS
-	sed -i \
-		-e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \
-		"${S}"/intl/icu_sources_data.py \
-		|| die "sed failed to set num_cores"
-
-	# sed-in toolchain prefix
-	sed -i \
-		-e "s/objdump/${CHOST}-objdump/" \
-		"${S}"/python/mozbuild/mozbuild/configure/check_debug_ranges.py \
-		|| die "sed failed to set toolchain prefix"
-
-	sed -i \
-		-e 's/ccache_stats = None/return None/' \
-		"${S}"/python/mozbuild/mozbuild/controller/building.py \
-		|| die "sed failed to disable ccache stats call"
-
-	einfo "Removing pre-built binaries ..."
-	find "${S}"/third_party -type f \( -name '*.so' -o -name '*.o' \) -print -delete || die
-
-	# Clearing checksums where we have applied patches
-	moz_clear_vendor_checksums audioipc
-	moz_clear_vendor_checksums audioipc-client
-	moz_clear_vendor_checksums audioipc-server
-
-	# Create build dir
-	BUILD_DIR="${WORKDIR}/${PN}_build"
-	mkdir -p "${BUILD_DIR}" || die
-
-	# Write API keys to disk
-	echo -n "${MOZ_API_KEY_GOOGLE//gGaPi/}" > "${S}"/api-google.key || die
-	echo -n "${MOZ_API_KEY_LOCATION//gGaPi/}" > "${S}"/api-location.key || die
-	echo -n "${MOZ_API_KEY_MOZILLA//m0ap1/}" > "${S}"/api-mozilla.key || die
-
-	xdg_environment_reset
-}
-
-src_configure() {
-	# Show flags set at the beginning
-	einfo "Current BINDGEN_CFLAGS:\t${BINDGEN_CFLAGS:-no value set}"
-	einfo "Current CFLAGS:\t\t${CFLAGS:-no value set}"
-	einfo "Current CXXFLAGS:\t\t${CXXFLAGS:-no value set}"
-	einfo "Current LDFLAGS:\t\t${LDFLAGS:-no value set}"
-	einfo "Current RUSTFLAGS:\t\t${RUSTFLAGS:-no value set}"
-
-	local have_switched_compiler=
-	if use clang && ! tc-is-clang ; then
-		# Force clang
-		einfo "Enforcing the use of clang due to USE=clang ..."
-		have_switched_compiler=yes
-		AR=llvm-ar
-		AS=llvm-as
-		CC=${CHOST}-clang
-		CXX=${CHOST}-clang++
-		NM=llvm-nm
-		RANLIB=llvm-ranlib
-	elif ! use clang && ! tc-is-gcc ; then
-		# Force gcc
-		have_switched_compiler=yes
-		einfo "Enforcing the use of gcc due to USE=-clang ..."
-		AR=gcc-ar
-		CC=${CHOST}-gcc
-		CXX=${CHOST}-g++
-		NM=gcc-nm
-		RANLIB=gcc-ranlib
-	fi
-
-	if [[ -n "${have_switched_compiler}" ]] ; then
-		# Because we switched active compiler we have to ensure
-		# that no unsupported flags are set
-		strip-unsupported-flags
-	fi
-
-	# Ensure we use correct toolchain
-	export HOST_CC="$(tc-getBUILD_CC)"
-	export HOST_CXX="$(tc-getBUILD_CXX)"
-	tc-export CC CXX LD AR NM OBJDUMP RANLIB PKG_CONFIG
-
-	# Pass the correct toolchain paths through cbindgen
-	if tc-is-cross-compiler ; then
-		export BINDGEN_CFLAGS="${SYSROOT:+--sysroot=${ESYSROOT}} --target=${CHOST} ${BINDGEN_CFLAGS-}"
-	fi
-
-	# Set MOZILLA_FIVE_HOME
-	export MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}"
-
-	# python/mach/mach/mixin/process.py fails to detect SHELL
-	export SHELL="${EPREFIX}/bin/bash"
-
-	# Set state path
-	export MOZBUILD_STATE_PATH="${BUILD_DIR}"
-
-	# Set MOZCONFIG
-	export MOZCONFIG="${S}/.mozconfig"
-
-	# Initialize MOZCONFIG
-	mozconfig_add_options_ac '' --enable-application=browser
-
-	# Set Gentoo defaults
-	export MOZILLA_OFFICIAL=1
-
-	mozconfig_add_options_ac 'Gentoo default' \
-		--allow-addon-sideload \
-		--disable-cargo-incremental \
-		--disable-crashreporter \
-		--disable-gpsd \
-		--disable-install-strip \
-		--disable-parental-controls \
-		--disable-strip \
-		--disable-updater \
-		--enable-negotiateauth \
-		--enable-new-pass-manager \
-		--enable-official-branding \
-		--enable-release \
-		--enable-system-ffi \
-		--enable-system-pixman \
-		--host="${CBUILD:-${CHOST}}" \
-		--libdir="${EPREFIX}/usr/$(get_libdir)" \
-		--prefix="${EPREFIX}/usr" \
-		--target="${CHOST}" \
-		--without-ccache \
-		--without-wasm-sandboxed-libraries \
-		--with-intl-api \
-		--with-libclang-path="$(llvm-config --libdir)" \
-		--with-system-nspr \
-		--with-system-nss \
-		--with-system-zlib \
-		--with-toolchain-prefix="${CHOST}-" \
-		--with-unsigned-addon-scopes=app,system \
-		--x-includes="${ESYSROOT}/usr/include" \
-		--x-libraries="${ESYSROOT}/usr/$(get_libdir)"
-
-	# Set update channel
-	local update_channel=release
-	[[ -n ${MOZ_ESR} ]] && update_channel=esr
-	mozconfig_add_options_ac '' --update-channel=${update_channel}
-
-	if ! use x86 && [[ ${CHOST} != armv*h* ]] ; then
-		mozconfig_add_options_ac '' --enable-rust-simd
-	fi
-
-	# For future keywording: This is currently (97.0) only supported on:
-	# amd64, arm, arm64 & x86.
-	# Might want to flip the logic around if Firefox is to support more arches.
-	if use ppc64 || use riscv; then
-		mozconfig_add_options_ac '' --disable-sandbox
-	else
-		mozconfig_add_options_ac '' --enable-sandbox
-	fi
-	if use riscv; then
-		mozconfig_add_options_ac '' --disable-jit
-	fi
-
-	if [[ -s "${S}/api-google.key" ]] ; then
-		local key_origin="Gentoo default"
-		if [[ $(cat "${S}/api-google.key" | md5sum | awk '{ print $1 }') != 709560c02f94b41f9ad2c49207be6c54 ]] ; then
-			key_origin="User value"
-		fi
-
-		mozconfig_add_options_ac "${key_origin}" \
-			--with-google-safebrowsing-api-keyfile="${S}/api-google.key"
-	else
-		einfo "Building without Google API key ..."
-	fi
-
-	if [[ -s "${S}/api-location.key" ]] ; then
-		local key_origin="Gentoo default"
-		if [[ $(cat "${S}/api-location.key" | md5sum | awk '{ print $1 }') != ffb7895e35dedf832eb1c5d420ac7420 ]] ; then
-			key_origin="User value"
-		fi
-
-		mozconfig_add_options_ac "${key_origin}" \
-			--with-google-location-service-api-keyfile="${S}/api-location.key"
-	else
-		einfo "Building without Location API key ..."
-	fi
-
-	if [[ -s "${S}/api-mozilla.key" ]] ; then
-		local key_origin="Gentoo default"
-		if [[ $(cat "${S}/api-mozilla.key" | md5sum | awk '{ print $1 }') != 3927726e9442a8e8fa0e46ccc39caa27 ]] ; then
-			key_origin="User value"
-		fi
-
-		mozconfig_add_options_ac "${key_origin}" \
-			--with-mozilla-api-keyfile="${S}/api-mozilla.key"
-	else
-		einfo "Building without Mozilla API key ..."
-	fi
-
-	mozconfig_use_with system-av1
-	mozconfig_use_with system-harfbuzz
-	mozconfig_use_with system-harfbuzz system-graphite2
-	mozconfig_use_with system-icu
-	mozconfig_use_with system-jpeg
-	mozconfig_use_with system-libevent
-	mozconfig_use_with system-libvpx
-	mozconfig_use_with system-png
-	mozconfig_use_with system-webp
-
-	mozconfig_use_enable dbus
-	mozconfig_use_enable libproxy
-
-	use eme-free && mozconfig_add_options_ac '+eme-free' --disable-eme
-
-	mozconfig_use_enable geckodriver
-
-	if use hardened ; then
-		mozconfig_add_options_ac "+hardened" --enable-hardening
-		append-ldflags "-Wl,-z,relro -Wl,-z,now"
-	fi
-
-	local myaudiobackends=""
-	use jack && myaudiobackends+="jack,"
-	use sndio && myaudiobackends+="sndio,"
-	use pulseaudio && myaudiobackends+="pulseaudio,"
-	! use pulseaudio && myaudiobackends+="alsa,"
-
-	mozconfig_add_options_ac '--enable-audio-backends' --enable-audio-backends="${myaudiobackends::-1}"
-
-	mozconfig_use_enable wifi necko-wifi
-
-	if use X && use wayland ; then
-		mozconfig_add_options_ac '+x11+wayland' --enable-default-toolkit=cairo-gtk3-x11-wayland
-	elif ! use X && use wayland ; then
-		mozconfig_add_options_ac '+wayland' --enable-default-toolkit=cairo-gtk3-wayland-only
-	else
-		mozconfig_add_options_ac '+x11' --enable-default-toolkit=cairo-gtk3
-	fi
-
-	if use lto ; then
-		if use clang ; then
-			# Upstream only supports lld when using clang
-			mozconfig_add_options_ac "forcing ld=lld due to USE=clang and USE=lto" --enable-linker=lld
-
-			mozconfig_add_options_ac '+lto' --enable-lto=cross
-
-		else
-			# ThinLTO is currently broken, see bmo#1644409
-			mozconfig_add_options_ac '+lto' --enable-lto=full
-			mozconfig_add_options_ac "linker is set to bfd" --enable-linker=bfd
-		fi
-
-		if use pgo ; then
-			mozconfig_add_options_ac '+pgo' MOZ_PGO=1
-
-			if use clang ; then
-				# Used in build/pgo/profileserver.py
-				export LLVM_PROFDATA="llvm-profdata"
-			fi
-		fi
-	else
-		# Avoid auto-magic on linker
-		if use clang ; then
-			# This is upstream's default
-			mozconfig_add_options_ac "forcing ld=lld due to USE=clang" --enable-linker=lld
-		else
-			mozconfig_add_options_ac "linker is set to bfd" --enable-linker=bfd
-		fi
-	fi
-
-	# LTO flag was handled via configure
-	filter-flags '-flto*'
-
-	mozconfig_use_enable debug
-	if use debug ; then
-		mozconfig_add_options_ac '+debug' --disable-optimize
-	else
-		if is-flag '-g*' ; then
-			if use clang ; then
-				mozconfig_add_options_ac 'from CFLAGS' --enable-debug-symbols=$(get-flag '-g*')
-			else
-				mozconfig_add_options_ac 'from CFLAGS' --enable-debug-symbols
-			fi
-		else
-			mozconfig_add_options_ac 'Gentoo default' --disable-debug-symbols
-		fi
-
-		if is-flag '-O0' ; then
-			mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O0
-		elif is-flag '-O4' ; then
-			mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O4
-		elif is-flag '-O3' ; then
-			mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O3
-		elif is-flag '-O1' ; then
-			mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-O1
-		elif is-flag '-Os' ; then
-			mozconfig_add_options_ac "from CFLAGS" --enable-optimize=-Os
-		else
-			mozconfig_add_options_ac "Gentoo default" --enable-optimize=-O2
-		fi
-	fi
-
-	# Debug flag was handled via configure
-	filter-flags '-g*'
-
-	# Optimization flag was handled via configure
-	filter-flags '-O*'
-
-	# Modifications to better support ARM, bug #553364
-	if use cpu_flags_arm_neon ; then
-		mozconfig_add_options_ac '+cpu_flags_arm_neon' --with-fpu=neon
-
-		if ! tc-is-clang ; then
-			# thumb options aren't supported when using clang, bug 666966
-			mozconfig_add_options_ac '+cpu_flags_arm_neon' \
-				--with-thumb=yes \
-				--with-thumb-interwork=no
-		fi
-	fi
-
-	if [[ ${CHOST} == armv*h* ]] ; then
-		mozconfig_add_options_ac 'CHOST=armv*h*' --with-float-abi=hard
-
-		if ! use system-libvpx ; then
-			sed -i \
-				-e "s|softfp|hard|" \
-				"${S}"/media/libvpx/moz.build \
-				|| die
-		fi
-	fi
-
-	if use clang ; then
-		# https://bugzilla.mozilla.org/show_bug.cgi?id=1482204
-		# https://bugzilla.mozilla.org/show_bug.cgi?id=1483822
-		# toolkit/moz.configure Elfhack section: target.cpu in ('arm', 'x86', 'x86_64')
-		local disable_elf_hack=
-		if use amd64 ; then
-			disable_elf_hack=yes
-		elif use x86 ; then
-			disable_elf_hack=yes
-		elif use arm ; then
-			disable_elf_hack=yes
-		fi
-
-		if [[ -n ${disable_elf_hack} ]] ; then
-			mozconfig_add_options_ac 'elf-hack is broken when using Clang' --disable-elf-hack
-		fi
-	elif tc-is-gcc ; then
-		if ver_test $(gcc-fullversion) -ge 10 ; then
-			einfo "Forcing -fno-tree-loop-vectorize to workaround GCC bug, see bug 758446 ..."
-			append-cxxflags -fno-tree-loop-vectorize
-		fi
-	fi
-
-	# Additional ARCH support
-	case "${ARCH}" in
-		arm)
-			# Reduce the memory requirements for linking
-			if use clang ; then
-				# Nothing to do
-				:;
-			elif use lto ; then
-				append-ldflags -Wl,--no-keep-memory
-			else
-				append-ldflags -Wl,--no-keep-memory -Wl,--reduce-memory-overheads
-			fi
-			;;
-	esac
-
-	if ! use elibc_glibc ; then
-		mozconfig_add_options_ac '!elibc_glibc' --disable-jemalloc
-	fi
-
-	# Allow elfhack to work in combination with unstripped binaries
-	# when they would normally be larger than 2GiB.
-	append-ldflags "-Wl,--compress-debug-sections=zlib"
-
-	# Make revdep-rebuild.sh happy; Also required for musl
-	append-ldflags -Wl,-rpath="${MOZILLA_FIVE_HOME}",--enable-new-dtags
-
-	# Pass $MAKEOPTS to build system
-	export MOZ_MAKE_FLAGS="${MAKEOPTS}"
-
-	# Use system's Python environment
-	PIP_NETWORK_INSTALL_RESTRICTED_VIRTUALENVS=mach
-
-	if use system-python-libs; then
-		export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE="system"
-	else
-		export MACH_BUILD_PYTHON_NATIVE_PACKAGE_SOURCE="none"
-	fi
-
-	# Disable notification when build system has finished
-	export MOZ_NOSPAM=1
-
-	# Portage sets XARGS environment variable to "xargs -r" by default which
-	# breaks build system's check_prog() function which doesn't support arguments
-	mozconfig_add_options_ac 'Gentoo default' "XARGS=${EPREFIX}/usr/bin/xargs"
-
-	# Set build dir
-	mozconfig_add_options_mk 'Gentoo default' "MOZ_OBJDIR=${BUILD_DIR}"
-
-	# Show flags we will use
-	einfo "Build BINDGEN_CFLAGS:\t${BINDGEN_CFLAGS:-no value set}"
-	einfo "Build CFLAGS:\t\t${CFLAGS:-no value set}"
-	einfo "Build CXXFLAGS:\t\t${CXXFLAGS:-no value set}"
-	einfo "Build LDFLAGS:\t\t${LDFLAGS:-no value set}"
-	einfo "Build RUSTFLAGS:\t\t${RUSTFLAGS:-no value set}"
-
-	# Handle EXTRA_CONF and show summary
-	local ac opt hash reason
-
-	# Apply EXTRA_ECONF entries to $MOZCONFIG
-	if [[ -n ${EXTRA_ECONF} ]] ; then
-		IFS=\! read -a ac <<<${EXTRA_ECONF// --/\!}
-		for opt in "${ac[@]}"; do
-			mozconfig_add_options_ac "EXTRA_ECONF" --${opt#--}
-		done
-	fi
-
-	echo
-	echo "=========================================================="
-	echo "Building ${PF} with the following configuration"
-	grep ^ac_add_options "${MOZCONFIG}" | while read ac opt hash reason; do
-		[[ -z ${hash} || ${hash} == \# ]] \
-			|| die "error reading mozconfig: ${ac} ${opt} ${hash} ${reason}"
-		printf "    %-30s  %s\n" "${opt}" "${reason:-mozilla.org default}"
-	done
-	echo "=========================================================="
-	echo
-
-	# To avoid huge patches of rust library (~200MB), we have to download on the fly
-	einfo "riscv overlay: Performing ./mach vendor rust to update third party libs"
-	./mach vendor rust --ignore-modified || die
-	./mach configure || die
-}
-
-src_compile() {
-	local virtx_cmd=
-
-	if use pgo ; then
-		virtx_cmd=virtx
-
-		# Reset and cleanup environment variables used by GNOME/XDG
-		gnome2_environment_reset
-
-		addpredict /root
-	fi
-
-	if ! use X && use wayland; then
-		local -x GDK_BACKEND=wayland
-	else
-		local -x GDK_BACKEND=x11
-	fi
-
-	${virtx_cmd} ./mach build --verbose \
-		|| die
-}
-
-src_install() {
-	# xpcshell is getting called during install
-	pax-mark m \
-		"${BUILD_DIR}"/dist/bin/xpcshell \
-		"${BUILD_DIR}"/dist/bin/${PN} \
-		"${BUILD_DIR}"/dist/bin/plugin-container
-
-	DESTDIR="${D}" ./mach install || die
-
-	# Upstream cannot ship symlink but we can (bmo#658850)
-	rm "${ED}${MOZILLA_FIVE_HOME}/${PN}-bin" || die
-	dosym ${PN} ${MOZILLA_FIVE_HOME}/${PN}-bin
-
-	# Don't install llvm-symbolizer from sys-devel/llvm package
-	if [[ -f "${ED}${MOZILLA_FIVE_HOME}/llvm-symbolizer" ]] ; then
-		rm -v "${ED}${MOZILLA_FIVE_HOME}/llvm-symbolizer" || die
-	fi
-
-	# Install policy (currently only used to disable application updates)
-	insinto "${MOZILLA_FIVE_HOME}/distribution"
-	newins "${FILESDIR}"/distribution.ini distribution.ini
-	newins "${FILESDIR}"/disable-auto-update.policy.json policies.json
-
-	# Install system-wide preferences
-	local PREFS_DIR="${MOZILLA_FIVE_HOME}/browser/defaults/preferences"
-	insinto "${PREFS_DIR}"
-	newins "${FILESDIR}"/gentoo-default-prefs.js gentoo-prefs.js
-
-	local GENTOO_PREFS="${ED}${PREFS_DIR}/gentoo-prefs.js"
-
-	# Set dictionary path to use system hunspell
-	cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set spellchecker.dictionary_path pref"
-	pref("spellchecker.dictionary_path",       "${EPREFIX}/usr/share/myspell");
-	EOF
-
-	# Force hwaccel prefs if USE=hwaccel is enabled
-	if use hwaccel ; then
-		cat "${FILESDIR}"/gentoo-hwaccel-prefs.js-r2 \
-		>>"${GENTOO_PREFS}" \
-		|| die "failed to add prefs to force hardware-accelerated rendering to all-gentoo.js"
-
-		if use wayland; then
-			cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set hwaccel wayland prefs"
-			pref("gfx.x11-egl.force-enabled",          false);
-			EOF
-		else
-			cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set hwaccel x11 prefs"
-			pref("gfx.x11-egl.force-enabled",          true);
-			EOF
-		fi
-	fi
-
-	if ! use gmp-autoupdate ; then
-		local plugin
-		for plugin in "${MOZ_GMP_PLUGIN_LIST[@]}" ; do
-			einfo "Disabling auto-update for ${plugin} plugin ..."
-			cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to disable autoupdate for ${plugin} media plugin"
-			pref("media.${plugin}.autoupdate",   false);
-			EOF
-		done
-	fi
-
-	# Force the graphite pref if USE=system-harfbuzz is enabled, since the pref cannot disable it
-	if use system-harfbuzz ; then
-		cat >>"${GENTOO_PREFS}" <<-EOF || die "failed to set gfx.font_rendering.graphite.enabled pref"
-		sticky_pref("gfx.font_rendering.graphite.enabled", true);
-		EOF
-	fi
-
-	# Install language packs
-	local langpacks=( $(find "${WORKDIR}/language_packs" -type f -name '*.xpi') )
-	if [[ -n "${langpacks}" ]] ; then
-		moz_install_xpi "${MOZILLA_FIVE_HOME}/distribution/extensions" "${langpacks[@]}"
-	fi
-
-	# Install geckodriver
-	if use geckodriver ; then
-		einfo "Installing geckodriver into ${ED}${MOZILLA_FIVE_HOME} ..."
-		pax-mark m "${BUILD_DIR}"/dist/bin/geckodriver
-		exeinto "${MOZILLA_FIVE_HOME}"
-		doexe "${BUILD_DIR}"/dist/bin/geckodriver
-
-		dosym ${MOZILLA_FIVE_HOME}/geckodriver /usr/bin/geckodriver
-	fi
-
-	# Install icons
-	local icon_srcdir="${S}/browser/branding/official"
-	local icon_symbolic_file="${FILESDIR}/icon/firefox-symbolic.svg"
-
-	insinto /usr/share/icons/hicolor/symbolic/apps
-	newins "${icon_symbolic_file}" ${PN}-symbolic.svg
-
-	local icon size
-	for icon in "${icon_srcdir}"/default*.png ; do
-		size=${icon%.png}
-		size=${size##*/default}
-
-		if [[ ${size} -eq 48 ]] ; then
-			newicon "${icon}" ${PN}.png
-		fi
-
-		newicon -s ${size} "${icon}" ${PN}.png
-	done
-
-	# Install menu
-	local app_name="Mozilla ${MOZ_PN^}"
-	local desktop_file="${FILESDIR}/icon/${PN}-r3.desktop"
-	local desktop_filename="${PN}.desktop"
-	local exec_command="${PN}"
-	local icon="${PN}"
-	local use_wayland="false"
-
-	if use wayland ; then
-		use_wayland="true"
-	fi
-
-	cp "${desktop_file}" "${WORKDIR}/${PN}.desktop-template" || die
-
-	sed -i \
-		-e "s:@NAME@:${app_name}:" \
-		-e "s:@EXEC@:${exec_command}:" \
-		-e "s:@ICON@:${icon}:" \
-		"${WORKDIR}/${PN}.desktop-template" \
-		|| die
-
-	newmenu "${WORKDIR}/${PN}.desktop-template" "${desktop_filename}"
-
-	rm "${WORKDIR}/${PN}.desktop-template" || die
-
-	# Install wrapper script
-	[[ -f "${ED}/usr/bin/${PN}" ]] && rm "${ED}/usr/bin/${PN}"
-	newbin "${FILESDIR}/${PN}-r1.sh" ${PN}
-
-	# Update wrapper
-	sed -i \
-		-e "s:@PREFIX@:${EPREFIX}/usr:" \
-		-e "s:@MOZ_FIVE_HOME@:${MOZILLA_FIVE_HOME}:" \
-		-e "s:@APULSELIB_DIR@:${apulselib}:" \
-		-e "s:@DEFAULT_WAYLAND@:${use_wayland}:" \
-		"${ED}/usr/bin/${PN}" \
-		|| die
-}
-
-pkg_preinst() {
-	xdg_pkg_preinst
-
-	# If the apulse libs are available in MOZILLA_FIVE_HOME then apulse
-	# does not need to be forced into the LD_LIBRARY_PATH
-	if use pulseaudio && has_version ">=media-sound/apulse-0.1.12-r4" ; then
-		einfo "APULSE found; Generating library symlinks for sound support ..."
-		local lib
-		pushd "${ED}${MOZILLA_FIVE_HOME}" &>/dev/null || die
-		for lib in ../apulse/libpulse{.so{,.0},-simple.so{,.0}} ; do
-			# A quickpkg rolled by hand will grab symlinks as part of the package,
-			# so we need to avoid creating them if they already exist.
-			if [[ ! -L ${lib##*/} ]] ; then
-				ln -s "${lib}" ${lib##*/} || die
-			fi
-		done
-		popd &>/dev/null || die
-	fi
-}
-
-pkg_postinst() {
-	xdg_pkg_postinst
-
-	if ! use gmp-autoupdate ; then
-		elog "USE='-gmp-autoupdate' has disabled the following plugins from updating or"
-		elog "installing into new profiles:"
-		local plugin
-		for plugin in "${MOZ_GMP_PLUGIN_LIST[@]}" ; do
-			elog "\t ${plugin}"
-		done
-		elog
-	fi
-
-	if use pulseaudio && has_version ">=media-sound/apulse-0.1.12-r4" ; then
-		elog "Apulse was detected at merge time on this system and so it will always be"
-		elog "used for sound.  If you wish to use pulseaudio instead please unmerge"
-		elog "media-sound/apulse."
-		elog
-	fi
-
-	local show_doh_information
-	local show_normandy_information
-	local show_shortcut_information
-
-	if [[ -z "${REPLACING_VERSIONS}" ]] ; then
-		# New install; Tell user that DoH is disabled by default
-		show_doh_information=yes
-		show_normandy_information=yes
-		show_shortcut_information=no
-	else
-		local replacing_version
-		for replacing_version in ${REPLACING_VERSIONS} ; do
-			if ver_test "${replacing_version}" -lt 91.0 ; then
-				# Tell user that we no longer install a shortcut
-				# per supported display protocol
-				show_shortcut_information=yes
-			fi
-		done
-	fi
-
-	if [[ -n "${show_doh_information}" ]] ; then
-		elog
-		elog "Note regarding Trusted Recursive Resolver aka DNS-over-HTTPS (DoH):"
-		elog "Due to privacy concerns (encrypting DNS might be a good thing, sending all"
-		elog "DNS traffic to Cloudflare by default is not a good idea and applications"
-		elog "should respect OS configured settings), \"network.trr.mode\" was set to 5"
-		elog "(\"Off by choice\") by default."
-		elog "You can enable DNS-over-HTTPS in ${PN^}'s preferences."
-	fi
-
-	# bug 713782
-	if [[ -n "${show_normandy_information}" ]] ; then
-		elog
-		elog "Upstream operates a service named Normandy which allows Mozilla to"
-		elog "push changes for default settings or even install new add-ons remotely."
-		elog "While this can be useful to address problems like 'Armagadd-on 2.0' or"
-		elog "revert previous decisions to disable TLS 1.0/1.1, privacy and security"
-		elog "concerns prevail, which is why we have switched off the use of this"
-		elog "service by default."
-		elog
-		elog "To re-enable this service set"
-		elog
-		elog "    app.normandy.enabled=true"
-		elog
-		elog "in about:config."
-	fi
-
-	if [[ -n "${show_shortcut_information}" ]] ; then
-		elog
-		elog "Since ${PN}-91.0 we no longer install multiple shortcuts for"
-		elog "each supported display protocol.  Instead we will only install"
-		elog "one generic Mozilla ${PN^} shortcut."
-		elog "If you still want to be able to select between running Mozilla ${PN^}"
-		elog "on X11 or Wayland, you have to re-create these shortcuts on your own."
-	fi
-
-	# bug 835078
-	if use hwaccel && has_version "x11-drivers/xf86-video-nouveau"; then
-		ewarn "You have nouveau drivers installed in your system and 'hwaccel' "
-		ewarn "enabled for Firefox. Nouveau / your GPU might not support the "
-		ewarn "required EGL, so either disable 'hwaccel' or try the workaround "
-		ewarn "explained in https://bugs.gentoo.org/835078#c5 if Firefox crashes."
-	fi
-
-	elog
-	elog "Unfortunately Firefox-100.0 breaks compatibility with some sites using "
-	elog "useragent checks. To temporarily fix this, enter about:config and modify "
-	elog "network.http.useragent.forceVersion preference to \"99\"."
-	elog "Or install an addon to change your useragent."
-	elog "See: https://support.mozilla.org/en-US/kb/difficulties-opening-or-using-website-firefox-100"
-	elog
-}

diff --git a/www-client/firefox/metadata.xml b/www-client/firefox/metadata.xml
deleted file mode 100644
index ac687a3..0000000
--- a/www-client/firefox/metadata.xml
+++ /dev/null
@@ -1,40 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
-<pkgmetadata>
-<maintainer type="project">
-	<email>mozilla@gentoo.org</email>
-	<name>Gentoo Mozilla Team</name>
-</maintainer>
-<use>
-	<flag name="clang">Use Clang compiler instead of GCC</flag>
-	<flag name="eme-free">Disable EME (DRM plugin) cabability at build time</flag>
-	<flag name="geckodriver">Enable WebDriver support</flag>
-	<flag name="gmp-autoupdate">Allow Gecko Media Plugins (binary blobs) to be automatically
-		downloaded and kept up-to-date in user profiles</flag>
-	<flag name="hwaccel">Force-enable hardware-accelerated rendering (Mozilla bug 594876)</flag>
-	<flag name="lto">Enable Link Time Optimization (LTO). Requires Gold linker when using GCC
-		or LDD linker when using Clang</flag>
-	<flag name="openh264">Use <pkg>media-libs/openh264</pkg> for H.264 support
-		instead of downloading binary blob from Mozilla at runtime</flag>
-	<flag name="pgo">Add support for profile-guided optimization using gcc-4.5,
-		for faster binaries. This option will double the compile time.</flag>
-	<flag name="screencast">Enable support for remote desktop and screen cast using <pkg>media-video/pipewire</pkg></flag>
-	<flag name="sndio">Enable support for the <pkg>media-sound/sndio</pkg> backend</flag>
-	<flag name="system-av1">Use the system-wide <pkg>media-libs/dav1d</pkg>
-		and <pkg>media-libs/libaom</pkg> library instead of bundled.</flag>
-	<flag name="system-harfbuzz">Use the system-wide <pkg>media-libs/harfbuzz</pkg>
-		and <pkg>media-gfx/graphite2</pkg> instead of bundled.</flag>
-	<flag name="system-icu">Use the system-wide <pkg>dev-libs/icu</pkg>
-		instead of bundled.</flag>
-	<flag name="system-jpeg">Use the system-wide <pkg>media-libs/libjpeg-turbo</pkg>
-		instead of bundled.</flag>
-	<flag name="system-libevent">Use the system-wide <pkg>dev-libs/libevent</pkg>
-		instead of bundled.</flag>
-	<flag name="system-libvpx">Use the system-wide <pkg>media-libs/libvpx</pkg>
-		instead of bundled.</flag>
-	<flag name="system-png">Use the system-wide <pkg>media-libs/libpng</pkg>
-		instead of bundled (requires APNG patches).</flag>
-	<flag name="system-webp">Use the system-wide <pkg>media-libs/libwebp</pkg>
-		instead of bundled.</flag>
-</use>
-</pkgmetadata>


             reply	other threads:[~2023-04-08 21:16 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-04-08 21:16 Yixun Lan [this message]
  -- strict thread matches above, loose matches on Subject: below --
2021-12-20  2:14 [gentoo-commits] proj/riscv:master commit in: www-client/firefox/files/icon/, www-client/firefox/files/, www-client/firefox/ Yixun Lan

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1680988529.3a343ba4c4c05e9f1e9721480c4542f64a6e9ace.dlan@gentoo \
    --to=dlan@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox