forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			83 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
// REQUIRES: powerpc-registered-target
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-DEFAULT
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mno-vsx -mpower8-vector %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-NVSX-P8V
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mno-vsx -mdirect-move %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-NVSX-DMV
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mno-vsx -mpower8-vector -mvsx %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-DEFAULT
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mno-vsx -mdirect-move -mvsx %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-DEFAULT
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mpower8-vector -mno-vsx %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-NVSX-P8V
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mdirect-move -mno-vsx %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-NVSX-DMV
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power8 -std=c++11 -mno-vsx %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-NVSX
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power6 -std=c++11 %s 2>&1 | FileCheck %s -check-prefix=CHECK-NVSX
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power6 -std=c++11 -mpower8-vector %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-DEFAULT
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power6 -std=c++11 -mdirect-move %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-VSX
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power9 -std=c++11 %s 2>&1 | FileCheck %s \
 | 
						|
// RUN: -check-prefix=CHECK-DEFAULT-P9
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power9 -std=c++11 -mno-vsx -mpower9-vector %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-NVSX-P9V
 | 
						|
 | 
						|
// RUN: not %clang -target powerpc64le-unknown-unknown -fsyntax-only \
 | 
						|
// RUN: -mcpu=power9 -std=c++11 -mno-vsx -mfloat128 %s 2>&1 | \
 | 
						|
// RUN: FileCheck %s -check-prefix=CHECK-NVSX-FLT128
 | 
						|
 | 
						|
#ifdef __VSX__
 | 
						|
static_assert(false, "VSX enabled");
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __POWER8_VECTOR__
 | 
						|
static_assert(false, "P8V enabled");
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __POWER9_VECTOR__
 | 
						|
static_assert(false, "P9V enabled");
 | 
						|
#endif
 | 
						|
 | 
						|
#if !defined(__VSX__) && !defined(__POWER8_VECTOR__) && \
 | 
						|
    !defined(__POWER9_VECTOR__)
 | 
						|
static_assert(false, "Neither enabled");
 | 
						|
#endif
 | 
						|
 | 
						|
// CHECK-DEFAULT: VSX enabled
 | 
						|
// CHECK-DEFAULT: P8V enabled
 | 
						|
// CHECK-DEFAULT-P9: P9V enabled
 | 
						|
// CHECK-NVSX-P8V: error: option '-mpower8-vector' cannot be specified with '-mno-vsx'
 | 
						|
// CHECK-NVSX-P9V: error: option '-mpower9-vector' cannot be specified with '-mno-vsx'
 | 
						|
// CHECK-NVSX-FLT128: error: option '-mfloat128' cannot be specified with '-mno-vsx'
 | 
						|
// CHECK-NVSX-DMV: error: option '-mdirect-move' cannot be specified with '-mno-vsx'
 | 
						|
// CHECK-NVSX: Neither enabled
 | 
						|
// CHECK-VSX: VSX enabled
 |