! { dg-do run } ! { dg-options "-O -fdump-tree-original" } program main implicit none character(len=4) :: c integer :: n integer :: i common /foo/ i n = 0 i = 0 c = 'abcd' n = n + 1 ; if (c == c) call yes n = n + 1 ; if (c >= c) call yes n = n + 1 ; if (c <= c) call yes n = n + 1 ; if (c .eq. c) call yes n = n + 1 ; if (c .ge. c) call yes n = n + 1 ; if (c .le. c) call yes if (c /= c) STOP 1 if (c > c) STOP 2 if (c < c) STOP 3 if (c .ne. c) STOP 4 if (c .gt. c) STOP 5 if (c .lt. c) STOP 6 if (n /= i) STOP 7 end program main subroutine yes implicit none common /foo/ i integer :: i i = i + 1 end subroutine yes ! { dg-final { scan-tree-dump-times "gfortran_compare_string" 0 "original" } }