Apply suggestions from code review

Co-authored-by: Nikita Popov <github@npopov.com>
This commit is contained in:
Lzu Tao 2024-06-09 13:25:12 +00:00
parent 95740fbfed
commit f9edd864df
11 changed files with 37 additions and 55 deletions

View file

@ -4,27 +4,25 @@
#![crate_type = "lib"] #![crate_type = "lib"]
#[no_mangle]
type T = u8; type T = u8;
type T1 = (T, T, T, T, T, T, T, T); type T1 = (T, T, T, T, T, T, T, T);
type T2 = [T; 8]; type T2 = [T; 8];
#[no_mangle]
// CHECK-LABEL: foo1a // CHECK-LABEL: foo1a
// CHECK: cmp // CHECK: cmp
// CHECK-NEXT: set // CHECK-NEXT: sete
// CHECK-NEXT: ret // CHECK-NEXT: ret
#[no_mangle]
pub fn foo1a(a: T1, b: T1) -> bool { pub fn foo1a(a: T1, b: T1) -> bool {
a == b a == b
} }
#[no_mangle]
// CHECK-LABEL: foo1b // CHECK-LABEL: foo1b
// CHECK: mov // CHECK: mov
// CHECK-NEXT: cmp // CHECK-NEXT: cmp
// CHECK-NEXT: set // CHECK-NEXT: sete
// CHECK-NEXT: ret // CHECK-NEXT: ret
#[no_mangle]
pub fn foo1b(a: &T1, b: &T1) -> bool { pub fn foo1b(a: &T1, b: &T1) -> bool {
a == b a == b
} }

View file

@ -1,11 +1,10 @@
//@ compile-flags: -O //@ compile-flags: -O
//@ min-llvm-version: 17
#![crate_type = "lib"] #![crate_type = "lib"]
#[no_mangle]
// CHECK-LABEL: @foo // CHECK-LABEL: @foo
// CHECK: getelementptr inbounds // CHECK-NEXT: {{.*}}:
// CHECK-NEXT: getelementptr inbounds
// CHECK-NEXT: load i64 // CHECK-NEXT: load i64
// CHECK-NEXT: icmp eq i64 // CHECK-NEXT: icmp eq i64
// CHECK-NEXT: br i1 // CHECK-NEXT: br i1

View file

@ -1,27 +1,26 @@
//@ compile-flags: -O //@ compile-flags: -O
// XXX: The x86-64 assembly get optimized correclty. But llvm-ir output is not until llvm 18?
//@ min-llvm-version: 18 //@ min-llvm-version: 18
#![crate_type = "lib"] #![crate_type = "lib"]
pub enum K{ pub enum K {
A(Box<[i32]>), A(Box<[i32]>),
B(Box<[u8]>), B(Box<[u8]>),
C(Box<[String]>), C(Box<[String]>),
D(Box<[u16]>), D(Box<[u16]>),
} }
#[no_mangle]
// CHECK-LABEL: @get_len // CHECK-LABEL: @get_len
// CHECK: getelementptr inbounds // CHECK-NEXT: {{.*}}:
// CHECK-NEXT: getelementptr inbounds
// CHECK-NEXT: load // CHECK-NEXT: load
// CHECK-NEXT: ret i64 // CHECK-NEXT: ret i64
// CHECK-NOT: switch #[no_mangle]
pub fn get_len(arg: &K)->usize{ pub fn get_len(arg: &K) -> usize {
match arg { match arg {
K::A(ref lst)=>lst.len(), K::A(ref lst) => lst.len(),
K::B(ref lst)=>lst.len(), K::B(ref lst) => lst.len(),
K::C(ref lst)=>lst.len(), K::C(ref lst) => lst.len(),
K::D(ref lst)=>lst.len(), K::D(ref lst) => lst.len(),
} }
} }

View file

@ -8,9 +8,9 @@ use std::convert::TryInto;
const N: usize = 24; const N: usize = 24;
#[no_mangle]
// CHECK-LABEL: @example // CHECK-LABEL: @example
// CHECK-NOT: unwrap_failed // CHECK-NOT: unwrap_failed
#[no_mangle]
pub fn example(a: Vec<u8>) -> u8 { pub fn example(a: Vec<u8>) -> u8 {
if a.len() != 32 { if a.len() != 32 {
return 0; return 0;

View file

@ -1,17 +1,12 @@
//@ compile-flags: -O //@ compile-flags: -O
//@ min-llvm-version: 17
#![crate_type = "lib"] #![crate_type = "lib"]
// CHECK-LABEL: @write_u8_variant_a // CHECK-LABEL: @write_u8_variant_a
// CHECK: getelementptr // CHECK-NEXT: {{.*}}:
// CHECK-NEXT: getelementptr
// CHECK-NEXT: icmp ugt // CHECK-NEXT: icmp ugt
#[no_mangle] #[no_mangle]
pub fn write_u8_variant_a( pub fn write_u8_variant_a(bytes: &mut [u8], buf: u8, offset: usize) -> Option<&mut [u8]> {
bytes: &mut [u8],
buf: u8,
offset: usize,
) -> Option<&mut [u8]> {
let buf = buf.to_le_bytes(); let buf = buf.to_le_bytes();
bytes bytes.get_mut(offset..).and_then(|bytes| bytes.get_mut(..buf.len()))
.get_mut(offset..).and_then(|bytes| bytes.get_mut(..buf.len()))
} }

View file

@ -1,15 +1,14 @@
// in Rust 1.73, -O and opt-level=3 optimizes differently // in Rust 1.73, -O and opt-level=3 optimizes differently
//@ compile-flags: -C opt-level=3 //@ compile-flags: -C opt-level=3
//@ min-llvm-version: 17
#![crate_type = "lib"] #![crate_type = "lib"]
use std::cmp::max; use std::cmp::max;
#[no_mangle]
// CHECK-LABEL: @foo // CHECK-LABEL: @foo
// CHECK-NOT: slice_start_index_len_fail // CHECK-NOT: slice_start_index_len_fail
// CHECK-NOT: unreachable // CHECK-NOT: unreachable
pub fn foo(v: &mut Vec<u8>, size: usize)-> Option<&mut [u8]> { #[no_mangle]
pub fn foo(v: &mut Vec<u8>, size: usize) -> Option<&mut [u8]> {
if v.len() > max(1, size) { if v.len() > max(1, size) {
let start = v.len() - size; let start = v.len() - size;
Some(&mut v[start..]) Some(&mut v[start..])

View file

@ -8,12 +8,12 @@ fn foo<T>(a: &mut T, b: T) -> bool {
let b = Some(mem::replace(a, b)); let b = Some(mem::replace(a, b));
let ret = b.is_some(); let ret = b.is_some();
mem::forget(b); mem::forget(b);
return ret return ret;
} }
// CHECK-LABEL: @foo_u32 // CHECK-LABEL: @foo_u32
// CHECK: store i32 // CHECK: store i32
// CHECK-NEXT: ret i1 // CHECK-NEXT: ret i1 true
#[no_mangle] #[no_mangle]
pub fn foo_u32(a: &mut u32, b: u32) -> bool { pub fn foo_u32(a: &mut u32, b: u32) -> bool {
foo(a, b) foo(a, b)
@ -21,9 +21,8 @@ pub fn foo_u32(a: &mut u32, b: u32) -> bool {
// CHECK-LABEL: @foo_box // CHECK-LABEL: @foo_box
// CHECK: store ptr // CHECK: store ptr
// CHECK-NEXT: ret i1 // CHECK-NEXT: ret i1 true
#[no_mangle] #[no_mangle]
pub fn foo_box(a: &mut Box<u32>, b: Box<u32>) -> bool { pub fn foo_box(a: &mut Box<u32>, b: Box<u32>) -> bool {
foo(a, b) foo(a, b)
} }

View file

@ -11,7 +11,5 @@
// CHECK-NEXT: ret i1 // CHECK-NEXT: ret i1
#[no_mangle] #[no_mangle]
pub fn unwrap_combinators(a: Option<i32>, b: i32) -> bool { pub fn unwrap_combinators(a: Option<i32>, b: i32) -> bool {
a.map(|t| t >= b) a.map(|t| t >= b).unwrap_or(false)
.unwrap_or(false)
} }

View file

@ -5,11 +5,10 @@
const N: usize = 3; const N: usize = 3;
pub type T = u8; pub type T = u8;
#[no_mangle] // CHECK-LABEL: @split_multiple
// CHECK-LABEL: @split_mutiple
// CHECK-NOT: unreachable // CHECK-NOT: unreachable
pub fn split_mutiple(slice: &[T]) -> (&[T], &[T]) { #[no_mangle]
pub fn split_multiple(slice: &[T]) -> (&[T], &[T]) {
let len = slice.len() / N; let len = slice.len() / N;
slice.split_at(len * N) slice.split_at(len * N)
} }

View file

@ -1,12 +1,9 @@
//@ compile-flags: -O //@ compile-flags: -O
//@ min-llvm-version: 17
#![crate_type = "lib"] #![crate_type = "lib"]
#[no_mangle] #[no_mangle]
// CHECK-LABEL: @foo // CHECK-LABEL: @foo
// CHECK: {{.*}}:
// CHECK: ret
// CHECK-NOT: unreachable // CHECK-NOT: unreachable
pub fn foo(arr: &mut [u32]) { pub fn foo(arr: &mut [u32]) {
for i in 0..arr.len() { for i in 0..arr.len() {
@ -15,4 +12,3 @@ pub fn foo(arr: &mut [u32]) {
} }
} }
} }

View file

@ -5,15 +5,15 @@
use std::ptr::NonNull; use std::ptr::NonNull;
// CHECK-LABEL: @slice_ptr_len_1 // CHECK-LABEL: @slice_ptr_len_1
// CHECK: {{.*}}: // CHECK-NEXT: {{.*}}:
// CHECK-NEXT: ret i64 %ptr.1 // CHECK-NEXT: ret i64 %ptr.1
#[no_mangle] #[no_mangle]
pub fn slice_ptr_len_1(ptr: *const [u8]) -> usize { pub fn slice_ptr_len_1(ptr: *const [u8]) -> usize {
let ptr = ptr.cast_mut(); let ptr = ptr.cast_mut();
if let Some(ptr) = NonNull::new(ptr) { if let Some(ptr) = NonNull::new(ptr) {
ptr.len() ptr.len()
} else { } else {
// We know ptr is null, so we know ptr.wrapping_byte_add(1) is not null. // We know ptr is null, so we know ptr.wrapping_byte_add(1) is not null.
NonNull::new(ptr.wrapping_byte_add(1)).unwrap().len() NonNull::new(ptr.wrapping_byte_add(1)).unwrap().len()
} }
} }