//! Regression test for https://github.com/rust-lang/rust/issues/137646. //! Since we don't know the exact implementation of the virtual call, //! it might write to parameters, we can't infer the readonly attribute. //@ compile-flags: -C opt-level=3 -C no-prepopulate-passes #![crate_type = "lib"] #![feature(rustc_attrs)] pub trait Trait { #[rustc_nounwind] fn m(&self, _: (i32, i32, i32)) {} } #[no_mangle] pub fn foo(trait_: &dyn Trait) { // CHECK-LABEL: @foo( // CHECK: call void // CHECK-NOT: readonly trait_.m((1, 1, 1)); } #[no_mangle] #[rustc_nounwind] pub fn foo_nounwind(trait_: &dyn Trait) { // CHECK-LABEL: @foo_nounwind( // FIXME: Here should be invoke. // COM: CHECK: invoke trait_.m((1, 1, 1)); } #[no_mangle] pub extern "C" fn c_nounwind(trait_: &dyn Trait) { // CHECK-LABEL: @c_nounwind( // FIXME: Here should be invoke. // COM: CHECK: invoke trait_.m((1, 1, 1)); }