Chromium Code Reviews| Index: chrome/test/data/nacl/crash/nonsfi_crash_via_signal_handler.cc |
| diff --git a/chrome/test/data/nacl/crash/nonsfi_crash_via_signal_handler.cc b/chrome/test/data/nacl/crash/nonsfi_crash_via_signal_handler.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..18ebefa3a4a5366f98f73128637dd511c1c6b619 |
| --- /dev/null |
| +++ b/chrome/test/data/nacl/crash/nonsfi_crash_via_signal_handler.cc |
| @@ -0,0 +1,47 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
|
Mark Seaborn
2014/04/23 03:49:50
Could you name this file after the interface it te
Junichi Uekawa
2014/04/23 07:56:15
Done.
|
| +#include <sched.h> |
| +#include <unistd.h> |
| + |
| +#include "native_client/src/include/nacl/nacl_exception.h" |
| +#include "native_client/src/shared/platform/nacl_check.h" |
|
Mark Seaborn
2014/04/23 03:49:50
I don't think you use this?
Junichi Uekawa
2014/04/23 07:56:15
Done.
|
| +#include "ppapi/native_client/tests/ppapi_test_lib/test_interface.h" |
| + |
| +namespace { |
| + |
| +static void MyNaClExceptionHandler(struct NaClExceptionContext *context) { |
| + printf("--- MyNaClExceptionHandler\n"); |
| + TEST_PASSED; |
| + // Wait for the javascript to realize that we have succeeded. If we |
| + // exit from here we shall crash and it's hard to distinguish that |
|
Mark Seaborn
2014/04/23 03:49:50
You could exit using setjmp()/longjmp() to exit fr
Junichi Uekawa
2014/04/23 07:56:15
Done.
|
| + // crash from a complete failure to register a fault handler. |
| + while (1) { |
| + sched_yield(); |
| + } |
| +} |
| + |
| +void CrashViaSignalHandler() { |
| + printf("--- CrashViaSignalHandler\n"); |
| + |
| + int retval = nacl_exception_set_handler(MyNaClExceptionHandler); |
| + if (retval != 0) { |
| + printf("Unexpected return value from nacl_exception_set_handler: %d\n", |
| + retval); |
| + TEST_FAILED; |
| + return; |
| + } |
| + CRASH; |
|
Mark Seaborn
2014/04/23 03:49:50
I think it would be better to use __builtin_trap()
Junichi Uekawa
2014/04/23 07:56:15
It seemed to me that CRASH is more consistent with
|
| +} |
| + |
| +} // namespace |
| + |
| +void SetupTests() { |
| + RegisterTest("CrashViaSignalHandler", CrashViaSignalHandler); |
| +} |
| + |
| +void SetupPluginInterfaces() { |
| + |
|
Mark Seaborn
2014/04/23 03:49:50
Nit: remove empty line at start of function
Junichi Uekawa
2014/04/23 07:56:15
Done.
|
| + // none |
|
Mark Seaborn
2014/04/23 03:49:50
Nit: maybe remove this? Empty functions aren't us
Junichi Uekawa
2014/04/23 07:56:15
Done.
|
| +} |