|  | //@ assembly-output: emit-asm | 
|  | //@ compile-flags: -Copt-level=1 | 
|  | //@ only-x86_64 | 
|  | #![crate_type = "rlib"] | 
|  |  | 
|  | // CHECK-LABEL: align_offset_byte_ptr | 
|  | // CHECK: leaq 31 | 
|  | // CHECK: andq $-32 | 
|  | // CHECK: subq | 
|  | #[no_mangle] | 
|  | pub fn align_offset_byte_ptr(ptr: *const u8) -> usize { | 
|  | ptr.align_offset(32) | 
|  | } | 
|  |  | 
|  | // CHECK-LABEL: align_offset_byte_slice | 
|  | // CHECK: leaq 31 | 
|  | // CHECK: andq $-32 | 
|  | // CHECK: subq | 
|  | #[no_mangle] | 
|  | pub fn align_offset_byte_slice(slice: &[u8]) -> usize { | 
|  | slice.as_ptr().align_offset(32) | 
|  | } | 
|  |  | 
|  | // CHECK-LABEL: align_offset_word_ptr | 
|  | // CHECK: leaq 31 | 
|  | // CHECK: andq $-32 | 
|  | // CHECK: subq | 
|  | // CHECK: shrq | 
|  | // This `ptr` is not known to be aligned, so it is required to check if it is at all possible to | 
|  | // align. LLVM applies a simple mask. | 
|  | // CHECK: orq | 
|  | #[no_mangle] | 
|  | pub fn align_offset_word_ptr(ptr: *const u32) -> usize { | 
|  | ptr.align_offset(32) | 
|  | } | 
|  |  | 
|  | // CHECK-LABEL: align_offset_word_slice | 
|  | // CHECK: leaq 31 | 
|  | // CHECK: andq $-32 | 
|  | // CHECK: subq | 
|  | // CHECK: shrq | 
|  | // `slice` is known to be aligned, so `!0` is not possible as a return | 
|  | // CHECK-NOT: orq | 
|  | #[no_mangle] | 
|  | pub fn align_offset_word_slice(slice: &[u32]) -> usize { | 
|  | slice.as_ptr().align_offset(32) | 
|  | } |