2018-08-30 07:18:55 -05:00
|
|
|
// run-pass
|
2016-09-15 12:02:10 -05:00
|
|
|
// Issue #34427: On ARM, the code in `foo` at one time was generating
|
|
|
|
// a machine code instruction of the form: `str r0, [r0, rN]!` (for
|
|
|
|
// some N), which is not legal because the source register and base
|
|
|
|
// register cannot be identical in the preindexed form signalled by
|
|
|
|
// the `!`.
|
|
|
|
//
|
|
|
|
// See LLVM bug: https://llvm.org/bugs/show_bug.cgi?id=28809
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
fn foo(n: usize) -> Vec<Option<(*mut (), &'static ())>> {
|
|
|
|
(0..n).map(|_| None).collect()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let _ = (foo(10), foo(32));
|
|
|
|
}
|