1 // Copyright 2012-2014 The Rust Project Developers. See the COPYRIGHT
2 // file at the top-level directory of this distribution and at
3 // http://rust-lang.org/COPYRIGHT.
5 // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6 // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7 // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8 // option. This file may not be copied, modified, or distributed
9 // except according to those terms.
11 // pretty-expanded FIXME #23616
15 #[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
16 unsafe fn next_power_of_2(n: u32) -> u32 {
18 asm!("dec $0" : "+rm"(tmp) :: "cc");
19 let mut shift = 1_usize;
25 : "+&rm"(tmp), "+{ecx}"(shift) : "r"(tmp) : "cc"
28 asm!("inc $0" : "+rm"(tmp) :: "cc");
32 #[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
35 assert_eq!(64, next_power_of_2(37));
36 assert_eq!(2147483648, next_power_of_2(2147483647));
42 // Treat the output as initialization.
47 : "=r"(x), "+r"(y) : "i"(3_usize), "ir"(7_usize) : "cc"
57 // Assignment to mutable.
59 // Forbids the use of a single register by both operands.
60 asm!("shr $$2, $1; add $1, $0" : "+&r"(x) : "r"(x) : "cc");
65 #[cfg(not(any(target_arch = "x86", target_arch = "x86_64")))]