Compare commits
	
		
			No commits in common. "c8-stream-rhel8-bootstrap" and "c8-stream-rhel8" have entirely different histories.
		
	
	
		
			c8-stream-
			...
			c8-stream-
		
	
		
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1 +1,2 @@ | |||||||
| SOURCES/rustc-1.40.0-src.tar.xz | SOURCES/rustc-1.84.1-src.tar.xz | ||||||
|  | SOURCES/wasi-libc-wasi-sdk-25.tar.gz | ||||||
|  | |||||||
| @ -1 +1,2 @@ | |||||||
| 34aa1c281487724648b39439bc512f958a3da4ad SOURCES/rustc-1.40.0-src.tar.xz | 787899153e848b012d8bbd6ec0baf0ed5e189831 SOURCES/rustc-1.84.1-src.tar.xz | ||||||
|  | c42dc30854ecbce5380304c38bd48b5911d1ce62 SOURCES/wasi-libc-wasi-sdk-25.tar.gz | ||||||
|  | |||||||
| @ -1,32 +0,0 @@ | |||||||
| From f6832adadb84364ce0c81fa02910b3706f441abc Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Mark Rousskov <mark.simulacrum@gmail.com> |  | ||||||
| Date: Wed, 6 Nov 2019 15:17:02 -0500 |  | ||||||
| Subject: [PATCH] Compiletest bump to stage0 bootstrap libtest |  | ||||||
| 
 |  | ||||||
| ---
 |  | ||||||
|  src/tools/compiletest/src/main.rs | 2 ++ |  | ||||||
|  1 file changed, 2 insertions(+) |  | ||||||
| 
 |  | ||||||
| diff --git a/src/tools/compiletest/src/main.rs b/src/tools/compiletest/src/main.rs
 |  | ||||||
| index 34435819a2c4..b115539b4af3 100644
 |  | ||||||
| --- a/src/tools/compiletest/src/main.rs
 |  | ||||||
| +++ b/src/tools/compiletest/src/main.rs
 |  | ||||||
| @@ -568,6 +568,7 @@ pub fn test_opts(config: &Config) -> test::TestOpts {
 |  | ||||||
|          skip: vec![], |  | ||||||
|          list: false, |  | ||||||
|          options: test::Options::new(), |  | ||||||
| +        time_options: None,
 |  | ||||||
|      } |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| @@ -703,6 +704,7 @@ pub fn make_test(config: &Config, testpaths: &TestPaths) -> Vec<test::TestDescAn
 |  | ||||||
|                      ignore, |  | ||||||
|                      should_panic, |  | ||||||
|                      allow_fail: false, |  | ||||||
| +                    test_type: test::TestType::Unknown,
 |  | ||||||
|                  }, |  | ||||||
|                  testfn: make_test_closure(config, early_props.ignore, testpaths, revision), |  | ||||||
|              } |  | ||||||
| -- 
 |  | ||||||
| 2.24.1 |  | ||||||
| 
 |  | ||||||
| @ -0,0 +1,53 @@ | |||||||
|  | From 5273432acfae75d6e509bbebcf8d28b0f3d820d0 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Josh Stone <jistone@redhat.com> | ||||||
|  | Date: Fri, 9 Jun 2023 15:23:08 -0700 | ||||||
|  | Subject: [PATCH] Let environment variables override some default CPUs | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  .../src/spec/targets/powerpc64le_unknown_linux_gnu.rs           | 2 +- | ||||||
|  |  .../rustc_target/src/spec/targets/s390x_unknown_linux_gnu.rs    | 2 +- | ||||||
|  |  .../rustc_target/src/spec/targets/x86_64_unknown_linux_gnu.rs   | 2 +- | ||||||
|  |  3 files changed, 3 insertions(+), 3 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/powerpc64le_unknown_linux_gnu.rs b/compiler/rustc_target/src/spec/targets/powerpc64le_unknown_linux_gnu.rs
 | ||||||
|  | index 23913687a1fd..3253fbc84c74 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/powerpc64le_unknown_linux_gnu.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/powerpc64le_unknown_linux_gnu.rs
 | ||||||
|  | @@ -2,7 +2,7 @@
 | ||||||
|  |   | ||||||
|  |  pub(crate) fn target() -> Target { | ||||||
|  |      let mut base = base::linux_gnu::opts(); | ||||||
|  | -    base.cpu = "ppc64le".into();
 | ||||||
|  | +    base.cpu = option_env!("RUSTC_TARGET_CPU_PPC64LE").unwrap_or("ppc64le").into();
 | ||||||
|  |      base.add_pre_link_args(LinkerFlavor::Gnu(Cc::Yes, Lld::No), &["-m64"]); | ||||||
|  |      base.max_atomic_width = Some(64); | ||||||
|  |      base.stack_probes = StackProbeType::Inline; | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/s390x_unknown_linux_gnu.rs b/compiler/rustc_target/src/spec/targets/s390x_unknown_linux_gnu.rs
 | ||||||
|  | index a84a18a433ff..441af1018ff3 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/s390x_unknown_linux_gnu.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/s390x_unknown_linux_gnu.rs
 | ||||||
|  | @@ -5,7 +5,7 @@ pub(crate) fn target() -> Target {
 | ||||||
|  |      let mut base = base::linux_gnu::opts(); | ||||||
|  |      base.endian = Endian::Big; | ||||||
|  |      // z10 is the oldest CPU supported by LLVM | ||||||
|  | -    base.cpu = "z10".into();
 | ||||||
|  | +    base.cpu = option_env!("RUSTC_TARGET_CPU_S390X").unwrap_or("z10").into();
 | ||||||
|  |      base.max_atomic_width = Some(128); | ||||||
|  |      base.min_global_align = Some(16); | ||||||
|  |      base.stack_probes = StackProbeType::Inline; | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/x86_64_unknown_linux_gnu.rs b/compiler/rustc_target/src/spec/targets/x86_64_unknown_linux_gnu.rs
 | ||||||
|  | index 59ec6c7f9d5f..b6f1be890b20 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/x86_64_unknown_linux_gnu.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/x86_64_unknown_linux_gnu.rs
 | ||||||
|  | @@ -2,7 +2,7 @@
 | ||||||
|  |   | ||||||
|  |  pub(crate) fn target() -> Target { | ||||||
|  |      let mut base = base::linux_gnu::opts(); | ||||||
|  | -    base.cpu = "x86-64".into();
 | ||||||
|  | +    base.cpu = option_env!("RUSTC_TARGET_CPU_X86_64").unwrap_or("x86-64").into();
 | ||||||
|  |      base.plt_by_default = false; | ||||||
|  |      base.max_atomic_width = Some(64); | ||||||
|  |      base.add_pre_link_args(LinkerFlavor::Gnu(Cc::Yes, Lld::No), &["-m64"]); | ||||||
|  | -- 
 | ||||||
|  | 2.47.1 | ||||||
|  | 
 | ||||||
							
								
								
									
										39
									
								
								SOURCES/0001-Only-translate-profile-flags-for-Clang.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								SOURCES/0001-Only-translate-profile-flags-for-Clang.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | |||||||
|  | From e4e678eb9cbd90acf2ba51e9ec0209b05c4403b5 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Josh Stone <cuviper@gmail.com> | ||||||
|  | Date: Thu, 9 Jan 2025 16:47:10 -0800 | ||||||
|  | Subject: [PATCH] Only translate profile flags for Clang | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  src/flags.rs | 16 +++++++++------- | ||||||
|  |  1 file changed, 9 insertions(+), 7 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/flags.rs b/src/flags.rs
 | ||||||
|  | index 81834cf625f7..1a53c1b2345c 100644
 | ||||||
|  | --- a/src/flags.rs
 | ||||||
|  | +++ b/src/flags.rs
 | ||||||
|  | @@ -201,13 +201,15 @@ impl<'this> RustcCodegenFlags<'this> {
 | ||||||
|  |                  if self.no_vectorize_slp { | ||||||
|  |                      push_if_supported("-fno-slp-vectorize".into()); | ||||||
|  |                  } | ||||||
|  | -                // https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-fprofile-generate
 | ||||||
|  | -                if let Some(value) = self.profile_generate {
 | ||||||
|  | -                    push_if_supported(format!("-fprofile-generate={value}").into());
 | ||||||
|  | -                }
 | ||||||
|  | -                // https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-fprofile-use
 | ||||||
|  | -                if let Some(value) = self.profile_use {
 | ||||||
|  | -                    push_if_supported(format!("-fprofile-use={value}").into());
 | ||||||
|  | +                if let ToolFamily::Clang { .. } = family {
 | ||||||
|  | +                    // https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-fprofile-generate
 | ||||||
|  | +                    if let Some(value) = self.profile_generate {
 | ||||||
|  | +                        push_if_supported(format!("-fprofile-generate={value}").into());
 | ||||||
|  | +                    }
 | ||||||
|  | +                    // https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-fprofile-use
 | ||||||
|  | +                    if let Some(value) = self.profile_use {
 | ||||||
|  | +                        push_if_supported(format!("-fprofile-use={value}").into());
 | ||||||
|  | +                    }
 | ||||||
|  |                  } | ||||||
|  |                  // https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-mguard | ||||||
|  |                  if let Some(value) = self.control_flow_guard { | ||||||
|  | -- 
 | ||||||
|  | 2.47.1 | ||||||
|  | 
 | ||||||
| @ -1,52 +0,0 @@ | |||||||
| From b6fd4598c5367e78b5841fd99412484f0e86fc21 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Amanieu d'Antras <amanieu@gmail.com> |  | ||||||
| Date: Wed, 1 Jan 2020 17:11:45 +0100 |  | ||||||
| Subject: [PATCH] Update the barrier cache during ARM EHABI unwinding |  | ||||||
| 
 |  | ||||||
| ---
 |  | ||||||
|  src/libpanic_unwind/gcc.rs | 8 +++++++- |  | ||||||
|  src/libunwind/libunwind.rs | 2 ++ |  | ||||||
|  2 files changed, 9 insertions(+), 1 deletion(-) |  | ||||||
| 
 |  | ||||||
| diff --git a/src/libpanic_unwind/gcc.rs b/src/libpanic_unwind/gcc.rs
 |  | ||||||
| index 4f572fe21b30..328d0d4ce7be 100644
 |  | ||||||
| --- a/src/libpanic_unwind/gcc.rs
 |  | ||||||
| +++ b/src/libpanic_unwind/gcc.rs
 |  | ||||||
| @@ -187,7 +187,13 @@ cfg_if::cfg_if! {
 |  | ||||||
|                  match eh_action { |  | ||||||
|                      EHAction::None | |  | ||||||
|                      EHAction::Cleanup(_) => return continue_unwind(exception_object, context), |  | ||||||
| -                    EHAction::Catch(_) => return uw::_URC_HANDLER_FOUND,
 |  | ||||||
| +                    EHAction::Catch(_) => {
 |  | ||||||
| +                        // EHABI requires the personality routine to update the
 |  | ||||||
| +                        // SP value in the barrier cache of the exception object.
 |  | ||||||
| +                        (*exception_object).private[5] =
 |  | ||||||
| +                            uw::_Unwind_GetGR(context, uw::UNWIND_SP_REG);
 |  | ||||||
| +                        return uw::_URC_HANDLER_FOUND;
 |  | ||||||
| +                    }
 |  | ||||||
|                      EHAction::Terminate => return uw::_URC_FAILURE, |  | ||||||
|                  } |  | ||||||
|              } else { |  | ||||||
| diff --git a/src/libunwind/libunwind.rs b/src/libunwind/libunwind.rs
 |  | ||||||
| index 0b39503c0d03..30658ce328d8 100644
 |  | ||||||
| --- a/src/libunwind/libunwind.rs
 |  | ||||||
| +++ b/src/libunwind/libunwind.rs
 |  | ||||||
| @@ -23,6 +23,7 @@ pub type _Unwind_Word = uintptr_t;
 |  | ||||||
|  pub type _Unwind_Ptr = uintptr_t; |  | ||||||
|  pub type _Unwind_Trace_Fn = extern "C" fn(ctx: *mut _Unwind_Context, arg: *mut c_void) |  | ||||||
|                                            -> _Unwind_Reason_Code; |  | ||||||
| +
 |  | ||||||
|  #[cfg(target_arch = "x86")] |  | ||||||
|  pub const unwinder_private_data_size: usize = 5; |  | ||||||
|   |  | ||||||
| @@ -151,6 +152,7 @@ if #[cfg(all(any(target_os = "ios", target_os = "netbsd", not(target_arch = "arm
 |  | ||||||
|      use _Unwind_VRS_DataRepresentation::*; |  | ||||||
|   |  | ||||||
|      pub const UNWIND_POINTER_REG: c_int = 12; |  | ||||||
| +    pub const UNWIND_SP_REG: c_int = 13;
 |  | ||||||
|      pub const UNWIND_IP_REG: c_int = 15; |  | ||||||
|   |  | ||||||
|      #[cfg_attr(all(feature = "llvm-libunwind", |  | ||||||
| -- 
 |  | ||||||
| 2.24.1 |  | ||||||
| 
 |  | ||||||
							
								
								
									
										80
									
								
								SOURCES/0001-Use-lld-provided-by-system.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								SOURCES/0001-Use-lld-provided-by-system.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,80 @@ | |||||||
|  | From 3d8c6d095581e8d7585f3772cfd16f6367f3c008 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Josh Stone <jistone@redhat.com> | ||||||
|  | Date: Fri, 16 Aug 2024 10:12:58 -0700 | ||||||
|  | Subject: [PATCH] Use lld provided by system | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  compiler/rustc_target/src/spec/base/wasm.rs                    | 3 +-- | ||||||
|  |  .../src/spec/targets/aarch64_unknown_none_softfloat.rs         | 2 +- | ||||||
|  |  compiler/rustc_target/src/spec/targets/aarch64_unknown_uefi.rs | 1 + | ||||||
|  |  compiler/rustc_target/src/spec/targets/x86_64_unknown_none.rs  | 2 +- | ||||||
|  |  compiler/rustc_target/src/spec/targets/x86_64_unknown_uefi.rs  | 1 + | ||||||
|  |  5 files changed, 5 insertions(+), 4 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/base/wasm.rs b/compiler/rustc_target/src/spec/base/wasm.rs
 | ||||||
|  | index f237391016e7..08bcd9699b4a 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/base/wasm.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/base/wasm.rs
 | ||||||
|  | @@ -85,8 +85,7 @@ macro_rules! args {
 | ||||||
|  |          // arguments just yet | ||||||
|  |          limit_rdylib_exports: false, | ||||||
|  |   | ||||||
|  | -        // we use the LLD shipped with the Rust toolchain by default
 | ||||||
|  | -        linker: Some("rust-lld".into()),
 | ||||||
|  | +        linker: Some("lld".into()),
 | ||||||
|  |          linker_flavor: LinkerFlavor::WasmLld(Cc::No), | ||||||
|  |   | ||||||
|  |          pre_link_args, | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/aarch64_unknown_none_softfloat.rs b/compiler/rustc_target/src/spec/targets/aarch64_unknown_none_softfloat.rs
 | ||||||
|  | index 222d5651b521..4b780bc8a8e7 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/aarch64_unknown_none_softfloat.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/aarch64_unknown_none_softfloat.rs
 | ||||||
|  | @@ -14,7 +14,7 @@ pub fn target() -> Target {
 | ||||||
|  |      let opts = TargetOptions { | ||||||
|  |          abi: "softfloat".into(), | ||||||
|  |          linker_flavor: LinkerFlavor::Gnu(Cc::No, Lld::Yes), | ||||||
|  | -        linker: Some("rust-lld".into()),
 | ||||||
|  | +        linker: Some("lld".into()),
 | ||||||
|  |          features: "+v8a,+strict-align,-neon,-fp-armv8".into(), | ||||||
|  |          relocation_model: RelocModel::Static, | ||||||
|  |          disable_redzone: true, | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/aarch64_unknown_uefi.rs b/compiler/rustc_target/src/spec/targets/aarch64_unknown_uefi.rs
 | ||||||
|  | index 429303170b6b..19d4ec53f6d8 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/aarch64_unknown_uefi.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/aarch64_unknown_uefi.rs
 | ||||||
|  | @@ -9,6 +9,7 @@ pub fn target() -> Target {
 | ||||||
|  |      base.max_atomic_width = Some(128); | ||||||
|  |      base.add_pre_link_args(LinkerFlavor::Msvc(Lld::No), &["/machine:arm64"]); | ||||||
|  |      base.features = "+v8a".into(); | ||||||
|  | +    base.linker = Some("lld".into());
 | ||||||
|  |   | ||||||
|  |      Target { | ||||||
|  |          llvm_target: "aarch64-unknown-windows".into(), | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/x86_64_unknown_none.rs b/compiler/rustc_target/src/spec/targets/x86_64_unknown_none.rs
 | ||||||
|  | index 549706998d46..b7e9158ddef5 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/x86_64_unknown_none.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/x86_64_unknown_none.rs
 | ||||||
|  | @@ -17,7 +17,7 @@ pub fn target() -> Target {
 | ||||||
|  |          static_position_independent_executables: true, | ||||||
|  |          relro_level: RelroLevel::Full, | ||||||
|  |          linker_flavor: LinkerFlavor::Gnu(Cc::No, Lld::Yes), | ||||||
|  | -        linker: Some("rust-lld".into()),
 | ||||||
|  | +        linker: Some("lld".into()),
 | ||||||
|  |          features: "-mmx,-sse,-sse2,-sse3,-ssse3,-sse4.1,-sse4.2,-avx,-avx2,+soft-float".into(), | ||||||
|  |          supported_sanitizers: SanitizerSet::KCFI | SanitizerSet::KERNELADDRESS, | ||||||
|  |          disable_redzone: true, | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/x86_64_unknown_uefi.rs b/compiler/rustc_target/src/spec/targets/x86_64_unknown_uefi.rs
 | ||||||
|  | index 6da1fcca58c8..c84ae44576d4 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/x86_64_unknown_uefi.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/x86_64_unknown_uefi.rs
 | ||||||
|  | @@ -16,6 +16,7 @@ pub fn target() -> Target {
 | ||||||
|  |      base.plt_by_default = false; | ||||||
|  |      base.max_atomic_width = Some(64); | ||||||
|  |      base.entry_abi = Conv::X86_64Win64; | ||||||
|  | +    base.linker = Some("lld".into());
 | ||||||
|  |   | ||||||
|  |      // We disable MMX and SSE for now, even though UEFI allows using them. Problem is, you have to | ||||||
|  |      // enable these CPU features explicitly before their first use, otherwise their instructions | ||||||
|  | -- 
 | ||||||
|  | 2.46.0 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,102 @@ | |||||||
|  | From 8d4d52446347872816ab51958e9f3162cf722ee6 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Josh Stone <jistone@redhat.com> | ||||||
|  | Date: Thu, 28 Sep 2023 18:14:28 -0700 | ||||||
|  | Subject: [PATCH 1/2] bootstrap: allow disabling target self-contained | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  config.example.toml                           | 5 +++++ | ||||||
|  |  src/bootstrap/src/core/build_steps/compile.rs | 4 ++++ | ||||||
|  |  src/bootstrap/src/core/config/config.rs       | 8 ++++++++ | ||||||
|  |  src/bootstrap/src/lib.rs                      | 5 +++++ | ||||||
|  |  4 files changed, 22 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/config.example.toml b/config.example.toml
 | ||||||
|  | index d3233ad17b51..6a1f097c20cb 100644
 | ||||||
|  | --- a/config.example.toml
 | ||||||
|  | +++ b/config.example.toml
 | ||||||
|  | @@ -916,6 +916,11 @@
 | ||||||
|  |  # argument as the test binary. | ||||||
|  |  #runner = <none> (string) | ||||||
|  |   | ||||||
|  | +# Copy libc and CRT objects into the target lib/self-contained/ directory.
 | ||||||
|  | +# Enabled by default on `musl`, `wasi`, and `windows-gnu` targets. Other
 | ||||||
|  | +# targets may ignore this setting if they have nothing to be contained.
 | ||||||
|  | +#self-contained = <platform-specific> (bool)
 | ||||||
|  | +
 | ||||||
|  |  # ============================================================================= | ||||||
|  |  # Distribution options | ||||||
|  |  # | ||||||
|  | diff --git a/src/bootstrap/src/core/build_steps/compile.rs b/src/bootstrap/src/core/build_steps/compile.rs
 | ||||||
|  | index 8e088682f92d..843b7123b120 100644
 | ||||||
|  | --- a/src/bootstrap/src/core/build_steps/compile.rs
 | ||||||
|  | +++ b/src/bootstrap/src/core/build_steps/compile.rs
 | ||||||
|  | @@ -346,6 +346,10 @@ fn copy_self_contained_objects(
 | ||||||
|  |      compiler: &Compiler, | ||||||
|  |      target: TargetSelection, | ||||||
|  |  ) -> Vec<(PathBuf, DependencyType)> { | ||||||
|  | +    if builder.self_contained(target) != Some(true) {
 | ||||||
|  | +        return vec![];
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  |      let libdir_self_contained = | ||||||
|  |          builder.sysroot_target_libdir(*compiler, target).join("self-contained"); | ||||||
|  |      t!(fs::create_dir_all(&libdir_self_contained)); | ||||||
|  | diff --git a/src/bootstrap/src/core/config/config.rs b/src/bootstrap/src/core/config/config.rs
 | ||||||
|  | index e706aba977b6..a55d98e94dd8 100644
 | ||||||
|  | --- a/src/bootstrap/src/core/config/config.rs
 | ||||||
|  | +++ b/src/bootstrap/src/core/config/config.rs
 | ||||||
|  | @@ -627,6 +627,7 @@ pub struct Target {
 | ||||||
|  |      pub runner: Option<String>, | ||||||
|  |      pub no_std: bool, | ||||||
|  |      pub codegen_backends: Option<Vec<String>>, | ||||||
|  | +    pub self_contained: bool,
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  impl Target { | ||||||
|  | @@ -638,6 +639,9 @@ pub fn from_triple(triple: &str) -> Self {
 | ||||||
|  |          if triple.contains("emscripten") { | ||||||
|  |              target.runner = Some("node".into()); | ||||||
|  |          } | ||||||
|  | +        if triple.contains("-musl") || triple.contains("-wasi") || triple.contains("-windows-gnu") {
 | ||||||
|  | +            target.self_contained = true;
 | ||||||
|  | +        }
 | ||||||
|  |          target | ||||||
|  |      } | ||||||
|  |  } | ||||||
|  | @@ -1213,6 +1217,7 @@ struct TomlTarget {
 | ||||||
|  |          no_std: Option<bool> = "no-std", | ||||||
|  |          codegen_backends: Option<Vec<String>> = "codegen-backends", | ||||||
|  |          runner: Option<String> = "runner", | ||||||
|  | +        self_contained: Option<bool> = "self-contained",
 | ||||||
|  |      } | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | @@ -2038,6 +2043,9 @@ fn get_table(option: &str) -> Result<TomlConfig, toml::de::Error> {
 | ||||||
|  |                  if let Some(s) = cfg.no_std { | ||||||
|  |                      target.no_std = s; | ||||||
|  |                  } | ||||||
|  | +                if let Some(s) = cfg.self_contained {
 | ||||||
|  | +                    target.self_contained = s;
 | ||||||
|  | +                }
 | ||||||
|  |                  target.cc = cfg.cc.map(PathBuf::from); | ||||||
|  |                  target.cxx = cfg.cxx.map(PathBuf::from); | ||||||
|  |                  target.ar = cfg.ar.map(PathBuf::from); | ||||||
|  | diff --git a/src/bootstrap/src/lib.rs b/src/bootstrap/src/lib.rs
 | ||||||
|  | index c384fd6bf435..a101c010b740 100644
 | ||||||
|  | --- a/src/bootstrap/src/lib.rs
 | ||||||
|  | +++ b/src/bootstrap/src/lib.rs
 | ||||||
|  | @@ -1351,6 +1351,11 @@ fn no_std(&self, target: TargetSelection) -> Option<bool> {
 | ||||||
|  |          self.config.target_config.get(&target).map(|t| t.no_std) | ||||||
|  |      } | ||||||
|  |   | ||||||
|  | +    /// Returns `true` if this is a self-contained `target`, if defined
 | ||||||
|  | +    fn self_contained(&self, target: TargetSelection) -> Option<bool> {
 | ||||||
|  | +        self.config.target_config.get(&target).map(|t| t.self_contained)
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  |      /// Returns `true` if the target will be tested using the `remote-test-client` | ||||||
|  |      /// and `remote-test-server` binaries. | ||||||
|  |      fn remote_tested(&self, target: TargetSelection) -> bool { | ||||||
|  | -- 
 | ||||||
|  | 2.47.1 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,98 @@ | |||||||
|  | From 21d53eca2af5f04c0aa6b898f99f58e0e093cfdd Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Josh Stone <jistone@redhat.com> | ||||||
|  | Date: Thu, 28 Sep 2023 18:18:16 -0700 | ||||||
|  | Subject: [PATCH 2/2] set an external library path for wasm32-wasi | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  compiler/rustc_codegen_ssa/src/back/link.rs            | 10 ++++++++++ | ||||||
|  |  compiler/rustc_target/src/spec/mod.rs                  |  4 ++++ | ||||||
|  |  .../rustc_target/src/spec/targets/wasm32_wasip1.rs     |  7 ++++--- | ||||||
|  |  3 files changed, 18 insertions(+), 3 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/compiler/rustc_codegen_ssa/src/back/link.rs b/compiler/rustc_codegen_ssa/src/back/link.rs
 | ||||||
|  | index 5149e3a12f23..cf62fbdc7f59 100644
 | ||||||
|  | --- a/compiler/rustc_codegen_ssa/src/back/link.rs
 | ||||||
|  | +++ b/compiler/rustc_codegen_ssa/src/back/link.rs
 | ||||||
|  | @@ -1663,6 +1663,12 @@ fn get_object_file_path(sess: &Session, name: &str, self_contained: bool) -> Pat
 | ||||||
|  |              return file_path; | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | +    if let Some(lib_path) = &sess.target.options.external_lib_path {
 | ||||||
|  | +        let file_path = Path::new(lib_path.as_ref()).join(name);
 | ||||||
|  | +        if file_path.exists() {
 | ||||||
|  | +            return file_path;
 | ||||||
|  | +        }
 | ||||||
|  | +    }
 | ||||||
|  |      for search_path in sess.target_filesearch().search_paths(PathKind::Native) { | ||||||
|  |          let file_path = search_path.dir.join(name); | ||||||
|  |          if file_path.exists() { | ||||||
|  | @@ -2163,6 +2169,10 @@ fn add_library_search_dirs(
 | ||||||
|  |              ControlFlow::<()>::Continue(()) | ||||||
|  |          }, | ||||||
|  |      ); | ||||||
|  | +
 | ||||||
|  | +    if let Some(lib_path) = &sess.target.options.external_lib_path {
 | ||||||
|  | +        cmd.include_path(Path::new(lib_path.as_ref()));
 | ||||||
|  | +    }
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  /// Add options making relocation sections in the produced ELF files read-only | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/mod.rs b/compiler/rustc_target/src/spec/mod.rs
 | ||||||
|  | index 321ab40403a3..54791c8892d8 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/mod.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/mod.rs
 | ||||||
|  | @@ -2155,6 +2155,7 @@ pub struct TargetOptions {
 | ||||||
|  |      /// Objects to link before and after all other object code. | ||||||
|  |      pub pre_link_objects: CrtObjects, | ||||||
|  |      pub post_link_objects: CrtObjects, | ||||||
|  | +    pub external_lib_path: Option<StaticCow<str>>,
 | ||||||
|  |      /// Same as `(pre|post)_link_objects`, but when self-contained linking mode is enabled. | ||||||
|  |      pub pre_link_objects_self_contained: CrtObjects, | ||||||
|  |      pub post_link_objects_self_contained: CrtObjects, | ||||||
|  | @@ -2651,6 +2652,7 @@ fn default() -> TargetOptions {
 | ||||||
|  |              relro_level: RelroLevel::None, | ||||||
|  |              pre_link_objects: Default::default(), | ||||||
|  |              post_link_objects: Default::default(), | ||||||
|  | +            external_lib_path: None,
 | ||||||
|  |              pre_link_objects_self_contained: Default::default(), | ||||||
|  |              post_link_objects_self_contained: Default::default(), | ||||||
|  |              link_self_contained: LinkSelfContainedDefault::False, | ||||||
|  | @@ -3355,6 +3357,7 @@ macro_rules! key {
 | ||||||
|  |          key!(linker_is_gnu_json = "linker-is-gnu", bool); | ||||||
|  |          key!(pre_link_objects = "pre-link-objects", link_objects); | ||||||
|  |          key!(post_link_objects = "post-link-objects", link_objects); | ||||||
|  | +        key!(external_lib_path, optional);
 | ||||||
|  |          key!(pre_link_objects_self_contained = "pre-link-objects-fallback", link_objects); | ||||||
|  |          key!(post_link_objects_self_contained = "post-link-objects-fallback", link_objects); | ||||||
|  |          // Deserializes the backwards-compatible variants of `-Clink-self-contained` | ||||||
|  | @@ -3636,6 +3639,7 @@ macro_rules! target_option_val {
 | ||||||
|  |          target_option_val!(linker_is_gnu_json, "linker-is-gnu"); | ||||||
|  |          target_option_val!(pre_link_objects); | ||||||
|  |          target_option_val!(post_link_objects); | ||||||
|  | +        target_option_val!(external_lib_path);
 | ||||||
|  |          target_option_val!(pre_link_objects_self_contained, "pre-link-objects-fallback"); | ||||||
|  |          target_option_val!(post_link_objects_self_contained, "post-link-objects-fallback"); | ||||||
|  |          target_option_val!(link_args - pre_link_args_json, "pre-link-args"); | ||||||
|  | diff --git a/compiler/rustc_target/src/spec/targets/wasm32_wasip1.rs b/compiler/rustc_target/src/spec/targets/wasm32_wasip1.rs
 | ||||||
|  | index 1cd30f21bec1..9a752d5712a6 100644
 | ||||||
|  | --- a/compiler/rustc_target/src/spec/targets/wasm32_wasip1.rs
 | ||||||
|  | +++ b/compiler/rustc_target/src/spec/targets/wasm32_wasip1.rs
 | ||||||
|  | @@ -19,11 +19,12 @@ pub(crate) fn target() -> Target {
 | ||||||
|  |      options.env = "p1".into(); | ||||||
|  |      options.add_pre_link_args(LinkerFlavor::WasmLld(Cc::Yes), &["--target=wasm32-wasip1"]); | ||||||
|  |   | ||||||
|  | -    options.pre_link_objects_self_contained = crt_objects::pre_wasi_self_contained();
 | ||||||
|  | -    options.post_link_objects_self_contained = crt_objects::post_wasi_self_contained();
 | ||||||
|  | +    options.pre_link_objects = crt_objects::pre_wasi_self_contained();
 | ||||||
|  | +    options.post_link_objects = crt_objects::post_wasi_self_contained();
 | ||||||
|  |   | ||||||
|  |      // FIXME: Figure out cases in which WASM needs to link with a native toolchain. | ||||||
|  | -    options.link_self_contained = LinkSelfContainedDefault::True;
 | ||||||
|  | +    options.link_self_contained = LinkSelfContainedDefault::False;
 | ||||||
|  | +    options.external_lib_path = Some("/usr/wasm32-wasi/lib/wasm32-wasi".into());
 | ||||||
|  |   | ||||||
|  |      // Right now this is a bit of a workaround but we're currently saying that | ||||||
|  |      // the target by default has a static crt which we're taking as a signal | ||||||
|  | -- 
 | ||||||
|  | 2.47.1 | ||||||
|  | 
 | ||||||
							
								
								
									
										2
									
								
								SOURCES/cargo_vendor.attr
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								SOURCES/cargo_vendor.attr
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | %__cargo_vendor_path     ^%{_defaultlicensedir}(/[^/]+)+/cargo-vendor.txt$ | ||||||
|  | %__cargo_vendor_provides %{_rpmconfigdir}/cargo_vendor.prov | ||||||
							
								
								
									
										127
									
								
								SOURCES/cargo_vendor.prov
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										127
									
								
								SOURCES/cargo_vendor.prov
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,127 @@ | |||||||
|  | #! /usr/bin/python3 -s | ||||||
|  | # Stripped down replacement for cargo2rpm parse-vendor-manifest | ||||||
|  | 
 | ||||||
|  | import re | ||||||
|  | import subprocess | ||||||
|  | import sys | ||||||
|  | from typing import Optional | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | VERSION_REGEX = re.compile( | ||||||
|  |     r""" | ||||||
|  |     ^ | ||||||
|  |     (?P<major>0|[1-9]\d*) | ||||||
|  |     \.(?P<minor>0|[1-9]\d*) | ||||||
|  |     \.(?P<patch>0|[1-9]\d*) | ||||||
|  |     (?:-(?P<pre>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))? | ||||||
|  |     (?:\+(?P<build>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$ | ||||||
|  |     """, | ||||||
|  |     re.VERBOSE, | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class Version: | ||||||
|  |     """ | ||||||
|  |     Version that adheres to the "semantic versioning" format. | ||||||
|  |     """ | ||||||
|  | 
 | ||||||
|  |     def __init__(self, major: int, minor: int, patch: int, pre: Optional[str] = None, build: Optional[str] = None): | ||||||
|  |         self.major: int = major | ||||||
|  |         self.minor: int = minor | ||||||
|  |         self.patch: int = patch | ||||||
|  |         self.pre: Optional[str] = pre | ||||||
|  |         self.build: Optional[str] = build | ||||||
|  | 
 | ||||||
|  |     @staticmethod | ||||||
|  |     def parse(version: str) -> "Version": | ||||||
|  |         """ | ||||||
|  |         Parses a version string and return a `Version` object. | ||||||
|  |         Raises a `ValueError` if the string does not match the expected format. | ||||||
|  |         """ | ||||||
|  | 
 | ||||||
|  |         match = VERSION_REGEX.match(version) | ||||||
|  |         if not match: | ||||||
|  |             raise ValueError(f"Invalid version: {version!r}") | ||||||
|  | 
 | ||||||
|  |         matches = match.groupdict() | ||||||
|  | 
 | ||||||
|  |         major_str = matches["major"] | ||||||
|  |         minor_str = matches["minor"] | ||||||
|  |         patch_str = matches["patch"] | ||||||
|  |         pre = matches["pre"] | ||||||
|  |         build = matches["build"] | ||||||
|  | 
 | ||||||
|  |         major = int(major_str) | ||||||
|  |         minor = int(minor_str) | ||||||
|  |         patch = int(patch_str) | ||||||
|  | 
 | ||||||
|  |         return Version(major, minor, patch, pre, build) | ||||||
|  | 
 | ||||||
|  |     def to_rpm(self) -> str: | ||||||
|  |         """ | ||||||
|  |         Formats the `Version` object as an equivalent RPM version string. | ||||||
|  |         Characters that are invalid in RPM versions are replaced ("-" -> "_") | ||||||
|  | 
 | ||||||
|  |         Build metadata (the optional `Version.build` attribute) is dropped, so | ||||||
|  |         the conversion is not lossless for versions where this attribute is not | ||||||
|  |         `None`. However, build metadata is not intended to be part of the | ||||||
|  |         version (and is not even considered when doing version comparison), so | ||||||
|  |         dropping it when converting to the RPM version format is correct. | ||||||
|  |         """ | ||||||
|  | 
 | ||||||
|  |         s = f"{self.major}.{self.minor}.{self.patch}" | ||||||
|  |         if self.pre: | ||||||
|  |             s += f"~{self.pre.replace('-', '_')}" | ||||||
|  |         return s | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def break_the_build(error: str): | ||||||
|  |     """ | ||||||
|  |     This function writes a string that is an invalid RPM dependency specifier, | ||||||
|  |     which causes dependency generators to fail and break the build. The | ||||||
|  |     additional error message is printed to stderr. | ||||||
|  |     """ | ||||||
|  | 
 | ||||||
|  |     print("*** FATAL ERROR ***") | ||||||
|  |     print(error, file=sys.stderr) | ||||||
|  | 
 | ||||||
|  |   | ||||||
|  | def get_cargo_vendor_txt_paths_from_stdin() -> set[str]:  # pragma nocover | ||||||
|  |     """ | ||||||
|  |     Read lines from standard input and filter out lines that look like paths | ||||||
|  |     to `cargo-vendor.txt` files. This is how RPM generators pass lists of files. | ||||||
|  |     """ | ||||||
|  | 
 | ||||||
|  |     lines = {line.rstrip("\n") for line in sys.stdin.readlines()} | ||||||
|  |     return {line for line in lines if line.endswith("/cargo-vendor.txt")} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def action_parse_vendor_manifest(): | ||||||
|  |     paths = get_cargo_vendor_txt_paths_from_stdin() | ||||||
|  | 
 | ||||||
|  |     for path in paths: | ||||||
|  |         with open(path) as file: | ||||||
|  |             manifest = file.read() | ||||||
|  | 
 | ||||||
|  |         for line in manifest.strip().splitlines(): | ||||||
|  |             crate, version = line.split(" v") | ||||||
|  |             print(f"bundled(crate({crate})) = {Version.parse(version).to_rpm()}") | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def main(): | ||||||
|  |     try: | ||||||
|  |         action_parse_vendor_manifest() | ||||||
|  |         exit(0) | ||||||
|  | 
 | ||||||
|  |     # print an error message that is not a valid RPM dependency | ||||||
|  |     # to cause the generator to break the build | ||||||
|  |     except (IOError, ValueError) as exc: | ||||||
|  |         break_the_build(str(exc)) | ||||||
|  |         exit(1) | ||||||
|  | 
 | ||||||
|  |     break_the_build("Uncaught exception: This should not happen, please report a bug.") | ||||||
|  |     exit(1) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | if __name__ == "__main__": | ||||||
|  |     main() | ||||||
							
								
								
									
										244
									
								
								SOURCES/macros.rust-toolset
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								SOURCES/macros.rust-toolset
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | |||||||
|  | # __rustc: path to the default rustc executable | ||||||
|  | %__rustc /usr/bin/rustc | ||||||
|  | 
 | ||||||
|  | # __rustdoc: path to the default rustdoc executable | ||||||
|  | %__rustdoc /usr/bin/rustdoc | ||||||
|  | 
 | ||||||
|  | # rustflags_opt_level: default optimization level | ||||||
|  | # | ||||||
|  | # It corresponds to the "-Copt-level" rustc command line option. | ||||||
|  | %rustflags_opt_level 3 | ||||||
|  | 
 | ||||||
|  | # rustflags_debuginfo: default verbosity of debug information | ||||||
|  | # | ||||||
|  | # It corresponds to the "-Cdebuginfo" rustc command line option. | ||||||
|  | # In some cases, it might be required to override this macro with "1" or even | ||||||
|  | # "0", if memory usage gets too high during builds on some resource-constrained | ||||||
|  | # architectures (most likely on 32-bit architectures), which will however | ||||||
|  | # reduce the quality of the produced debug symbols. | ||||||
|  | %rustflags_debuginfo 2 | ||||||
|  | 
 | ||||||
|  | # rustflags_codegen_units: default number of parallel code generation units | ||||||
|  | # | ||||||
|  | # The default value of "1" results in generation of better code, but comes at | ||||||
|  | # the cost of longer build times. | ||||||
|  | %rustflags_codegen_units 1 | ||||||
|  | 
 | ||||||
|  | # build_rustflags: default compiler flags for rustc (RUSTFLAGS) | ||||||
|  | # | ||||||
|  | # -Copt-level: set optimization level (default: highest optimization level) | ||||||
|  | # -Cdebuginfo: set debuginfo verbosity (default: full debug information) | ||||||
|  | # -Ccodegen-units: set number of parallel code generation units (default: 1) | ||||||
|  | # | ||||||
|  | # ref. https://doc.rust-lang.org/rustc/codegen-options/index.html | ||||||
|  | %build_rustflags %{shrink: | ||||||
|  |   -Copt-level=%rustflags_opt_level | ||||||
|  |   -Cdebuginfo=%rustflags_debuginfo | ||||||
|  |   -Ccodegen-units=%rustflags_codegen_units | ||||||
|  |   -Cstrip=none | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # __cargo: cargo command with environment variables | ||||||
|  | # | ||||||
|  | # CARGO_HOME: This ensures cargo reads configuration file from .cargo/config.toml, | ||||||
|  | #       and prevents writing any files to $HOME during RPM builds. | ||||||
|  | %__cargo /usr/bin/env CARGO_HOME=.cargo RUSTFLAGS='%{build_rustflags}' /usr/bin/cargo | ||||||
|  | 
 | ||||||
|  | # __cargo_common_opts: common command line flags for cargo | ||||||
|  | # | ||||||
|  | # _smp_mflags: run builds and tests in parallel | ||||||
|  | %__cargo_common_opts %{?_smp_mflags} | ||||||
|  | 
 | ||||||
|  | # cargo_prep: macro to set up build environment for cargo projects | ||||||
|  | # | ||||||
|  | # This involves four steps: | ||||||
|  | # - create the ".cargo" directory if it doesn't exist yet | ||||||
|  | # - dump custom cargo configuration into ".cargo/config.toml" | ||||||
|  | # - remove "Cargo.lock" if it exists (it breaks builds with custom cargo config) | ||||||
|  | # - remove "Cargo.toml.orig" if it exists (it breaks running "cargo package") | ||||||
|  | # | ||||||
|  | # Options: | ||||||
|  | #   -V <number>    - unpack and use vendored sources from Source<number> tarball | ||||||
|  | #                    (deprecated; use -v instead) | ||||||
|  | #   -v <directory> - use vendored sources from <directory> | ||||||
|  | #   -N             - Don't set up any registry. Only set up the build configuration. | ||||||
|  | %cargo_prep(V:v:N)\ | ||||||
|  | %{-v:%{-V:%{error:-v and -V are mutually exclusive!}}}\ | ||||||
|  | %{-v:%{-N:%{error:-v and -N are mutually exclusive!}}}\ | ||||||
|  | (\ | ||||||
|  | set -euo pipefail\ | ||||||
|  | %{__mkdir} -p target/rpm\ | ||||||
|  | /usr/bin/ln -s rpm target/release\ | ||||||
|  | %{__rm} -rf .cargo/\ | ||||||
|  | %{__mkdir} -p .cargo\ | ||||||
|  | cat > .cargo/config.toml << EOF\ | ||||||
|  | [build]\ | ||||||
|  | rustc = "%{__rustc}"\ | ||||||
|  | rustdoc = "%{__rustdoc}"\ | ||||||
|  | \ | ||||||
|  | [profile.rpm]\ | ||||||
|  | inherits = "release"\ | ||||||
|  | opt-level = %{rustflags_opt_level}\ | ||||||
|  | codegen-units = %{rustflags_codegen_units}\ | ||||||
|  | debug = %{rustflags_debuginfo}\ | ||||||
|  | strip = "none"\ | ||||||
|  | \ | ||||||
|  | [env]\ | ||||||
|  | CFLAGS = "%{build_cflags}"\ | ||||||
|  | CXXFLAGS = "%{build_cxxflags}"\ | ||||||
|  | LDFLAGS = "%{build_ldflags}"\ | ||||||
|  | \ | ||||||
|  | [install]\ | ||||||
|  | root = "%{buildroot}%{_prefix}"\ | ||||||
|  | \ | ||||||
|  | [term]\ | ||||||
|  | verbose = true\ | ||||||
|  | EOF\ | ||||||
|  | %{-V:%{__tar} -xoaf %{S:%{-V*}}}\ | ||||||
|  | %{!?-N:\ | ||||||
|  | cat >> .cargo/config.toml << EOF\ | ||||||
|  | [source.vendored-sources]\ | ||||||
|  | directory = "%{-v*}%{-V:./vendor}"\ | ||||||
|  | \ | ||||||
|  | [source.crates-io]\ | ||||||
|  | registry = "https://crates.io"\ | ||||||
|  | replace-with = "vendored-sources"\ | ||||||
|  | EOF}\ | ||||||
|  | %{__rm} -f Cargo.toml.orig\ | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | # __cargo_parse_opts: function-like macro which parses common flags into the | ||||||
|  | #       equivalent command-line flags for cargo | ||||||
|  | %__cargo_parse_opts(naf:) %{shrink:\ | ||||||
|  |     %{-n:%{-a:%{error:Can't specify both -n and -a}}}           \ | ||||||
|  |     %{-f:%{-a:%{error:Can't specify both -f(%{-f*}) and -a}}}   \ | ||||||
|  |     %{-n:--no-default-features}                                 \ | ||||||
|  |     %{-a:--all-features}                                        \ | ||||||
|  |     %{-f:--features %{-f*}}                                     \ | ||||||
|  |     %{nil}                                                      \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # NB: cargo_build/test/install do not use the -n/-a/-f argument parsing like | ||||||
|  | # Fedora's rust-packaging, because that change would break anyone that's | ||||||
|  | # already passing arguments directly to cargo after the macro. Instead, one can | ||||||
|  | # explicitly use --no-default-features, --all-features, or --features XYZ. | ||||||
|  | 
 | ||||||
|  | # cargo_build: builds the crate with cargo | ||||||
|  | %cargo_build\ | ||||||
|  | %{shrink:                                               \ | ||||||
|  |     %{__cargo} build                                    \ | ||||||
|  |     %{__cargo_common_opts}                              \ | ||||||
|  |     --profile rpm                                       \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # cargo_test: runs the test suite with cargo | ||||||
|  | # | ||||||
|  | # To pass command-line arguments to the cargo test runners directly (for | ||||||
|  | # example, to skip certain tests during package builds), the | ||||||
|  | # "cargo test" argument parsing need to be bypassed, | ||||||
|  | # i.e. "%%cargo_test -- --skip foo" for skipping all tests with names that | ||||||
|  | # match "foo". | ||||||
|  | %cargo_test\ | ||||||
|  | %{shrink:                                               \ | ||||||
|  |     %{__cargo} test                                     \ | ||||||
|  |     %{__cargo_common_opts}                              \ | ||||||
|  |     --profile rpm                                       \ | ||||||
|  |     --no-fail-fast                                      \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # cargo_install: install files into the buildroot | ||||||
|  | # | ||||||
|  | # For "binary" crates, this macro installs all "bin" build targets to _bindir | ||||||
|  | # inside the buildroot. The "--no-track" option prevents the creation of the | ||||||
|  | # "$CARGO_HOME/.crates.toml" file, which is used to keep track of which version | ||||||
|  | # of a specific binary has been installed, but which conflicts between builds | ||||||
|  | # of different Rust applications and is not needed when building RPM packages. | ||||||
|  | %cargo_install\ | ||||||
|  | %{shrink:                                                         \ | ||||||
|  |   %{__cargo} install                                              \ | ||||||
|  |     %{__cargo_common_opts}                                        \ | ||||||
|  |     --profile rpm                                                 \ | ||||||
|  |     --no-track                                                    \ | ||||||
|  |     --path .                                                      \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # cargo_license: print license information for all crate dependencies | ||||||
|  | # | ||||||
|  | # The "no-build,no-dev,no-proc-macro" argument results in only crates which are | ||||||
|  | # linked into the final binary to be considered. | ||||||
|  | # | ||||||
|  | # Additionally, deprecated SPDX syntax ("/" instead of "OR") is normalized | ||||||
|  | # before sorting the results to ensure reproducible output of this macro. | ||||||
|  | # | ||||||
|  | # This macro must be called with the same feature flags as other cargo macros, | ||||||
|  | # in particular, "cargo_build", otherwise its output will be incomplete. | ||||||
|  | # | ||||||
|  | # The "cargo tree" command called by this macro will fail if there are missing | ||||||
|  | # (optional) dependencies. | ||||||
|  | %cargo_license(naf:)\ | ||||||
|  | (\ | ||||||
|  | set -euo pipefail\ | ||||||
|  | %{shrink:                                                           \ | ||||||
|  |     %{__cargo} tree                                                 \ | ||||||
|  |     --workspace                                                     \ | ||||||
|  |     --offline                                                       \ | ||||||
|  |     --edges no-build,no-dev,no-proc-macro                           \ | ||||||
|  |     --no-dedupe                                                     \ | ||||||
|  |     %{__cargo_parse_opts %{-n} %{-a} %{-f:-f%{-f*}}}                \ | ||||||
|  |     --prefix none                                                   \ | ||||||
|  |     --format "{l}: {p}"                                             \ | ||||||
|  |     | sed -e "s: ($(pwd)[^)]*)::g" -e "s: / :/:g" -e "s:/: OR :g"   \ | ||||||
|  |     | sort -u                                                       \ | ||||||
|  | }\ | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | # cargo_license_summary: print license summary for all crate dependencies | ||||||
|  | # | ||||||
|  | # This macro works in the same way as cargo_license, except that it only prints | ||||||
|  | # a list of licenses, and not the complete license information for every crate | ||||||
|  | # in the dependency tree. This is useful for determining the correct License | ||||||
|  | # tag for packages that contain compiled Rust binaries. | ||||||
|  | %cargo_license_summary(naf:)\ | ||||||
|  | (\ | ||||||
|  | set -euo pipefail\ | ||||||
|  | %{shrink:                                                           \ | ||||||
|  |     %{__cargo} tree                                                 \ | ||||||
|  |     --workspace                                                     \ | ||||||
|  |     --offline                                                       \ | ||||||
|  |     --edges no-build,no-dev,no-proc-macro                           \ | ||||||
|  |     --no-dedupe                                                     \ | ||||||
|  |     %{__cargo_parse_opts %{-n} %{-a} %{-f:-f%{-f*}}}                \ | ||||||
|  |     --prefix none                                                   \ | ||||||
|  |     --format "# {l}"                                                \ | ||||||
|  |     | sed -e "s: / :/:g" -e "s:/: OR :g"                            \ | ||||||
|  |     | sort -u                                                       \ | ||||||
|  | }\ | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | # cargo_vendor_manifest: write list of vendored crates and their versions | ||||||
|  | # | ||||||
|  | # The arguments for the internal "cargo tree" call emulate the logic | ||||||
|  | # that determines which crates are included when running "cargo vendor". | ||||||
|  | # The results are written to "cargo-vendor.txt". | ||||||
|  | # | ||||||
|  | # TODO: --all-features may be overly broad; this should be modified to | ||||||
|  | # use %%__cargo_parse_opts to handle feature flags. | ||||||
|  | %cargo_vendor_manifest()\ | ||||||
|  | (\ | ||||||
|  | set -euo pipefail\ | ||||||
|  | %{shrink:                                                           \ | ||||||
|  |     %{__cargo} tree                                                 \ | ||||||
|  |     --workspace                                                     \ | ||||||
|  |     --offline                                                       \ | ||||||
|  |     --edges normal,build                                            \ | ||||||
|  |     --no-dedupe                                                     \ | ||||||
|  |     --all-features                                                  \ | ||||||
|  |     --prefix none                                                   \ | ||||||
|  |     --format "{p}"                                                  \ | ||||||
|  |     | grep -v "$(pwd)"                                              \ | ||||||
|  |     | sed -e "s: (proc-macro)::"                                    \ | ||||||
|  |     | sort -u                                                       \ | ||||||
|  |     > cargo-vendor.txt                                              \ | ||||||
|  | }\ | ||||||
|  | ) | ||||||
|  | 
 | ||||||
| @ -1,32 +0,0 @@ | |||||||
| commit ab998a2eeb2bcdc69ce70c814af97f0d1302a404 (from d17f62d857c70508efbf60be41135880bcd2e062) |  | ||||||
| Merge: d17f62d857c7 9452a8dfa3ba |  | ||||||
| Author: Mazdak Farrokhzad <twingoow@gmail.com> |  | ||||||
| Date:   Thu Jan 24 00:20:00 2019 +0100 |  | ||||||
| 
 |  | ||||||
|     Rollup merge of #57840 - tromey:fix-issue-57762, r=nikic |  | ||||||
|      |  | ||||||
|     Fix issue 57762 |  | ||||||
|      |  | ||||||
|     against a stock LLVM 7.  LLVM 7 was released without a necessary fix |  | ||||||
|     for a bug in the DWARF discriminant code. |  | ||||||
|      |  | ||||||
|     This patch changes rustc to use the fallback mode on (non-Rust) LLVM 7. |  | ||||||
|      |  | ||||||
|     Closes #57762 |  | ||||||
| 
 |  | ||||||
| diff --git a/src/librustc_codegen_llvm/debuginfo/metadata.rs b/src/librustc_codegen_llvm/debuginfo/metadata.rs
 |  | ||||||
| index 6deedd0b5ea3..9f63038c3623 100644
 |  | ||||||
| --- a/src/librustc_codegen_llvm/debuginfo/metadata.rs
 |  | ||||||
| +++ b/src/librustc_codegen_llvm/debuginfo/metadata.rs
 |  | ||||||
| @@ -1164,7 +1164,10 @@ fn use_enum_fallback(cx: &CodegenCx) -> bool {
 |  | ||||||
|      // On MSVC we have to use the fallback mode, because LLVM doesn't |  | ||||||
|      // lower variant parts to PDB. |  | ||||||
|      return cx.sess().target.target.options.is_like_msvc |  | ||||||
| -        || llvm_util::get_major_version() < 7;
 |  | ||||||
| +        // LLVM version 7 did not release with an important bug fix;
 |  | ||||||
| +        // but the required patch is in the LLVM 8.  Rust LLVM reports
 |  | ||||||
| +        // 8 as well.
 |  | ||||||
| +        || llvm_util::get_major_version() < 8;
 |  | ||||||
|  } |  | ||||||
|   |  | ||||||
|  // Describes the members of an enum value: An enum is described as a union of |  | ||||||
| @ -1,39 +0,0 @@ | |||||||
| diff --git a/src/bootstrap/builder.rs b/src/bootstrap/builder.rs
 |  | ||||||
| index 2748903f2d47..10d02d6db829 100644
 |  | ||||||
| --- a/src/bootstrap/builder.rs
 |  | ||||||
| +++ b/src/bootstrap/builder.rs
 |  | ||||||
| @@ -1231,7 +1231,8 @@ impl<'a> Builder<'a> {
 |  | ||||||
|              cargo.arg("--frozen"); |  | ||||||
|          } |  | ||||||
|   |  | ||||||
| -        cargo.env("RUSTC_INSTALL_BINDIR", &self.config.bindir);
 |  | ||||||
| +        // Try to use a sysroot-relative bindir, in case it was configured absolutely.
 |  | ||||||
| +        cargo.env("RUSTC_INSTALL_BINDIR", self.config.bindir_relative());
 |  | ||||||
|   |  | ||||||
|          self.ci_env.force_coloring_in_ci(&mut cargo); |  | ||||||
|   |  | ||||||
| diff --git a/src/bootstrap/config.rs b/src/bootstrap/config.rs
 |  | ||||||
| index d1bdfa0a7676..0c03b95c7b25 100644
 |  | ||||||
| --- a/src/bootstrap/config.rs
 |  | ||||||
| +++ b/src/bootstrap/config.rs
 |  | ||||||
| @@ -647,6 +647,20 @@ impl Config {
 |  | ||||||
|          config |  | ||||||
|      } |  | ||||||
|   |  | ||||||
| +    /// Try to find the relative path of `bindir`, otherwise return it in full.
 |  | ||||||
| +    pub fn bindir_relative(&self) -> &Path {
 |  | ||||||
| +        let bindir = &self.bindir;
 |  | ||||||
| +        if bindir.is_absolute() {
 |  | ||||||
| +            // Try to make it relative to the prefix.
 |  | ||||||
| +            if let Some(prefix) = &self.prefix {
 |  | ||||||
| +                if let Ok(stripped) = bindir.strip_prefix(prefix) {
 |  | ||||||
| +                    return stripped;
 |  | ||||||
| +                }
 |  | ||||||
| +            }
 |  | ||||||
| +        }
 |  | ||||||
| +        bindir
 |  | ||||||
| +    }
 |  | ||||||
| +
 |  | ||||||
|      /// Try to find the relative path of `libdir`. |  | ||||||
|      pub fn libdir_relative(&self) -> Option<&Path> { |  | ||||||
|          let libdir = self.libdir.as_ref()?; |  | ||||||
| @ -1,97 +0,0 @@ | |||||||
| From ed8e55fe8d732d8a87343441db3bfbb974f043df Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Josh Stone <jistone@redhat.com> |  | ||||||
| Date: Wed, 8 Jan 2020 09:44:45 -0800 |  | ||||||
| Subject: [PATCH 1/2] Remove obsolete llvm_tools flag |  | ||||||
| 
 |  | ||||||
| ---
 |  | ||||||
|  src/bootstrap/tool.rs | 12 +----------- |  | ||||||
|  1 file changed, 1 insertion(+), 11 deletions(-) |  | ||||||
| 
 |  | ||||||
| diff --git a/src/bootstrap/tool.rs b/src/bootstrap/tool.rs
 |  | ||||||
| index 815498047fd5..f785a0989a36 100644
 |  | ||||||
| --- a/src/bootstrap/tool.rs
 |  | ||||||
| +++ b/src/bootstrap/tool.rs
 |  | ||||||
| @@ -293,7 +293,6 @@ fn rustbook_features() -> Vec<String> {
 |  | ||||||
|  macro_rules! bootstrap_tool { |  | ||||||
|      ($( |  | ||||||
|          $name:ident, $path:expr, $tool_name:expr |  | ||||||
| -        $(,llvm_tools = $llvm:expr)*
 |  | ||||||
|          $(,is_external_tool = $external:expr)* |  | ||||||
|          $(,features = $features:expr)* |  | ||||||
|          ; |  | ||||||
| @@ -305,15 +304,6 @@ macro_rules! bootstrap_tool {
 |  | ||||||
|              )+ |  | ||||||
|          } |  | ||||||
|   |  | ||||||
| -        impl Tool {
 |  | ||||||
| -            /// Whether this tool requires LLVM to run
 |  | ||||||
| -            pub fn uses_llvm_tools(&self) -> bool {
 |  | ||||||
| -                match self {
 |  | ||||||
| -                    $(Tool::$name => false $(|| $llvm)*,)+
 |  | ||||||
| -                }
 |  | ||||||
| -            }
 |  | ||||||
| -        }
 |  | ||||||
| -
 |  | ||||||
|          impl<'a> Builder<'a> { |  | ||||||
|              pub fn tool_exe(&self, tool: Tool) -> PathBuf { |  | ||||||
|                  match tool { |  | ||||||
| @@ -381,7 +371,7 @@ bootstrap_tool!(
 |  | ||||||
|      Tidy, "src/tools/tidy", "tidy"; |  | ||||||
|      Linkchecker, "src/tools/linkchecker", "linkchecker"; |  | ||||||
|      CargoTest, "src/tools/cargotest", "cargotest"; |  | ||||||
| -    Compiletest, "src/tools/compiletest", "compiletest", llvm_tools = true;
 |  | ||||||
| +    Compiletest, "src/tools/compiletest", "compiletest";
 |  | ||||||
|      BuildManifest, "src/tools/build-manifest", "build-manifest"; |  | ||||||
|      RemoteTestClient, "src/tools/remote-test-client", "remote-test-client"; |  | ||||||
|      RustInstaller, "src/tools/rust-installer", "fabricate", is_external_tool = true; |  | ||||||
| -- 
 |  | ||||||
| 2.24.1 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| From cc4688d66d75e149a0136f701045cbf7ee672725 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Josh Stone <jistone@redhat.com> |  | ||||||
| Date: Wed, 8 Jan 2020 10:04:18 -0800 |  | ||||||
| Subject: [PATCH 2/2] Build compiletest with in-tree libtest |  | ||||||
| 
 |  | ||||||
| ---
 |  | ||||||
|  src/bootstrap/tool.rs | 10 ++++++++-- |  | ||||||
|  1 file changed, 8 insertions(+), 2 deletions(-) |  | ||||||
| 
 |  | ||||||
| diff --git a/src/bootstrap/tool.rs b/src/bootstrap/tool.rs
 |  | ||||||
| index f785a0989a36..73a4dda74e88 100644
 |  | ||||||
| --- a/src/bootstrap/tool.rs
 |  | ||||||
| +++ b/src/bootstrap/tool.rs
 |  | ||||||
| @@ -294,6 +294,7 @@ macro_rules! bootstrap_tool {
 |  | ||||||
|      ($( |  | ||||||
|          $name:ident, $path:expr, $tool_name:expr |  | ||||||
|          $(,is_external_tool = $external:expr)* |  | ||||||
| +        $(,is_unstable_tool = $unstable:expr)*
 |  | ||||||
|          $(,features = $features:expr)* |  | ||||||
|          ; |  | ||||||
|      )+) => { |  | ||||||
| @@ -344,7 +345,12 @@ macro_rules! bootstrap_tool {
 |  | ||||||
|                      compiler: self.compiler, |  | ||||||
|                      target: self.target, |  | ||||||
|                      tool: $tool_name, |  | ||||||
| -                    mode: Mode::ToolBootstrap,
 |  | ||||||
| +                    mode: if false $(|| $unstable)* {
 |  | ||||||
| +                        // use in-tree libraries for unstable features
 |  | ||||||
| +                        Mode::ToolStd
 |  | ||||||
| +                    } else {
 |  | ||||||
| +                        Mode::ToolBootstrap
 |  | ||||||
| +                    },
 |  | ||||||
|                      path: $path, |  | ||||||
|                      is_optional_tool: false, |  | ||||||
|                      source_type: if false $(|| $external)* { |  | ||||||
| @@ -371,7 +377,7 @@ bootstrap_tool!(
 |  | ||||||
|      Tidy, "src/tools/tidy", "tidy"; |  | ||||||
|      Linkchecker, "src/tools/linkchecker", "linkchecker"; |  | ||||||
|      CargoTest, "src/tools/cargotest", "cargotest"; |  | ||||||
| -    Compiletest, "src/tools/compiletest", "compiletest";
 |  | ||||||
| +    Compiletest, "src/tools/compiletest", "compiletest", is_unstable_tool = true;
 |  | ||||||
|      BuildManifest, "src/tools/build-manifest", "build-manifest"; |  | ||||||
|      RemoteTestClient, "src/tools/remote-test-client", "remote-test-client"; |  | ||||||
|      RustInstaller, "src/tools/rust-installer", "fabricate", is_external_tool = true; |  | ||||||
| -- 
 |  | ||||||
| 2.24.1 |  | ||||||
| 
 |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| --- rustc-1.39.0-src/Cargo.lock.orig	2019-11-04 07:45:21.000000000 -0800
 |  | ||||||
| +++ rustc-1.39.0-src/Cargo.lock	2019-11-08 13:25:37.743377197 -0800
 |  | ||||||
| @@ -1697,7 +1697,6 @@
 |  | ||||||
|  dependencies = [ |  | ||||||
|   "cc", |  | ||||||
|   "libc", |  | ||||||
| - "libssh2-sys",
 |  | ||||||
|   "libz-sys", |  | ||||||
|   "openssl-sys", |  | ||||||
|   "pkg-config", |  | ||||||
| @@ -1714,20 +1713,6 @@
 |  | ||||||
|  ] |  | ||||||
|   |  | ||||||
|  [[package]] |  | ||||||
| -name = "libssh2-sys"
 |  | ||||||
| -version = "0.2.11"
 |  | ||||||
| -source = "registry+https://github.com/rust-lang/crates.io-index"
 |  | ||||||
| -checksum = "126a1f4078368b163bfdee65fbab072af08a1b374a5551b21e87ade27b1fbf9d"
 |  | ||||||
| -dependencies = [
 |  | ||||||
| - "cc",
 |  | ||||||
| - "libc",
 |  | ||||||
| - "libz-sys",
 |  | ||||||
| - "openssl-sys",
 |  | ||||||
| - "pkg-config",
 |  | ||||||
| - "vcpkg",
 |  | ||||||
| -]
 |  | ||||||
| -
 |  | ||||||
| -[[package]]
 |  | ||||||
|  name = "libz-sys" |  | ||||||
|  version = "1.0.25" |  | ||||||
|  source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| --- rustc-1.39.0-src/vendor/git2/Cargo.toml.orig	2019-11-04 09:34:41.000000000 -0800
 |  | ||||||
| +++ rustc-1.39.0-src/vendor/git2/Cargo.toml	2019-11-08 13:25:13.174904479 -0800
 |  | ||||||
| @@ -55,7 +55,7 @@
 |  | ||||||
|  version = "0.1.39" |  | ||||||
|   |  | ||||||
|  [features] |  | ||||||
| -default = ["ssh", "https", "ssh_key_from_memory"]
 |  | ||||||
| +default = ["https"]
 |  | ||||||
|  https = ["libgit2-sys/https", "openssl-sys", "openssl-probe"] |  | ||||||
|  ssh = ["libgit2-sys/ssh"] |  | ||||||
|  ssh_key_from_memory = ["libgit2-sys/ssh_key_from_memory"] |  | ||||||
							
								
								
									
										21
									
								
								SOURCES/rustc-1.70.0-rust-gdb-substitute-path.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								SOURCES/rustc-1.70.0-rust-gdb-substitute-path.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | diff --git a/src/etc/rust-gdb b/src/etc/rust-gdb
 | ||||||
|  | index 9abed30ea6f7..e4bf55df3688 100755
 | ||||||
|  | --- a/src/etc/rust-gdb
 | ||||||
|  | +++ b/src/etc/rust-gdb
 | ||||||
|  | @@ -13,8 +13,6 @@ fi
 | ||||||
|  |  # Find out where the pretty printer Python module is | ||||||
|  |  RUSTC_SYSROOT="$("$RUSTC" --print=sysroot)" | ||||||
|  |  GDB_PYTHON_MODULE_DIRECTORY="$RUSTC_SYSROOT/lib/rustlib/etc" | ||||||
|  | -# Get the commit hash for path remapping
 | ||||||
|  | -RUSTC_COMMIT_HASH="$("$RUSTC" -vV | sed -n 's/commit-hash: \([a-zA-Z0-9_]*\)/\1/p')"
 | ||||||
|  |   | ||||||
|  |  # Run GDB with the additional arguments that load the pretty printers | ||||||
|  |  # Set the environment variable `RUST_GDB` to overwrite the call to a | ||||||
|  | @@ -23,6 +21,6 @@ RUST_GDB="${RUST_GDB:-gdb}"
 | ||||||
|  |  PYTHONPATH="$PYTHONPATH:$GDB_PYTHON_MODULE_DIRECTORY" exec ${RUST_GDB} \ | ||||||
|  |    --directory="$GDB_PYTHON_MODULE_DIRECTORY" \ | ||||||
|  |    -iex "add-auto-load-safe-path $GDB_PYTHON_MODULE_DIRECTORY" \ | ||||||
|  | -  -iex "set substitute-path /rustc/$RUSTC_COMMIT_HASH $RUSTC_SYSROOT/lib/rustlib/src/rust" \
 | ||||||
|  | +  -iex "set substitute-path @BUILDDIR@ $RUSTC_SYSROOT/lib/rustlib/src/rust" \
 | ||||||
|  |    "$@" | ||||||
|  |    | ||||||
							
								
								
									
										44
									
								
								SOURCES/rustc-1.84.0-disable-libssh2.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								SOURCES/rustc-1.84.0-disable-libssh2.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | diff -up rustc-beta-src/src/tools/cargo/Cargo.lock.orig rustc-beta-src/src/tools/cargo/Cargo.lock
 | ||||||
|  | --- rustc-beta-src/src/tools/cargo/Cargo.lock.orig	2024-12-12 14:07:10.755481543 -0800
 | ||||||
|  | +++ rustc-beta-src/src/tools/cargo/Cargo.lock	2024-12-12 14:07:10.756481534 -0800
 | ||||||
|  | @@ -2272,7 +2272,6 @@ checksum = "10472326a8a6477c3c20a64547b0
 | ||||||
|  |  dependencies = [ | ||||||
|  |   "cc", | ||||||
|  |   "libc", | ||||||
|  | - "libssh2-sys",
 | ||||||
|  |   "libz-sys", | ||||||
|  |   "openssl-sys", | ||||||
|  |   "pkg-config", | ||||||
|  | @@ -2313,20 +2312,6 @@ dependencies = [
 | ||||||
|  |   "pkg-config", | ||||||
|  |   "vcpkg", | ||||||
|  |  ] | ||||||
|  | -
 | ||||||
|  | -[[package]]
 | ||||||
|  | -name = "libssh2-sys"
 | ||||||
|  | -version = "0.3.0"
 | ||||||
|  | -source = "registry+https://github.com/rust-lang/crates.io-index"
 | ||||||
|  | -checksum = "2dc8a030b787e2119a731f1951d6a773e2280c660f8ec4b0f5e1505a386e71ee"
 | ||||||
|  | -dependencies = [
 | ||||||
|  | - "cc",
 | ||||||
|  | - "libc",
 | ||||||
|  | - "libz-sys",
 | ||||||
|  | - "openssl-sys",
 | ||||||
|  | - "pkg-config",
 | ||||||
|  | - "vcpkg",
 | ||||||
|  | -]
 | ||||||
|  |   | ||||||
|  |  [[package]] | ||||||
|  |  name = "libz-sys" | ||||||
|  | diff -up rustc-beta-src/src/tools/cargo/Cargo.toml.orig rustc-beta-src/src/tools/cargo/Cargo.toml
 | ||||||
|  | --- rustc-beta-src/src/tools/cargo/Cargo.toml.orig	2024-12-12 14:07:10.756481534 -0800
 | ||||||
|  | +++ rustc-beta-src/src/tools/cargo/Cargo.toml	2024-12-12 14:07:56.866087428 -0800
 | ||||||
|  | @@ -47,7 +47,7 @@ curl = "0.4.46"
 | ||||||
|  |  curl-sys = "0.4.73" | ||||||
|  |  filetime = "0.2.23" | ||||||
|  |  flate2 = { version = "1.0.30", default-features = false, features = ["zlib"] } | ||||||
|  | -git2 = "0.19.0"
 | ||||||
|  | +git2 = { version = "0.19.0", default-features = false, features = ["https"] }
 | ||||||
|  |  git2-curl = "0.20.0" | ||||||
|  |  gix = { version = "0.67.0", default-features = false, features = ["blocking-http-transport-curl", "progress-tree", "parallel", "dirwalk"] } | ||||||
|  |  glob = "0.3.1" | ||||||
							
								
								
									
										23
									
								
								SOURCES/rustc-1.84.0-unbundle-sqlite.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								SOURCES/rustc-1.84.0-unbundle-sqlite.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | diff -up rustc-beta-src/src/tools/cargo/Cargo.lock.orig rustc-beta-src/src/tools/cargo/Cargo.lock
 | ||||||
|  | --- rustc-beta-src/src/tools/cargo/Cargo.lock.orig	2024-12-07 06:47:38.000000000 -0800
 | ||||||
|  | +++ rustc-beta-src/src/tools/cargo/Cargo.lock	2024-12-12 14:02:54.412672539 -0800
 | ||||||
|  | @@ -2310,7 +2310,6 @@ version = "0.30.1"
 | ||||||
|  |  source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  checksum = "2e99fb7a497b1e3339bc746195567ed8d3e24945ecd636e3619d20b9de9e9149" | ||||||
|  |  dependencies = [ | ||||||
|  | - "cc",
 | ||||||
|  |   "pkg-config", | ||||||
|  |   "vcpkg", | ||||||
|  |  ] | ||||||
|  | diff -up rustc-beta-src/src/tools/cargo/Cargo.toml.orig rustc-beta-src/src/tools/cargo/Cargo.toml
 | ||||||
|  | --- rustc-beta-src/src/tools/cargo/Cargo.toml.orig	2024-12-12 14:02:54.412672539 -0800
 | ||||||
|  | +++ rustc-beta-src/src/tools/cargo/Cargo.toml	2024-12-12 14:03:25.665405417 -0800
 | ||||||
|  | @@ -80,7 +80,7 @@ proptest = "1.5.0"
 | ||||||
|  |  pulldown-cmark = { version = "0.12.0", default-features = false, features = ["html"] } | ||||||
|  |  rand = "0.8.5" | ||||||
|  |  regex = "1.10.5" | ||||||
|  | -rusqlite = { version = "0.32.0", features = ["bundled"] }
 | ||||||
|  | +rusqlite = { version = "0.32.0", features = [] }
 | ||||||
|  |  rustc-hash = "2.0.0" | ||||||
|  |  rustfix = { version = "0.9.0", path = "crates/rustfix" } | ||||||
|  |  same-file = "1.0.6" | ||||||
							
								
								
									
										1233
									
								
								SPECS/rust.spec
									
									
									
									
									
								
							
							
						
						
									
										1233
									
								
								SPECS/rust.spec
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user