Apply suggestions from code review
Co-authored-by: Nikita Popov <github@npopov.com>
This commit is contained in:
parent
95740fbfed
commit
f9edd864df
11 changed files with 37 additions and 55 deletions
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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()))
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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..])
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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]) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue