diff options
| author | Chris Lattner <sabre@nondot.org> | 2003-08-24 06:55:07 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2003-08-24 06:55:07 +0000 |
| commit | 0f12ef6289367a97a10c21f57a0ea4033e6dc053 (patch) | |
| tree | 33cc8666036d7a727cd9794e036e1e12301e2bc0 /llvm | |
| parent | ade9410c990151329e4ab097da5797a4cd7cc991 (diff) | |
| download | bcm5719-llvm-0f12ef6289367a97a10c21f57a0ea4033e6dc053.tar.gz bcm5719-llvm-0f12ef6289367a97a10c21f57a0ea4033e6dc053.zip | |
New testcases for inlining invoke instructions
llvm-svn: 8103
Diffstat (limited to 'llvm')
3 files changed, 78 insertions, 0 deletions
diff --git a/llvm/test/Regression/Transforms/Inline/invoke_test-1.ll b/llvm/test/Regression/Transforms/Inline/invoke_test-1.ll new file mode 100644 index 00000000000..c8d844c8854 --- /dev/null +++ b/llvm/test/Regression/Transforms/Inline/invoke_test-1.ll @@ -0,0 +1,22 @@ +; Test that we can invoke a simple function, turning the calls in it into invoke +; instructions + +; RUN: as < %s | opt -inline | dis | not grep 'call[^e]' + +declare void %might_throw() + +implementation + +internal void %callee() { + call void %might_throw() + ret void +} + +; caller returns true if might_throw throws an exception... +int %caller() { + invoke void %callee() to label %cont except label %exc +cont: + ret int 0 +exc: + ret int 1 +} diff --git a/llvm/test/Regression/Transforms/Inline/invoke_test-2.ll b/llvm/test/Regression/Transforms/Inline/invoke_test-2.ll new file mode 100644 index 00000000000..d673e85d7dd --- /dev/null +++ b/llvm/test/Regression/Transforms/Inline/invoke_test-2.ll @@ -0,0 +1,27 @@ +; Test that if an invoked function is inlined, and if that function cannot +; throw, that the dead handler is now unreachable. + +; RUN: as < %s | opt -inline -simplifycfg | dis | not grep UnreachableExceptionHandler + +declare void %might_throw() + +implementation + +internal int %callee() { + invoke void %might_throw() to label %cont except label %exc +cont: + ret int 0 +exc: + ; This just consumes the exception! + ret int 1 +} + +; caller returns true if might_throw throws an exception... +int %caller() { + %X = invoke int %callee() to label %cont + except label %UnreachableExceptionHandler +cont: + ret int %X +UnreachableExceptionHandler: + ret int -1 ; This is dead! +} diff --git a/llvm/test/Regression/Transforms/Inline/invoke_test-3.ll b/llvm/test/Regression/Transforms/Inline/invoke_test-3.ll new file mode 100644 index 00000000000..bc112042b2e --- /dev/null +++ b/llvm/test/Regression/Transforms/Inline/invoke_test-3.ll @@ -0,0 +1,29 @@ +; Test that any rethrown exceptions in an inlined function are automatically +; turned into branches to the invoke destination. + +; RUN: as < %s | opt -inline | dis | not grep 'call void %llvm.exc.rethrow' + +declare void %might_throw() +declare void %llvm.exc.rethrow() + +implementation + +internal int %callee() { + invoke void %might_throw() to label %cont except label %exc +cont: + ret int 0 +exc: ; This just rethrows the exception! + call void %llvm.exc.rethrow() + ret int 0 +} + +; caller returns true if might_throw throws an exception... +int %caller() { + %X = invoke int %callee() to label %cont + except label %Handler +cont: + ret int %X +Handler: + ; This consumes an exception thrown by might_throw + ret int -1 +} |

