1*67e74705SXin Li // RUN: %clang_cc1 -triple i386-unknown-unknown -emit-llvm < %s| FileCheck %s 2*67e74705SXin Li // RUN: %clang_cc1 -triple x86_64-unknown-unknown -emit-llvm < %s| FileCheck %s 3*67e74705SXin Li // RUN: %clang_cc1 -triple x86_64-windows -emit-llvm < %s| FileCheck %s 4*67e74705SXin Li // RUN: %clang_cc1 -triple powerpc-unknown-unknown -emit-llvm < %s| FileCheck %s 5*67e74705SXin Li // RUN: %clang_cc1 -triple powerpc64-unknown-unknown -emit-llvm < %s| FileCheck %s 6*67e74705SXin Li // RUN: %clang_cc1 -triple sparc-eabi-unknown -emit-llvm < %s | FileCheck %s 7*67e74705SXin Li 8*67e74705SXin Li // RUN: %clang_cc1 -triple aarch64-unknown-unknown -emit-llvm-only -verify %s 9*67e74705SXin Li // RUN: %clang_cc1 -triple mips-unknown-unknown -emit-llvm-only -verify %s 10*67e74705SXin Li // RUN: %clang_cc1 -triple mips64-unknown-unknown -emit-llvm-only -verify %s 11*67e74705SXin Li 12*67e74705SXin Li // Check that __builtin_longjmp and __builtin_setjmp are lowered into 13*67e74705SXin Li // IR intrinsics on those architectures that can handle them. 14*67e74705SXin Li // Check that an error is created otherwise. 15*67e74705SXin Li 16*67e74705SXin Li typedef void *jmp_buf; 17*67e74705SXin Li jmp_buf buf; 18*67e74705SXin Li 19*67e74705SXin Li // CHECK: define{{.*}} void @do_jump() 20*67e74705SXin Li // CHECK: call{{.*}} void @llvm.eh.sjlj.longjmp 21*67e74705SXin Li 22*67e74705SXin Li // CHECK: define{{.*}} void @do_setjmp() 23*67e74705SXin Li // CHECK: call{{.*}} i32 @llvm.eh.sjlj.setjmp 24*67e74705SXin Li do_jump(void)25*67e74705SXin Livoid do_jump(void) { 26*67e74705SXin Li __builtin_longjmp(buf, 1); // expected-error {{__builtin_longjmp is not supported for the current target}} 27*67e74705SXin Li } 28*67e74705SXin Li 29*67e74705SXin Li void f(void); 30*67e74705SXin Li do_setjmp(void)31*67e74705SXin Livoid do_setjmp(void) { 32*67e74705SXin Li if (!__builtin_setjmp(buf)) // expected-error {{__builtin_setjmp is not supported for the current target}} 33*67e74705SXin Li f(); 34*67e74705SXin Li } 35