Compiler projects using llvm
// REQUIRES: amdgpu-registered-target

// RUN: %clang_cc1 -triple x86_64-mingw64 -emit-llvm-bc -target-cpu x86-64 -fopenmp -fopenmp-targets=amdgcn-amd-amdhsa -o %t.bc -x c++ %s
// RUN: %clang_cc1 -triple amdgcn-amd-amdhsa -aux-triple x86_64-mingw64 -fsyntax-only -target-cpu gfx900 -fopenmp -fopenmp-is-device -fopenmp-host-ir-file-path %t.bc -x c++ %s
// expected-no-diagnostics

void print(double);

constexpr double operator"" _X (long double a)
{
	return (double)a;
}

int main()
{
	auto a = 1._X;
  print(a);
#pragma omp target map(tofrom: a)
	{
#pragma omp teams num_teams(1) thread_limit(4)
		{
			a += 1._X;
		}
	}
  print(a);
	return 0;
}