diff options
| author | Jakub Beránek <berykubik@gmail.com> | 2025-07-23 14:59:10 +0200 |
|---|---|---|
| committer | Jakub Beránek <berykubik@gmail.com> | 2025-07-23 14:59:10 +0200 |
| commit | 67f73c75477338560fb78003149c11a9fa7d4820 (patch) | |
| tree | 7792f3f9786658de9949e9c27ac4dfb8c63fdb8d /tests/codegen/array-codegen.rs | |
| parent | a343926954a525f491756c3c9714417ae9ccc121 (diff) | |
| parent | 0b88bea0d5169af3b3f9326274bda8b9c4a31823 (diff) | |
| download | rust-67f73c75477338560fb78003149c11a9fa7d4820.tar.gz rust-67f73c75477338560fb78003149c11a9fa7d4820.zip | |
Merge ref '5a30e4307f05' from rust-lang/rust
Pull recent changes from https://github.com/rust-lang/rust via Josh. Upstream ref: 5a30e4307f0506bed87eeecd171f8366fdbda1dc Filtered ref: 59749e9f8c765d3021796a9fe0c188643c4b8d77 This merge was created using https://github.com/rust-lang/josh-sync.
Diffstat (limited to 'tests/codegen/array-codegen.rs')
| -rw-r--r-- | tests/codegen/array-codegen.rs | 62 |
1 files changed, 0 insertions, 62 deletions
diff --git a/tests/codegen/array-codegen.rs b/tests/codegen/array-codegen.rs deleted file mode 100644 index 9b0c6e8c347..00000000000 --- a/tests/codegen/array-codegen.rs +++ /dev/null @@ -1,62 +0,0 @@ -//@ compile-flags: -Copt-level=3 -C no-prepopulate-passes - -#![crate_type = "lib"] - -// CHECK-LABEL: @array_load -#[no_mangle] -pub fn array_load(a: &[u8; 4]) -> [u8; 4] { - // CHECK-NOT: alloca - // CHECK: %[[ALLOCA:.+]] = alloca [4 x i8], align 1 - // CHECK-NOT: alloca - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %[[ALLOCA]], ptr align 1 %a, {{.+}} 4, i1 false) - // CHECK: %[[TEMP:.+]] = load i32, ptr %[[ALLOCA]], align 1 - // CHECK: ret i32 %[[TEMP]] - *a -} - -// CHECK-LABEL: @array_store -#[no_mangle] -pub fn array_store(a: [u8; 4], p: &mut [u8; 4]) { - // CHECK-NOT: alloca - // CHECK: %[[TEMP:.+]] = alloca [4 x i8], [[TEMPALIGN:align [0-9]+]] - // CHECK-NOT: alloca - // CHECK: %a = alloca [4 x i8] - // CHECK-NOT: alloca - // store i32 %0, ptr %[[TEMP]] - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %a, ptr [[TEMPALIGN]] %[[TEMP]], {{.+}} 4, i1 false) - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %p, ptr align 1 %a, {{.+}} 4, i1 false) - *p = a; -} - -// CHECK-LABEL: @array_copy -#[no_mangle] -pub fn array_copy(a: &[u8; 4], p: &mut [u8; 4]) { - // CHECK-NOT: alloca - // CHECK: %[[LOCAL:.+]] = alloca [4 x i8], align 1 - // CHECK-NOT: alloca - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %[[LOCAL]], ptr align 1 %a, {{.+}} 4, i1 false) - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %p, ptr align 1 %[[LOCAL]], {{.+}} 4, i1 false) - *p = *a; -} - -// CHECK-LABEL: @array_copy_1_element -#[no_mangle] -pub fn array_copy_1_element(a: &[u8; 1], p: &mut [u8; 1]) { - // CHECK-NOT: alloca - // CHECK: %[[LOCAL:.+]] = alloca [1 x i8], align 1 - // CHECK-NOT: alloca - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %[[LOCAL]], ptr align 1 %a, {{.+}} 1, i1 false) - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %p, ptr align 1 %[[LOCAL]], {{.+}} 1, i1 false) - *p = *a; -} - -// CHECK-LABEL: @array_copy_2_elements -#[no_mangle] -pub fn array_copy_2_elements(a: &[u8; 2], p: &mut [u8; 2]) { - // CHECK-NOT: alloca - // CHECK: %[[LOCAL:.+]] = alloca [2 x i8], align 1 - // CHECK-NOT: alloca - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %[[LOCAL]], ptr align 1 %a, {{.+}} 2, i1 false) - // CHECK: call void @llvm.memcpy.{{.+}}(ptr align 1 %p, ptr align 1 %[[LOCAL]], {{.+}} 2, i1 false) - *p = *a; -} |
