1! { dg-do run } 2! { dg-additional-options "-cpp" } 3 4! { dg-additional-options "-fopt-info-all-omp" } 5! { dg-additional-options "--param=openacc-privatization=noisy" } 6! { dg-additional-options "-foffload=-fopt-info-all-omp" } 7! { dg-additional-options "-foffload=--param=openacc-privatization=noisy" } 8! for testing/documenting aspects of that functionality. 9 10! TODO: Have to disable the acc_on_device builtin for we want to test 11! the libgomp library function? The command line option 12! '-fno-builtin-acc_on_device' is valid for C/C++/ObjC/ObjC++ but not 13! for Fortran. 14 15 IMPLICIT NONE 16 INCLUDE "openacc_lib.h" 17 18!Host. 19 20 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_NONE)) STOP 1 21 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_HOST)) STOP 2 22 IF (ACC_ON_DEVICE (ACC_DEVICE_NOT_HOST)) STOP 3 23 IF (ACC_ON_DEVICE (ACC_DEVICE_NVIDIA)) STOP 4 24 IF (ACC_ON_DEVICE (ACC_DEVICE_RADEON)) STOP 4 25 26 27!Host via offloading fallback mode. 28 29!$ACC PARALLEL IF(.FALSE.) 30! { dg-note {variable 'C\.[0-9]+' declared in block potentially has improper OpenACC privatization level: 'const_decl'} "TODO" { target *-*-* } .-1 } 31!TODO Unhandled 'CONST_DECL' instances for constant arguments in 'acc_on_device' calls. 32 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_NONE)) STOP 5 33 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_HOST)) STOP 6 34 IF (ACC_ON_DEVICE (ACC_DEVICE_NOT_HOST)) STOP 7 35 IF (ACC_ON_DEVICE (ACC_DEVICE_NVIDIA)) STOP 8 36 IF (ACC_ON_DEVICE (ACC_DEVICE_RADEON)) STOP 8 37!$ACC END PARALLEL 38 39 40#if !ACC_DEVICE_TYPE_host 41 42! Offloaded. 43 44!$ACC PARALLEL 45! { dg-note {variable 'C\.[0-9]+' declared in block potentially has improper OpenACC privatization level: 'const_decl'} "TODO" { target { ! openacc_host_selected } } .-1 } 46 IF (ACC_ON_DEVICE (ACC_DEVICE_NONE)) STOP 9 47 IF (ACC_ON_DEVICE (ACC_DEVICE_HOST)) STOP 10 48 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_NOT_HOST)) STOP 11 49#if ACC_DEVICE_TYPE_nvidia 50 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_NVIDIA)) STOP 12 51#else 52 IF (ACC_ON_DEVICE (ACC_DEVICE_NVIDIA)) STOP 13 53#endif 54#if ACC_DEVICE_TYPE_radeon 55 IF (.NOT. ACC_ON_DEVICE (ACC_DEVICE_RADEON)) STOP 14 56#else 57 IF (ACC_ON_DEVICE (ACC_DEVICE_RADEON)) STOP 15 58#endif 59!$ACC END PARALLEL 60 61#endif 62 63 END 64