1! { dg-do run }
2! { dg-options "-fno-backtrace -fbounds-check -fno-realloc-lhs" }
3! { dg-shouldfail "Fortran runtime error: Incorrect extent in return array in MATMUL intrinsic for dimension 1: is 4, should be 3" }
4program main
5  real, dimension(3,2) :: a
6  real, dimension(3,2) :: b
7  real, dimension(:,:), allocatable :: ret
8  allocate (ret(3,3))
9  a = 1.0
10  b = 2.3
11  ret = matmul(a,transpose(b))  ! This is OK
12  deallocate(ret)
13  allocate(ret(4,3))
14  ret = matmul(a,transpose(b))  ! This should throw an error.
15end program main
16! { dg-output "Fortran runtime error: Incorrect extent in return array in MATMUL intrinsic for dimension 1: is 4, should be 3" }
17