mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-31 04:57:19 +00:00 
			
		
		
		
	 b41c232488
			
		
	
	
		b41c232488
		
	
	
	
	
		
			
			Same motivation as #136287, but for a newly introduced test. Rather than over-constraining here, we just match the sret and accept pretty much all other attributes. @rustbot label llvm-main r? @nikic
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| //@ compile-flags: -Copt-level=3
 | |
| 
 | |
| // See https://github.com/rust-lang/rust/issues/135802
 | |
| 
 | |
| #![crate_type = "lib"]
 | |
| 
 | |
| enum Void {}
 | |
| 
 | |
| // Should be ABI-compatible with T, but wasn't prior to the PR adding this test.
 | |
| #[repr(transparent)]
 | |
| struct NoReturn<T>(T, Void);
 | |
| 
 | |
| // Returned by invisible reference (in most ABIs)
 | |
| #[allow(dead_code)]
 | |
| struct Large(u64, u64, u64);
 | |
| 
 | |
| extern "Rust" {
 | |
|     fn opaque() -> NoReturn<Large>;
 | |
|     fn opaque_with_arg(rsi: u32) -> NoReturn<Large>;
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @test_uninhabited_ret_by_ref
 | |
| #[no_mangle]
 | |
| pub fn test_uninhabited_ret_by_ref() {
 | |
|     // CHECK: %_1 = alloca [24 x i8], align {{8|4}}
 | |
|     // CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 24, ptr nonnull %_1)
 | |
|     // CHECK-NEXT: call void @opaque({{.*}} sret([24 x i8]) {{.*}} %_1) #2
 | |
|     // CHECK-NEXT: unreachable
 | |
|     unsafe {
 | |
|         opaque();
 | |
|     }
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @test_uninhabited_ret_by_ref_with_arg
 | |
| #[no_mangle]
 | |
| pub fn test_uninhabited_ret_by_ref_with_arg(rsi: u32) {
 | |
|     // CHECK: %_2 = alloca [24 x i8], align {{8|4}}
 | |
|     // CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 24, ptr nonnull %_2)
 | |
|     // CHECK-NEXT: call void @opaque_with_arg({{.*}} sret([24 x i8]) {{.*}} %_2, i32 noundef %rsi) #2
 | |
|     // CHECK-NEXT: unreachable
 | |
|     unsafe {
 | |
|         opaque_with_arg(rsi);
 | |
|     }
 | |
| }
 |