OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
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.
| |
5 #include <sched.h> | |
6 #include <unistd.h> | |
7 | |
8 #include "native_client/src/include/nacl/nacl_exception.h" | |
9 #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.
| |
10 #include "ppapi/native_client/tests/ppapi_test_lib/test_interface.h" | |
11 | |
12 namespace { | |
13 | |
14 static void MyNaClExceptionHandler(struct NaClExceptionContext *context) { | |
15 printf("--- MyNaClExceptionHandler\n"); | |
16 TEST_PASSED; | |
17 // Wait for the javascript to realize that we have succeeded. If we | |
18 // 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.
| |
19 // crash from a complete failure to register a fault handler. | |
20 while (1) { | |
21 sched_yield(); | |
22 } | |
23 } | |
24 | |
25 void CrashViaSignalHandler() { | |
26 printf("--- CrashViaSignalHandler\n"); | |
27 | |
28 int retval = nacl_exception_set_handler(MyNaClExceptionHandler); | |
29 if (retval != 0) { | |
30 printf("Unexpected return value from nacl_exception_set_handler: %d\n", | |
31 retval); | |
32 TEST_FAILED; | |
33 return; | |
34 } | |
35 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
| |
36 } | |
37 | |
38 } // namespace | |
39 | |
40 void SetupTests() { | |
41 RegisterTest("CrashViaSignalHandler", CrashViaSignalHandler); | |
42 } | |
43 | |
44 void SetupPluginInterfaces() { | |
45 | |
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.
| |
46 // 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.
| |
47 } | |
OLD | NEW |