mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-25 16:24:46 +00:00
Auto merge of #132526 - bjorn3:sync_cg_clif-2024-11-02, r=bjorn3
Subtree sync for rustc_codegen_cranelift The highlight this time is an update to Cranelift 0.113, r? `@ghost` `@rustbot` label +A-codegen +A-cranelift +T-compiler
This commit is contained in:
commit
89ab6559cc
@ -1,6 +1,6 @@
|
|||||||
# This file is automatically @generated by Cargo.
|
# This file is automatically @generated by Cargo.
|
||||||
# It is not intended for manual editing.
|
# It is not intended for manual editing.
|
||||||
version = 3
|
version = 4
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ahash"
|
name = "ahash"
|
||||||
@ -46,24 +46,24 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-bforest"
|
name = "cranelift-bforest"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b80c3a50b9c4c7e5b5f73c0ed746687774fc9e36ef652b110da8daebf0c6e0e6"
|
checksum = "8ea5e7afe85cadb55c4c1176268a2ac046fdff8dfaeca39e18581b9dc319ca9e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cranelift-entity",
|
"cranelift-entity",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-bitset"
|
name = "cranelift-bitset"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "38778758c2ca918b05acb2199134e0c561fb577c50574259b26190b6c2d95ded"
|
checksum = "8ab25ef3be935a80680e393183e1f94ef507e93a24a8369494d2c6818aedb3e3"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-codegen"
|
name = "cranelift-codegen"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "58258667ad10e468bfc13a8d620f50dfcd4bb35d668123e97defa2549b9ad397"
|
checksum = "900a19b84545924f1851cbfe386962edfc4ecbc3366a254825cf1ecbcda8ba08"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bumpalo",
|
"bumpalo",
|
||||||
"cranelift-bforest",
|
"cranelift-bforest",
|
||||||
@ -74,7 +74,7 @@ dependencies = [
|
|||||||
"cranelift-entity",
|
"cranelift-entity",
|
||||||
"cranelift-isle",
|
"cranelift-isle",
|
||||||
"gimli",
|
"gimli",
|
||||||
"hashbrown 0.14.5",
|
"hashbrown",
|
||||||
"log",
|
"log",
|
||||||
"regalloc2",
|
"regalloc2",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
@ -84,42 +84,42 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-codegen-meta"
|
name = "cranelift-codegen-meta"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "043f0b702e529dcb07ff92bd7d40e7d5317b5493595172c5eb0983343751ee06"
|
checksum = "08c73b2395ffe9e7b4fdf7e2ebc052e7e27af13f68a964985346be4da477a5fc"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cranelift-codegen-shared",
|
"cranelift-codegen-shared",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-codegen-shared"
|
name = "cranelift-codegen-shared"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7763578888ab53eca5ce7da141953f828e82c2bfadcffc106d10d1866094ffbb"
|
checksum = "7d9ed0854e96a4ff0879bff39d078de8dea7f002721c9494c1fdb4e1baa86ccc"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-control"
|
name = "cranelift-control"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "32db15f08c05df570f11e8ab33cb1ec449a64b37c8a3498377b77650bef33d8b"
|
checksum = "b4aca921dd422e781409de0129c255768fec5dec1dae83239b497fb9138abb89"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"arbitrary",
|
"arbitrary",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-entity"
|
name = "cranelift-entity"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5289cdb399381a27e7bbfa1b42185916007c3d49aeef70b1d01cb4caa8010130"
|
checksum = "e2d770e6605eccee15b49decdd82cd26f2b6404767802471459ea49c57379a98"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cranelift-bitset",
|
"cranelift-bitset",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-frontend"
|
name = "cranelift-frontend"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "31ba8ab24eb9470477e98ddfa3c799a649ac5a0d9a2042868c4c952133c234e8"
|
checksum = "29268711cb889cb39215b10faf88b9087d4c9e1d2633581e4f722a2bf4bb4ef9"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cranelift-codegen",
|
"cranelift-codegen",
|
||||||
"log",
|
"log",
|
||||||
@ -129,15 +129,15 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-isle"
|
name = "cranelift-isle"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "2b72a3c5c166a70426dcb209bdd0bb71a787c1ea76023dc0974fbabca770e8f9"
|
checksum = "dc65156f010aed1985767ad1bff0eb8d186743b7b03e23d0c17604a253e3f356"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-jit"
|
name = "cranelift-jit"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "df32578a47582e49b4fc1f9a5786839d9be1fedaa9f00bea7612c54425663c6b"
|
checksum = "40ba6b46367a4f466cfb1abe32793fa1a0f96d862251491b01a44726b8ed9445"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"cranelift-codegen",
|
"cranelift-codegen",
|
||||||
@ -150,14 +150,14 @@ dependencies = [
|
|||||||
"region",
|
"region",
|
||||||
"target-lexicon",
|
"target-lexicon",
|
||||||
"wasmtime-jit-icache-coherence",
|
"wasmtime-jit-icache-coherence",
|
||||||
"windows-sys",
|
"windows-sys 0.59.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-module"
|
name = "cranelift-module"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "96094a758cdb543c9143f70817cd31069fecd49f50981a0fac06820ac011dc2f"
|
checksum = "007607022a4883ebdffc46c0925e2e10babf2a565ae78518034ade722aa825d2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"cranelift-codegen",
|
"cranelift-codegen",
|
||||||
@ -166,9 +166,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-native"
|
name = "cranelift-native"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "46a42424c956bbc31fc5c2706073df896156c5420ae8fa2a5d48dbc7b295d71b"
|
checksum = "d8bf9b361eaf5a7627647270fabf1dc910d993edbeaf272a652c107861ebe9c2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cranelift-codegen",
|
"cranelift-codegen",
|
||||||
"libc",
|
"libc",
|
||||||
@ -177,9 +177,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cranelift-object"
|
name = "cranelift-object"
|
||||||
version = "0.111.0"
|
version = "0.113.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "1cf5e2484ab47fe38a3150747cdd2016535f13542a925acca152b63383a6591b"
|
checksum = "30ca5c38fa00c0cd943035391bdcc84ed00748f17c66c682e410f5a62f234d44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"cranelift-codegen",
|
"cranelift-codegen",
|
||||||
@ -213,24 +213,15 @@ checksum = "2acce4a10f12dc2fb14a218589d4f1f62ef011b2d0cc4b3cb1bba8e94da14649"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gimli"
|
name = "gimli"
|
||||||
version = "0.29.0"
|
version = "0.31.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "40ecd4077b5ae9fd2e9e169b102c6c330d0605168eb0e8bf79952b256dbefffd"
|
checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"fallible-iterator",
|
"fallible-iterator",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"stable_deref_trait",
|
"stable_deref_trait",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "hashbrown"
|
|
||||||
version = "0.13.2"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "43a3c133739dddd0d2990f9a4bdf8eb4b21ef50e4851ca85ab661199821d510e"
|
|
||||||
dependencies = [
|
|
||||||
"ahash",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hashbrown"
|
name = "hashbrown"
|
||||||
version = "0.14.5"
|
version = "0.14.5"
|
||||||
@ -247,7 +238,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "168fb715dda47215e360912c096649d23d58bf392ac62f73919e831745e40f26"
|
checksum = "168fb715dda47215e360912c096649d23d58bf392ac62f73919e831745e40f26"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"equivalent",
|
"equivalent",
|
||||||
"hashbrown 0.14.5",
|
"hashbrown",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -273,10 +264,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24"
|
checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "mach"
|
name = "mach2"
|
||||||
version = "0.3.2"
|
version = "0.4.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b823e83b2affd8f40a9ee8c29dbc56404c1e34cd2710921f2801e2cf29527afa"
|
checksum = "19b955cdeb2a02b9117f121ce63aa52d08ade45de53e48fe6a38b39c10f6f709"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
@ -294,7 +285,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "3f203fa8daa7bb185f760ae12bd8e097f63d17041dcdcaf675ac54cdf863170e"
|
checksum = "3f203fa8daa7bb185f760ae12bd8e097f63d17041dcdcaf675ac54cdf863170e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crc32fast",
|
"crc32fast",
|
||||||
"hashbrown 0.14.5",
|
"hashbrown",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"memchr",
|
"memchr",
|
||||||
]
|
]
|
||||||
@ -325,11 +316,11 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "regalloc2"
|
name = "regalloc2"
|
||||||
version = "0.9.3"
|
version = "0.10.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "ad156d539c879b7a24a363a2016d77961786e71f48f2e2fc8302a92abd2429a6"
|
checksum = "12908dbeb234370af84d0579b9f68258a0f67e201412dd9a2814e6f45b2fc0f0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"hashbrown 0.13.2",
|
"hashbrown",
|
||||||
"log",
|
"log",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
"slice-group-by",
|
"slice-group-by",
|
||||||
@ -338,21 +329,21 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "region"
|
name = "region"
|
||||||
version = "2.2.0"
|
version = "3.0.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "877e54ea2adcd70d80e9179344c97f93ef0dffd6b03e1f4529e6e83ab2fa9ae0"
|
checksum = "e6b6ebd13bc009aef9cd476c1310d49ac354d36e240cf1bd753290f3dc7199a7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags",
|
"bitflags",
|
||||||
"libc",
|
"libc",
|
||||||
"mach",
|
"mach2",
|
||||||
"winapi",
|
"windows-sys 0.52.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustc-hash"
|
name = "rustc-hash"
|
||||||
version = "1.1.0"
|
version = "2.0.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2"
|
checksum = "583034fd73374156e66797ed8e5b0d5690409c9226b22d87cb7f19821c05d152"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustc_codegen_cranelift"
|
name = "rustc_codegen_cranelift"
|
||||||
@ -421,38 +412,16 @@ checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wasmtime-jit-icache-coherence"
|
name = "wasmtime-jit-icache-coherence"
|
||||||
version = "24.0.0"
|
version = "26.0.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d15de8429db996f0d17a4163a35eccc3f874cbfb50f29c379951ea1bbb39452e"
|
checksum = "6e458e6a1a010a53f86ac8d75837c0c6b2ce3e54b7503b2f1dc5629a4a541f5a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
"libc",
|
"libc",
|
||||||
"windows-sys",
|
"windows-sys 0.59.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "winapi"
|
|
||||||
version = "0.3.9"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419"
|
|
||||||
dependencies = [
|
|
||||||
"winapi-i686-pc-windows-gnu",
|
|
||||||
"winapi-x86_64-pc-windows-gnu",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "winapi-i686-pc-windows-gnu"
|
|
||||||
version = "0.4.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6"
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "winapi-x86_64-pc-windows-gnu"
|
|
||||||
version = "0.4.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows-sys"
|
name = "windows-sys"
|
||||||
version = "0.52.0"
|
version = "0.52.0"
|
||||||
@ -462,6 +431,15 @@ dependencies = [
|
|||||||
"windows-targets",
|
"windows-targets",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "windows-sys"
|
||||||
|
version = "0.59.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b"
|
||||||
|
dependencies = [
|
||||||
|
"windows-targets",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows-targets"
|
name = "windows-targets"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
|
@ -8,14 +8,14 @@ crate-type = ["dylib"]
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
# These have to be in sync with each other
|
# These have to be in sync with each other
|
||||||
cranelift-codegen = { version = "0.111.0", default-features = false, features = ["std", "unwind", "all-arch"] }
|
cranelift-codegen = { version = "0.113.0", default-features = false, features = ["std", "unwind", "all-native-arch"] }
|
||||||
cranelift-frontend = { version = "0.111.0" }
|
cranelift-frontend = { version = "0.113.0" }
|
||||||
cranelift-module = { version = "0.111.0" }
|
cranelift-module = { version = "0.113.0" }
|
||||||
cranelift-native = { version = "0.111.0" }
|
cranelift-native = { version = "0.113.0" }
|
||||||
cranelift-jit = { version = "0.111.0", optional = true }
|
cranelift-jit = { version = "0.113.0", optional = true }
|
||||||
cranelift-object = { version = "0.111.0" }
|
cranelift-object = { version = "0.113.0" }
|
||||||
target-lexicon = "0.12.0"
|
target-lexicon = "0.12.0"
|
||||||
gimli = { version = "0.29", default-features = false, features = ["write"] }
|
gimli = { version = "0.31", default-features = false, features = ["write"] }
|
||||||
object = { version = "0.36", default-features = false, features = ["std", "read_core", "write", "archive", "coff", "elf", "macho", "pe"] }
|
object = { version = "0.36", default-features = false, features = ["std", "read_core", "write", "archive", "coff", "elf", "macho", "pe"] }
|
||||||
|
|
||||||
indexmap = "2.0.0"
|
indexmap = "2.0.0"
|
||||||
|
@ -102,15 +102,6 @@ pub(crate) fn build_sysroot(
|
|||||||
.install_into_sysroot(&dist_dir);
|
.install_into_sysroot(&dist_dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy std for the host to the lib dir. This is necessary for the jit mode to find
|
|
||||||
// libstd.
|
|
||||||
for lib in host.libs {
|
|
||||||
let filename = lib.file_name().unwrap().to_str().unwrap();
|
|
||||||
if filename.contains("std-") && !filename.contains(".rlib") {
|
|
||||||
try_hard_link(&lib, dist_dir.join("lib").join(lib.file_name().unwrap()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let mut target_compiler = {
|
let mut target_compiler = {
|
||||||
let rustc_clif = dist_dir.join(wrapper_base_name.replace("____", "rustc-clif"));
|
let rustc_clif = dist_dir.join(wrapper_base_name.replace("____", "rustc-clif"));
|
||||||
let rustdoc_clif = dist_dir.join(wrapper_base_name.replace("____", "rustdoc-clif"));
|
let rustdoc_clif = dist_dir.join(wrapper_base_name.replace("____", "rustdoc-clif"));
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
use std::ffi::OsStr;
|
use std::ffi::OsStr;
|
||||||
use std::fs;
|
|
||||||
use std::hash::{Hash, Hasher};
|
use std::hash::{Hash, Hasher};
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
|
use std::{fs, io};
|
||||||
|
|
||||||
use crate::path::{Dirs, RelPath};
|
use crate::path::{Dirs, RelPath};
|
||||||
use crate::utils::{copy_dir_recursively, ensure_empty_dir, spawn_and_wait};
|
use crate::utils::{copy_dir_recursively, ensure_empty_dir, spawn_and_wait};
|
||||||
@ -89,6 +89,19 @@ impl GitRepo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn verify_checksum(&self, dirs: &Dirs) {
|
||||||
|
let download_dir = self.download_dir(dirs);
|
||||||
|
let actual_hash = format!("{:016x}", hash_dir(&download_dir));
|
||||||
|
if actual_hash != self.content_hash {
|
||||||
|
eprintln!(
|
||||||
|
"Mismatched content hash for {download_dir}: {actual_hash} != {content_hash}. Please run ./y.sh prepare again.",
|
||||||
|
download_dir = download_dir.display(),
|
||||||
|
content_hash = self.content_hash,
|
||||||
|
);
|
||||||
|
std::process::exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn fetch(&self, dirs: &Dirs) {
|
pub(crate) fn fetch(&self, dirs: &Dirs) {
|
||||||
let download_dir = self.download_dir(dirs);
|
let download_dir = self.download_dir(dirs);
|
||||||
|
|
||||||
@ -126,18 +139,11 @@ impl GitRepo {
|
|||||||
assert!(target_lockfile.exists());
|
assert!(target_lockfile.exists());
|
||||||
}
|
}
|
||||||
|
|
||||||
let actual_hash = format!("{:016x}", hash_dir(&download_dir));
|
self.verify_checksum(dirs);
|
||||||
if actual_hash != self.content_hash {
|
|
||||||
eprintln!(
|
|
||||||
"Download of {download_dir} failed with mismatched content hash: {actual_hash} != {content_hash}",
|
|
||||||
download_dir = download_dir.display(),
|
|
||||||
content_hash = self.content_hash,
|
|
||||||
);
|
|
||||||
std::process::exit(1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn patch(&self, dirs: &Dirs) {
|
pub(crate) fn patch(&self, dirs: &Dirs) {
|
||||||
|
self.verify_checksum(dirs);
|
||||||
apply_patches(
|
apply_patches(
|
||||||
dirs,
|
dirs,
|
||||||
self.patch_name,
|
self.patch_name,
|
||||||
@ -149,6 +155,13 @@ impl GitRepo {
|
|||||||
|
|
||||||
fn clone_repo(download_dir: &Path, repo: &str, rev: &str) {
|
fn clone_repo(download_dir: &Path, repo: &str, rev: &str) {
|
||||||
eprintln!("[CLONE] {}", repo);
|
eprintln!("[CLONE] {}", repo);
|
||||||
|
|
||||||
|
match fs::remove_dir_all(download_dir) {
|
||||||
|
Ok(()) => {}
|
||||||
|
Err(err) if err.kind() == io::ErrorKind::NotFound => {}
|
||||||
|
Err(err) => panic!("Failed to remove {path}: {err}", path = download_dir.display()),
|
||||||
|
}
|
||||||
|
|
||||||
// Ignore exit code as the repo may already have been checked out
|
// Ignore exit code as the repo may already have been checked out
|
||||||
git_command(None, "clone").arg(repo).arg(download_dir).spawn().unwrap().wait().unwrap();
|
git_command(None, "clone").arg(repo).arg(download_dir).spawn().unwrap().wait().unwrap();
|
||||||
|
|
||||||
|
@ -7,11 +7,23 @@ Subject: [PATCH] Disable broken tests
|
|||||||
src/report.rs | 36 ++++++++++++++++++++++++++++++++++++
|
src/report.rs | 36 ++++++++++++++++++++++++++++++++++++
|
||||||
1 file changed, 36 insertions(+)
|
1 file changed, 36 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/toolchains/rust.rs b/src/toolchains/rust.rs
|
||||||
|
index 0c50f7a..bfde2b1 100644
|
||||||
|
--- a/src/toolchains/rust.rs
|
||||||
|
+++ b/src/toolchains/rust.rs
|
||||||
|
@@ -83,6 +83,7 @@ impl Toolchain for RustcToolchain {
|
||||||
|
.arg(out_dir)
|
||||||
|
.arg("--target")
|
||||||
|
.arg(built_info::TARGET)
|
||||||
|
+ .arg("-g")
|
||||||
|
.arg(format!("-Cmetadata={lib_name}"))
|
||||||
|
.arg(src_path);
|
||||||
|
if let Some(codegen_backend) = &self.codegen_backend {
|
||||||
diff --git a/src/report.rs b/src/report.rs
|
diff --git a/src/report.rs b/src/report.rs
|
||||||
index 958ab43..dcf1044 100644
|
index 958ab43..dcf1044 100644
|
||||||
--- a/src/report.rs
|
--- a/src/report.rs
|
||||||
+++ b/src/report.rs
|
+++ b/src/report.rs
|
||||||
@@ -48,6 +48,58 @@ pub fn get_test_rules(test: &TestKey, caller: &dyn Toolchain, callee: &dyn Toolc
|
@@ -48,6 +48,40 @@ pub fn get_test_rules(test: &TestKey, caller: &dyn Toolchain, callee: &dyn Toolc
|
||||||
//
|
//
|
||||||
// THIS AREA RESERVED FOR VENDORS TO APPLY PATCHES
|
// THIS AREA RESERVED FOR VENDORS TO APPLY PATCHES
|
||||||
|
|
||||||
@ -19,10 +31,6 @@ index 958ab43..dcf1044 100644
|
|||||||
+ if test.test == "F32Array" && test.options.convention == CallingConvention::C {
|
+ if test.test == "F32Array" && test.options.convention == CallingConvention::C {
|
||||||
+ result.check = Busted(Check);
|
+ result.check = Busted(Check);
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
+ if test.test == "OptionU128" && test.options.convention == CallingConvention::Rust && test.options.repr == LangRepr::C {
|
|
||||||
+ result.check = Busted(Check);
|
|
||||||
+ }
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if cfg!(all(target_arch = "aarch64", target_os = "macos")) {
|
+ if cfg!(all(target_arch = "aarch64", target_os = "macos")) {
|
||||||
@ -39,21 +47,7 @@ index 958ab43..dcf1044 100644
|
|||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if cfg!(all(target_arch = "x86_64", unix)) {
|
|
||||||
+ if test.test == "OptionU128" && test.options.convention == CallingConvention::Rust && test.options.repr == LangRepr::Rust {
|
|
||||||
+ result.check = Busted(Run);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if cfg!(all(target_arch = "x86_64", windows)) {
|
+ if cfg!(all(target_arch = "x86_64", windows)) {
|
||||||
+ if test.test == "OptionU128" && test.options.convention == CallingConvention::Rust {
|
|
||||||
+ result.check = Busted(Check);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if test.test == "OptionU128" && test.options.convention == CallingConvention::Rust && (test.caller == "rustc" || test.options.repr == LangRepr::Rust) {
|
|
||||||
+ result.check = Busted(Run);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if test.test == "simple" && test.options.convention == CallingConvention::Rust {
|
+ if test.test == "simple" && test.options.convention == CallingConvention::Rust {
|
||||||
+ result.check = Busted(Check);
|
+ result.check = Busted(Check);
|
||||||
+ }
|
+ }
|
||||||
|
@ -38,7 +38,7 @@ index 42a26ae..5ac1042 100644
|
|||||||
@@ -1,3 +1,4 @@
|
@@ -1,3 +1,4 @@
|
||||||
+#![cfg(test)]
|
+#![cfg(test)]
|
||||||
// tidy-alphabetical-start
|
// tidy-alphabetical-start
|
||||||
#![cfg_attr(bootstrap, feature(const_mut_refs))]
|
#![cfg_attr(bootstrap, feature(strict_provenance))]
|
||||||
#![cfg_attr(target_has_atomic = "128", feature(integer_atomics))]
|
#![cfg_attr(not(bootstrap), feature(strict_provenance_lints))]
|
||||||
--
|
--
|
||||||
2.21.0 (Apple Git-122)
|
2.21.0 (Apple Git-122)
|
||||||
|
@ -14,13 +14,14 @@ diff --git a/lib.rs b/lib.rs
|
|||||||
index 1e336bf..35e6f54 100644
|
index 1e336bf..35e6f54 100644
|
||||||
--- a/lib.rs
|
--- a/lib.rs
|
||||||
+++ b/lib.rs
|
+++ b/lib.rs
|
||||||
@@ -1,6 +1,5 @@
|
@@ -2,7 +2,6 @@
|
||||||
#![cfg(test)]
|
|
||||||
// tidy-alphabetical-start
|
// tidy-alphabetical-start
|
||||||
#![cfg_attr(bootstrap, feature(const_mut_refs))]
|
#![cfg_attr(bootstrap, feature(strict_provenance))]
|
||||||
|
#![cfg_attr(not(bootstrap), feature(strict_provenance_lints))]
|
||||||
-#![cfg_attr(target_has_atomic = "128", feature(integer_atomics))]
|
-#![cfg_attr(target_has_atomic = "128", feature(integer_atomics))]
|
||||||
#![cfg_attr(test, feature(cfg_match))]
|
#![cfg_attr(test, feature(cfg_match))]
|
||||||
#![feature(alloc_layout_extra)]
|
#![feature(alloc_layout_extra)]
|
||||||
|
#![feature(array_chunks)]
|
||||||
diff --git a/atomic.rs b/atomic.rs
|
diff --git a/atomic.rs b/atomic.rs
|
||||||
index b735957..ea728b6 100644
|
index b735957..ea728b6 100644
|
||||||
--- a/atomic.rs
|
--- a/atomic.rs
|
||||||
|
@ -12,7 +12,7 @@ index 8402833..84592e0 100644
|
|||||||
--- a/slice.rs
|
--- a/slice.rs
|
||||||
+++ b/slice.rs
|
+++ b/slice.rs
|
||||||
@@ -1809,6 +1809,7 @@ fn sort_unstable() {
|
@@ -1809,6 +1809,7 @@ fn sort_unstable() {
|
||||||
assert!(v == [0xDEADBEEF]);
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
+/*
|
+/*
|
||||||
@ -43,26 +43,6 @@ index 8402833..84592e0 100644
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_slice_from_ptr_range() {
|
fn test_slice_from_ptr_range() {
|
||||||
diff --git a/lazy.rs b/lazy.rs
|
|
||||||
index 711511e..49c8d78 100644
|
|
||||||
--- a/lazy.rs
|
|
||||||
+++ b/lazy.rs
|
|
||||||
@@ -113,6 +113,7 @@ fn lazy_type_inference() {
|
|
||||||
let _ = LazyCell::new(|| ());
|
|
||||||
}
|
|
||||||
|
|
||||||
+/*
|
|
||||||
#[test]
|
|
||||||
#[should_panic = "LazyCell instance has previously been poisoned"]
|
|
||||||
fn lazy_force_mut_panic() {
|
|
||||||
@@ -123,6 +124,7 @@ fn lazy_force_mut_panic() {
|
|
||||||
.unwrap_err();
|
|
||||||
let _ = &*lazy;
|
|
||||||
}
|
|
||||||
+*/
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn lazy_force_mut() {
|
|
||||||
--
|
--
|
||||||
2.26.2.7.g19db9cfb68
|
2.26.2.7.g19db9cfb68
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
[toolchain]
|
[toolchain]
|
||||||
channel = "nightly-2024-09-23"
|
channel = "nightly-2024-11-02"
|
||||||
components = ["rust-src", "rustc-dev", "llvm-tools"]
|
components = ["rust-src", "rustc-dev", "llvm-tools"]
|
||||||
profile = "minimal"
|
profile = "minimal"
|
||||||
|
@ -47,9 +47,6 @@ rm tests/ui/abi/variadic-ffi.rs # requires callee side vararg support
|
|||||||
rm -r tests/run-make/c-link-to-rust-va-list-fn # requires callee side vararg support
|
rm -r tests/run-make/c-link-to-rust-va-list-fn # requires callee side vararg support
|
||||||
rm tests/ui/delegation/fn-header.rs
|
rm tests/ui/delegation/fn-header.rs
|
||||||
|
|
||||||
# unsized locals
|
|
||||||
rm -r tests/run-pass-valgrind/unsized-locals
|
|
||||||
|
|
||||||
# misc unimplemented things
|
# misc unimplemented things
|
||||||
rm tests/ui/target-feature/missing-plusminus.rs # error not implemented
|
rm tests/ui/target-feature/missing-plusminus.rs # error not implemented
|
||||||
rm -r tests/run-make/repr128-dwarf # debuginfo test
|
rm -r tests/run-make/repr128-dwarf # debuginfo test
|
||||||
@ -148,6 +145,7 @@ rm tests/ui/intrinsics/panic-uninitialized-zeroed.rs # same
|
|||||||
rm tests/ui/process/process-panic-after-fork.rs # same
|
rm tests/ui/process/process-panic-after-fork.rs # same
|
||||||
|
|
||||||
cp ../dist/bin/rustdoc-clif ../dist/bin/rustdoc # some tests expect bin/rustdoc to exist
|
cp ../dist/bin/rustdoc-clif ../dist/bin/rustdoc # some tests expect bin/rustdoc to exist
|
||||||
|
cp $(../dist/rustc-clif --print target-libdir)/libstd-*.so ../dist/lib/
|
||||||
|
|
||||||
# prevent $(RUSTDOC) from picking up the sysroot built by x.py. It conflicts with the one used by
|
# prevent $(RUSTDOC) from picking up the sysroot built by x.py. It conflicts with the one used by
|
||||||
# rustdoc-clif
|
# rustdoc-clif
|
||||||
@ -180,92 +178,20 @@ index 9607ff02f96..b7d97caf9a2 100644
|
|||||||
Self { cmd }
|
Self { cmd }
|
||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/src/bootstrap/src/core/build_steps/test.rs b/src/bootstrap/src/core/build_steps/test.rs
|
|
||||||
index 2047345d78a..a7e9352bb1c 100644
|
|
||||||
--- a/src/bootstrap/src/core/build_steps/test.rs
|
|
||||||
+++ b/src/bootstrap/src/core/build_steps/test.rs
|
|
||||||
@@ -1733,11 +1733,6 @@ fn run(self, builder: &Builder<'_>) {
|
|
||||||
|
|
||||||
let is_rustdoc = suite.ends_with("rustdoc-ui") || suite.ends_with("rustdoc-js");
|
|
||||||
|
|
||||||
- if mode == "run-make" {
|
|
||||||
- let cargo = builder.ensure(tool::Cargo { compiler, target: compiler.host });
|
|
||||||
- cmd.arg("--cargo-path").arg(cargo);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
// Avoid depending on rustdoc when we don't need it.
|
|
||||||
if mode == "rustdoc"
|
|
||||||
|| mode == "run-make"
|
|
||||||
diff --git a/src/tools/compiletest/src/common.rs b/src/tools/compiletest/src/common.rs
|
|
||||||
index 414f9f3a7f1..5c18179b6fe 100644
|
|
||||||
--- a/src/tools/compiletest/src/common.rs
|
|
||||||
+++ b/src/tools/compiletest/src/common.rs
|
|
||||||
@@ -183,9 +183,6 @@ pub struct Config {
|
|
||||||
/// The rustc executable.
|
|
||||||
pub rustc_path: PathBuf,
|
|
||||||
|
|
||||||
- /// The cargo executable.
|
|
||||||
- pub cargo_path: Option<PathBuf>,
|
|
||||||
-
|
|
||||||
/// The rustdoc executable.
|
|
||||||
pub rustdoc_path: Option<PathBuf>,
|
|
||||||
|
|
||||||
diff --git a/src/tools/compiletest/src/lib.rs b/src/tools/compiletest/src/lib.rs
|
|
||||||
index 3339116d542..250b5084d13 100644
|
|
||||||
--- a/src/tools/compiletest/src/lib.rs
|
|
||||||
+++ b/src/tools/compiletest/src/lib.rs
|
|
||||||
@@ -47,7 +47,6 @@ pub fn parse_config(args: Vec<String>) -> Config {
|
|
||||||
opts.reqopt("", "compile-lib-path", "path to host shared libraries", "PATH")
|
|
||||||
.reqopt("", "run-lib-path", "path to target shared libraries", "PATH")
|
|
||||||
.reqopt("", "rustc-path", "path to rustc to use for compiling", "PATH")
|
|
||||||
- .optopt("", "cargo-path", "path to cargo to use for compiling", "PATH")
|
|
||||||
.optopt("", "rustdoc-path", "path to rustdoc to use for compiling", "PATH")
|
|
||||||
.optopt("", "coverage-dump-path", "path to coverage-dump to use in tests", "PATH")
|
|
||||||
.reqopt("", "python", "path to python to use for doc tests", "PATH")
|
|
||||||
@@ -261,7 +260,6 @@ fn make_absolute(path: PathBuf) -> PathBuf {
|
|
||||||
compile_lib_path: make_absolute(opt_path(matches, "compile-lib-path")),
|
|
||||||
run_lib_path: make_absolute(opt_path(matches, "run-lib-path")),
|
|
||||||
rustc_path: opt_path(matches, "rustc-path"),
|
|
||||||
- cargo_path: matches.opt_str("cargo-path").map(PathBuf::from),
|
|
||||||
rustdoc_path: matches.opt_str("rustdoc-path").map(PathBuf::from),
|
|
||||||
coverage_dump_path: matches.opt_str("coverage-dump-path").map(PathBuf::from),
|
|
||||||
python: matches.opt_str("python").unwrap(),
|
|
||||||
@@ -366,7 +364,6 @@ pub fn log_config(config: &Config) {
|
|
||||||
logv(c, format!("compile_lib_path: {:?}", config.compile_lib_path));
|
|
||||||
logv(c, format!("run_lib_path: {:?}", config.run_lib_path));
|
|
||||||
logv(c, format!("rustc_path: {:?}", config.rustc_path.display()));
|
|
||||||
- logv(c, format!("cargo_path: {:?}", config.cargo_path));
|
|
||||||
logv(c, format!("rustdoc_path: {:?}", config.rustdoc_path));
|
|
||||||
logv(c, format!("src_base: {:?}", config.src_base.display()));
|
|
||||||
logv(c, format!("build_base: {:?}", config.build_base.display()));
|
|
||||||
diff --git a/src/tools/compiletest/src/runtest/run_make.rs b/src/tools/compiletest/src/runtest/run_make.rs
|
diff --git a/src/tools/compiletest/src/runtest/run_make.rs b/src/tools/compiletest/src/runtest/run_make.rs
|
||||||
index 75fe6a6baaf..852568ae925 100644
|
index e7ae773ffa1d3..04bc2d7787da7 100644
|
||||||
--- a/src/tools/compiletest/src/runtest/run_make.rs
|
--- a/src/tools/compiletest/src/runtest/run_make.rs
|
||||||
+++ b/src/tools/compiletest/src/runtest/run_make.rs
|
+++ b/src/tools/compiletest/src/runtest/run_make.rs
|
||||||
@@ -61,10 +61,6 @@ fn run_rmake_legacy_test(&self) {
|
@@ -329,7 +329,6 @@ impl TestCx<'_> {
|
||||||
.env_remove("MFLAGS")
|
.arg(format!("run_make_support={}", &support_lib_path.to_string_lossy()))
|
||||||
.env_remove("CARGO_MAKEFLAGS");
|
.arg("--edition=2021")
|
||||||
|
.arg(&self.testpaths.file.join("rmake.rs"))
|
||||||
|
- .arg("-Cprefer-dynamic")
|
||||||
|
// Provide necessary library search paths for rustc.
|
||||||
|
.env(dylib_env_var(), &env::join_paths(host_dylib_search_paths).unwrap());
|
||||||
|
|
||||||
- if let Some(ref cargo) = self.config.cargo_path {
|
|
||||||
- cmd.env("CARGO", cwd.join(cargo));
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if let Some(ref rustdoc) = self.config.rustdoc_path {
|
|
||||||
cmd.env("RUSTDOC", cwd.join(rustdoc));
|
|
||||||
}
|
|
||||||
@@ -413,10 +409,6 @@ fn run_rmake_v2_test(&self) {
|
|
||||||
// through a specific CI runner).
|
|
||||||
.env("LLVM_COMPONENTS", &self.config.llvm_components);
|
|
||||||
|
|
||||||
- if let Some(ref cargo) = self.config.cargo_path {
|
|
||||||
- cmd.env("CARGO", source_root.join(cargo));
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if let Some(ref rustdoc) = self.config.rustdoc_path {
|
|
||||||
cmd.env("RUSTDOC", source_root.join(rustdoc));
|
|
||||||
}
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
echo "[TEST] rustc test suite"
|
echo "[TEST] rustc test suite"
|
||||||
COMPILETEST_FORCE_STAGE0=1 ./x.py test --stage 0 --test-args=--nocapture tests/{codegen-units,run-make,run-pass-valgrind,ui,incremental}
|
COMPILETEST_FORCE_STAGE0=1 ./x.py test --stage 0 --test-args=--nocapture tests/{codegen-units,run-make,ui,incremental}
|
||||||
popd
|
popd
|
||||||
|
@ -389,7 +389,7 @@ pub(crate) fn codegen_terminator_call<'tcx>(
|
|||||||
let callee = with_no_trimmed_paths!(fx.tcx.def_path_str(def_id));
|
let callee = with_no_trimmed_paths!(fx.tcx.def_path_str(def_id));
|
||||||
fx.tcx.dcx().emit_err(CompilerBuiltinsCannotCall { caller, callee });
|
fx.tcx.dcx().emit_err(CompilerBuiltinsCannotCall { caller, callee });
|
||||||
} else {
|
} else {
|
||||||
fx.bcx.ins().trap(TrapCode::User(0));
|
fx.bcx.ins().trap(TrapCode::user(2).unwrap());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -562,6 +562,11 @@ pub(crate) fn codegen_terminator_call<'tcx>(
|
|||||||
adjust_call_for_c_variadic(fx, &fn_abi, source_info, func_ref, &mut call_args);
|
adjust_call_for_c_variadic(fx, &fn_abi, source_info, func_ref, &mut call_args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if fx.clif_comments.enabled() {
|
||||||
|
let nop_inst = fx.bcx.ins().nop();
|
||||||
|
with_no_trimmed_paths!(fx.add_comment(nop_inst, format!("abi: {:?}", fn_abi)));
|
||||||
|
}
|
||||||
|
|
||||||
match func_ref {
|
match func_ref {
|
||||||
CallTarget::Direct(func_ref) => fx.bcx.ins().call(func_ref, &call_args),
|
CallTarget::Direct(func_ref) => fx.bcx.ins().call(func_ref, &call_args),
|
||||||
CallTarget::Indirect(sig, func_ptr) => {
|
CallTarget::Indirect(sig, func_ptr) => {
|
||||||
@ -574,7 +579,7 @@ pub(crate) fn codegen_terminator_call<'tcx>(
|
|||||||
let ret_block = fx.get_block(dest);
|
let ret_block = fx.get_block(dest);
|
||||||
fx.bcx.ins().jump(ret_block, &[]);
|
fx.bcx.ins().jump(ret_block, &[]);
|
||||||
} else {
|
} else {
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
fn adjust_call_for_c_variadic<'tcx>(
|
fn adjust_call_for_c_variadic<'tcx>(
|
||||||
|
@ -103,12 +103,12 @@ pub(crate) fn codegen_fn<'tcx>(
|
|||||||
let block_map: IndexVec<BasicBlock, Block> =
|
let block_map: IndexVec<BasicBlock, Block> =
|
||||||
(0..mir.basic_blocks.len()).map(|_| bcx.create_block()).collect();
|
(0..mir.basic_blocks.len()).map(|_| bcx.create_block()).collect();
|
||||||
|
|
||||||
|
let fn_abi = RevealAllLayoutCx(tcx).fn_abi_of_instance(instance, ty::List::empty());
|
||||||
|
|
||||||
// Make FunctionCx
|
// Make FunctionCx
|
||||||
let target_config = module.target_config();
|
let target_config = module.target_config();
|
||||||
let pointer_type = target_config.pointer_type();
|
let pointer_type = target_config.pointer_type();
|
||||||
let clif_comments = crate::pretty_clif::CommentWriter::new(tcx, instance);
|
let clif_comments = crate::pretty_clif::CommentWriter::new(tcx, instance, fn_abi);
|
||||||
|
|
||||||
let fn_abi = RevealAllLayoutCx(tcx).fn_abi_of_instance(instance, ty::List::empty());
|
|
||||||
|
|
||||||
let func_debug_cx = if let Some(debug_context) = &mut cx.debug_context {
|
let func_debug_cx = if let Some(debug_context) = &mut cx.debug_context {
|
||||||
Some(debug_context.define_function(tcx, type_dbg, instance, fn_abi, &symbol_name, mir.span))
|
Some(debug_context.define_function(tcx, type_dbg, instance, fn_abi, &symbol_name, mir.span))
|
||||||
@ -294,7 +294,7 @@ fn codegen_fn_body(fx: &mut FunctionCx<'_, '_, '_>, start_block: Block) {
|
|||||||
if arg_uninhabited {
|
if arg_uninhabited {
|
||||||
fx.bcx.append_block_params_for_function_params(fx.block_map[START_BLOCK]);
|
fx.bcx.append_block_params_for_function_params(fx.block_map[START_BLOCK]);
|
||||||
fx.bcx.switch_to_block(fx.block_map[START_BLOCK]);
|
fx.bcx.switch_to_block(fx.block_map[START_BLOCK]);
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fx.tcx
|
fx.tcx
|
||||||
@ -311,7 +311,7 @@ fn codegen_fn_body(fx: &mut FunctionCx<'_, '_, '_>, start_block: Block) {
|
|||||||
if !reachable_blocks.contains(bb) {
|
if !reachable_blocks.contains(bb) {
|
||||||
// We want to skip this block, because it's not reachable. But we still create
|
// We want to skip this block, because it's not reachable. But we still create
|
||||||
// the block so terminators in other blocks can reference it.
|
// the block so terminators in other blocks can reference it.
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -379,7 +379,6 @@ fn codegen_fn_body(fx: &mut FunctionCx<'_, '_, '_>, start_block: Block) {
|
|||||||
|
|
||||||
let target = fx.get_block(*target);
|
let target = fx.get_block(*target);
|
||||||
let failure = fx.bcx.create_block();
|
let failure = fx.bcx.create_block();
|
||||||
fx.bcx.set_cold_block(failure);
|
|
||||||
|
|
||||||
if *expected {
|
if *expected {
|
||||||
fx.bcx.ins().brif(cond, target, &[], failure, &[]);
|
fx.bcx.ins().brif(cond, target, &[], failure, &[]);
|
||||||
@ -541,10 +540,11 @@ fn codegen_fn_body(fx: &mut FunctionCx<'_, '_, '_>, start_block: Block) {
|
|||||||
}
|
}
|
||||||
TerminatorKind::UnwindResume => {
|
TerminatorKind::UnwindResume => {
|
||||||
// FIXME implement unwinding
|
// FIXME implement unwinding
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
TerminatorKind::Unreachable => {
|
TerminatorKind::Unreachable => {
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.set_cold_block(block);
|
||||||
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
TerminatorKind::Yield { .. }
|
TerminatorKind::Yield { .. }
|
||||||
| TerminatorKind::FalseEdge { .. }
|
| TerminatorKind::FalseEdge { .. }
|
||||||
@ -1075,12 +1075,14 @@ fn codegen_panic_inner<'tcx>(
|
|||||||
args: &[Value],
|
args: &[Value],
|
||||||
span: Option<Span>,
|
span: Option<Span>,
|
||||||
) {
|
) {
|
||||||
|
fx.bcx.set_cold_block(fx.bcx.current_block().unwrap());
|
||||||
|
|
||||||
let def_id = fx.tcx.require_lang_item(lang_item, span);
|
let def_id = fx.tcx.require_lang_item(lang_item, span);
|
||||||
|
|
||||||
let instance = Instance::mono(fx.tcx, def_id).polymorphize(fx.tcx);
|
let instance = Instance::mono(fx.tcx, def_id).polymorphize(fx.tcx);
|
||||||
|
|
||||||
if is_call_from_compiler_builtins_to_upstream_monomorphization(fx.tcx, instance) {
|
if is_call_from_compiler_builtins_to_upstream_monomorphization(fx.tcx, instance) {
|
||||||
fx.bcx.ins().trap(TrapCode::User(0));
|
fx.bcx.ins().trap(TrapCode::user(2).unwrap());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1093,5 +1095,5 @@ fn codegen_panic_inner<'tcx>(
|
|||||||
args,
|
args,
|
||||||
);
|
);
|
||||||
|
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,12 @@ fn make_file_info(hash: SourceFileHash) -> Option<FileInfo> {
|
|||||||
if hash.kind == SourceFileHashAlgorithm::Md5 {
|
if hash.kind == SourceFileHashAlgorithm::Md5 {
|
||||||
let mut buf = [0u8; MD5_LEN];
|
let mut buf = [0u8; MD5_LEN];
|
||||||
buf.copy_from_slice(hash.hash_bytes());
|
buf.copy_from_slice(hash.hash_bytes());
|
||||||
Some(FileInfo { timestamp: 0, size: 0, md5: buf })
|
Some(FileInfo {
|
||||||
|
timestamp: 0,
|
||||||
|
size: 0,
|
||||||
|
md5: buf,
|
||||||
|
source: None, // FIXME implement -Zembed-source
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
@ -101,6 +101,7 @@ impl DebugContext {
|
|||||||
None => (tcx.crate_name(LOCAL_CRATE).to_string(), None),
|
None => (tcx.crate_name(LOCAL_CRATE).to_string(), None),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let file_has_md5 = file_info.is_some();
|
||||||
let mut line_program = LineProgram::new(
|
let mut line_program = LineProgram::new(
|
||||||
encoding,
|
encoding,
|
||||||
LineEncoding::default(),
|
LineEncoding::default(),
|
||||||
@ -108,7 +109,7 @@ impl DebugContext {
|
|||||||
LineString::new(name.as_bytes(), encoding, &mut dwarf.line_strings),
|
LineString::new(name.as_bytes(), encoding, &mut dwarf.line_strings),
|
||||||
file_info,
|
file_info,
|
||||||
);
|
);
|
||||||
line_program.file_has_md5 = file_info.is_some();
|
line_program.file_has_md5 = file_has_md5;
|
||||||
|
|
||||||
dwarf.unit.line_program = line_program;
|
dwarf.unit.line_program = line_program;
|
||||||
|
|
||||||
|
@ -60,8 +60,8 @@ impl UnwindContext {
|
|||||||
self.frame_table
|
self.frame_table
|
||||||
.add_fde(self.cie_id.unwrap(), unwind_info.to_fde(address_for_func(func_id)));
|
.add_fde(self.cie_id.unwrap(), unwind_info.to_fde(address_for_func(func_id)));
|
||||||
}
|
}
|
||||||
UnwindInfo::WindowsX64(_) => {
|
UnwindInfo::WindowsX64(_) | UnwindInfo::WindowsArm64(_) => {
|
||||||
// FIXME implement this
|
// Windows does not have debug info for its unwind info.
|
||||||
}
|
}
|
||||||
unwind_info => unimplemented!("{:?}", unwind_info),
|
unwind_info => unimplemented!("{:?}", unwind_info),
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ pub(crate) fn codegen_inline_asm_terminator<'tcx>(
|
|||||||
// asm!() by accident and breaks with the GNU assembler as well as global_asm!() for
|
// asm!() by accident and breaks with the GNU assembler as well as global_asm!() for
|
||||||
// the LLVM backend.
|
// the LLVM backend.
|
||||||
if template.len() == 1 && template[0] == InlineAsmTemplatePiece::String("int $$0x29".into()) {
|
if template.len() == 1 && template[0] == InlineAsmTemplatePiece::String("int $$0x29".into()) {
|
||||||
fx.bcx.ins().trap(TrapCode::User(1));
|
fx.bcx.ins().trap(TrapCode::user(2).unwrap());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -137,7 +137,7 @@ pub(crate) fn codegen_inline_asm_terminator<'tcx>(
|
|||||||
fx.bcx.ins().jump(destination_block, &[]);
|
fx.bcx.ins().jump(destination_block, &[]);
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(0 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ fn report_atomic_type_validation_error<'tcx>(
|
|||||||
),
|
),
|
||||||
);
|
);
|
||||||
// Prevent verifier error
|
// Prevent verifier error
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn clif_vector_type<'tcx>(tcx: TyCtxt<'tcx>, layout: TyAndLayout<'tcx>) -> Type {
|
pub(crate) fn clif_vector_type<'tcx>(tcx: TyCtxt<'tcx>, layout: TyAndLayout<'tcx>) -> Type {
|
||||||
@ -449,7 +449,8 @@ fn codegen_regular_intrinsic_call<'tcx>(
|
|||||||
|
|
||||||
match intrinsic {
|
match intrinsic {
|
||||||
sym::abort => {
|
sym::abort => {
|
||||||
fx.bcx.ins().trap(TrapCode::User(0));
|
fx.bcx.set_cold_block(fx.bcx.current_block().unwrap());
|
||||||
|
fx.bcx.ins().trap(TrapCode::user(2).unwrap());
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
sym::likely | sym::unlikely => {
|
sym::likely | sym::unlikely => {
|
||||||
|
@ -14,7 +14,7 @@ fn report_simd_type_validation_error(
|
|||||||
) {
|
) {
|
||||||
fx.tcx.dcx().span_err(span, format!("invalid monomorphization of `{}` intrinsic: expected SIMD input type, found non-SIMD `{}`", intrinsic, ty));
|
fx.tcx.dcx().span_err(span, format!("invalid monomorphization of `{}` intrinsic: expected SIMD input type, found non-SIMD `{}`", intrinsic, ty));
|
||||||
// Prevent verifier error
|
// Prevent verifier error
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(super) fn codegen_simd_intrinsic_call<'tcx>(
|
pub(super) fn codegen_simd_intrinsic_call<'tcx>(
|
||||||
@ -190,7 +190,7 @@ pub(super) fn codegen_simd_intrinsic_call<'tcx>(
|
|||||||
format!("simd_shuffle index must be a SIMD vector of `u32`, got `{}`", idx_ty),
|
format!("simd_shuffle index must be a SIMD vector of `u32`, got `{}`", idx_ty),
|
||||||
);
|
);
|
||||||
// Prevent verifier error
|
// Prevent verifier error
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(1 /* unreachable */).unwrap());
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
let n: u16 = idx_ty.simd_size_and_type(fx.tcx).0.try_into().unwrap();
|
let n: u16 = idx_ty.simd_size_and_type(fx.tcx).0.try_into().unwrap();
|
||||||
@ -1135,7 +1135,7 @@ pub(super) fn codegen_simd_intrinsic_call<'tcx>(
|
|||||||
_ => {
|
_ => {
|
||||||
fx.tcx.dcx().span_err(span, format!("Unknown SIMD intrinsic {}", intrinsic));
|
fx.tcx.dcx().span_err(span, format!("Unknown SIMD intrinsic {}", intrinsic));
|
||||||
// Prevent verifier error
|
// Prevent verifier error
|
||||||
fx.bcx.ins().trap(TrapCode::UnreachableCodeReached);
|
fx.bcx.ins().trap(TrapCode::user(0 /* unreachable */).unwrap());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -302,8 +302,11 @@ fn build_isa(sess: &Session, backend_config: &BackendConfig) -> Arc<dyn TargetIs
|
|||||||
OptLevel::No => {
|
OptLevel::No => {
|
||||||
flags_builder.set("opt_level", "none").unwrap();
|
flags_builder.set("opt_level", "none").unwrap();
|
||||||
}
|
}
|
||||||
OptLevel::Less | OptLevel::Default => {}
|
OptLevel::Less
|
||||||
OptLevel::Size | OptLevel::SizeMin | OptLevel::Aggressive => {
|
| OptLevel::Default
|
||||||
|
| OptLevel::Size
|
||||||
|
| OptLevel::SizeMin
|
||||||
|
| OptLevel::Aggressive => {
|
||||||
flags_builder.set("opt_level", "speed_and_size").unwrap();
|
flags_builder.set("opt_level", "speed_and_size").unwrap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,9 +62,9 @@ use cranelift_codegen::entity::SecondaryMap;
|
|||||||
use cranelift_codegen::ir::Fact;
|
use cranelift_codegen::ir::Fact;
|
||||||
use cranelift_codegen::ir::entities::AnyEntity;
|
use cranelift_codegen::ir::entities::AnyEntity;
|
||||||
use cranelift_codegen::write::{FuncWriter, PlainWriter};
|
use cranelift_codegen::write::{FuncWriter, PlainWriter};
|
||||||
use rustc_middle::ty::layout::FnAbiOf;
|
|
||||||
use rustc_middle::ty::print::with_no_trimmed_paths;
|
use rustc_middle::ty::print::with_no_trimmed_paths;
|
||||||
use rustc_session::config::{OutputFilenames, OutputType};
|
use rustc_session::config::{OutputFilenames, OutputType};
|
||||||
|
use rustc_target::abi::call::FnAbi;
|
||||||
|
|
||||||
use crate::prelude::*;
|
use crate::prelude::*;
|
||||||
|
|
||||||
@ -76,17 +76,18 @@ pub(crate) struct CommentWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl CommentWriter {
|
impl CommentWriter {
|
||||||
pub(crate) fn new<'tcx>(tcx: TyCtxt<'tcx>, instance: Instance<'tcx>) -> Self {
|
pub(crate) fn new<'tcx>(
|
||||||
|
tcx: TyCtxt<'tcx>,
|
||||||
|
instance: Instance<'tcx>,
|
||||||
|
fn_abi: &'tcx FnAbi<'tcx, Ty<'tcx>>,
|
||||||
|
) -> Self {
|
||||||
let enabled = should_write_ir(tcx);
|
let enabled = should_write_ir(tcx);
|
||||||
let global_comments = if enabled {
|
let global_comments = if enabled {
|
||||||
with_no_trimmed_paths!({
|
with_no_trimmed_paths!({
|
||||||
vec![
|
vec![
|
||||||
format!("symbol {}", tcx.symbol_name(instance).name),
|
format!("symbol {}", tcx.symbol_name(instance).name),
|
||||||
format!("instance {:?}", instance),
|
format!("instance {:?}", instance),
|
||||||
format!(
|
format!("abi {:?}", fn_abi),
|
||||||
"abi {:?}",
|
|
||||||
RevealAllLayoutCx(tcx).fn_abi_of_instance(instance, ty::List::empty())
|
|
||||||
),
|
|
||||||
String::new(),
|
String::new(),
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
|
@ -30,5 +30,5 @@ pub(crate) fn trap_unimplemented(fx: &mut FunctionCx<'_, '_, '_>, msg: impl AsRe
|
|||||||
let one = fx.bcx.ins().iconst(types::I32, 1);
|
let one = fx.bcx.ins().iconst(types::I32, 1);
|
||||||
fx.lib_call("exit", vec![AbiParam::new(types::I32)], vec![], &[one]);
|
fx.lib_call("exit", vec![AbiParam::new(types::I32)], vec![], &[one]);
|
||||||
|
|
||||||
fx.bcx.ins().trap(TrapCode::User(!0));
|
fx.bcx.ins().trap(TrapCode::user(3).unwrap());
|
||||||
}
|
}
|
||||||
|
@ -203,7 +203,7 @@ const EXCEPTIONS_CRANELIFT: ExceptionList = &[
|
|||||||
("cranelift-module", "Apache-2.0 WITH LLVM-exception"),
|
("cranelift-module", "Apache-2.0 WITH LLVM-exception"),
|
||||||
("cranelift-native", "Apache-2.0 WITH LLVM-exception"),
|
("cranelift-native", "Apache-2.0 WITH LLVM-exception"),
|
||||||
("cranelift-object", "Apache-2.0 WITH LLVM-exception"),
|
("cranelift-object", "Apache-2.0 WITH LLVM-exception"),
|
||||||
("mach", "BSD-2-Clause"),
|
("mach2", "BSD-2-Clause OR MIT OR Apache-2.0"),
|
||||||
("regalloc2", "Apache-2.0 WITH LLVM-exception"),
|
("regalloc2", "Apache-2.0 WITH LLVM-exception"),
|
||||||
("target-lexicon", "Apache-2.0 WITH LLVM-exception"),
|
("target-lexicon", "Apache-2.0 WITH LLVM-exception"),
|
||||||
("wasmtime-jit-icache-coherence", "Apache-2.0 WITH LLVM-exception"),
|
("wasmtime-jit-icache-coherence", "Apache-2.0 WITH LLVM-exception"),
|
||||||
@ -537,7 +537,7 @@ const PERMITTED_CRANELIFT_DEPENDENCIES: &[&str] = &[
|
|||||||
"libc",
|
"libc",
|
||||||
"libloading",
|
"libloading",
|
||||||
"log",
|
"log",
|
||||||
"mach",
|
"mach2",
|
||||||
"memchr",
|
"memchr",
|
||||||
"object",
|
"object",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
@ -554,9 +554,6 @@ const PERMITTED_CRANELIFT_DEPENDENCIES: &[&str] = &[
|
|||||||
"unicode-ident",
|
"unicode-ident",
|
||||||
"version_check",
|
"version_check",
|
||||||
"wasmtime-jit-icache-coherence",
|
"wasmtime-jit-icache-coherence",
|
||||||
"winapi",
|
|
||||||
"winapi-i686-pc-windows-gnu",
|
|
||||||
"winapi-x86_64-pc-windows-gnu",
|
|
||||||
"windows-sys",
|
"windows-sys",
|
||||||
"windows-targets",
|
"windows-targets",
|
||||||
"windows_aarch64_gnullvm",
|
"windows_aarch64_gnullvm",
|
||||||
|
Loading…
Reference in New Issue
Block a user