2020-11-06 15:51:44 -06:00
|
|
|
// no-system-llvm
|
|
|
|
// compile-flags: -O
|
|
|
|
// only-64bit (because the LLVM type of i64 for usize shows up)
|
2021-01-16 16:52:48 -06:00
|
|
|
// ignore-debug: the debug assertions get in the way
|
2020-11-06 15:51:44 -06:00
|
|
|
|
|
|
|
#![crate_type = "lib"]
|
|
|
|
#![feature(slice_as_chunks)]
|
|
|
|
|
|
|
|
// CHECK-LABEL: @chunks4
|
|
|
|
#[no_mangle]
|
|
|
|
pub fn chunks4(x: &[u8]) -> &[[u8; 4]] {
|
|
|
|
// CHECK-NEXT: start:
|
|
|
|
// CHECK-NEXT: lshr i64 %x.1, 2
|
|
|
|
// CHECK-NOT: shl
|
|
|
|
// CHECK-NOT: mul
|
|
|
|
// CHECK-NOT: udiv
|
|
|
|
// CHECK-NOT: urem
|
|
|
|
// CHECK: ret
|
|
|
|
x.as_chunks().0
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: @chunks4_with_remainder
|
|
|
|
#[no_mangle]
|
|
|
|
pub fn chunks4_with_remainder(x: &[u8]) -> (&[[u8; 4]], &[u8]) {
|
|
|
|
// CHECK: and i64 %x.1, -4
|
|
|
|
// CHECK: and i64 %x.1, 3
|
|
|
|
// CHECK: lshr exact
|
|
|
|
// CHECK-NOT: mul
|
|
|
|
// CHECK-NOT: udiv
|
|
|
|
// CHECK-NOT: urem
|
|
|
|
// CHECK: ret
|
|
|
|
x.as_chunks()
|
|
|
|
}
|