1 /*
2  * Copyright (c) Copyright (c) 2020 Intel Corporation.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #include <zephyr/kernel.h>
8 #include <zephyr/sys/printk.h>
9 #include <ksched.h>
10 
11 static volatile int expected_reason = -1;
12 
13 void z_thread_essential_clear(struct k_thread *thread);
14 
k_sys_fatal_error_handler(unsigned int reason,const struct arch_esf * pEsf)15 void k_sys_fatal_error_handler(unsigned int reason, const struct arch_esf *pEsf)
16 {
17 	printk("Caught system error -- reason %d\n", reason);
18 
19 	if (expected_reason == -1) {
20 		printk("Was not expecting a crash\n");
21 		printk("PROJECT EXECUTION FAILED\n");
22 		k_fatal_halt(reason);
23 	}
24 
25 	if (reason != expected_reason) {
26 		printk("Wrong crash type got %d expected %d\n", reason,
27 		       expected_reason);
28 		printk("PROJECT EXECUTION FAILED\n");
29 		k_fatal_halt(reason);
30 	}
31 
32 	printk("Fatal error expected as part of test case.\n");
33 
34 	expected_reason = -1;
35 }
36 
37 /**
38  * @brief This test case verifies when fatal error
39  *        log message can be captured.
40  * @details
41  * Test Objective:
42  * - When the fatal error is triggered, if the debugging message function
43  *   is turned on, the system can capture the log information.
44  *
45  * Prerequisite Conditions:
46  * - N/A
47  *
48  * Input Specifications:
49  * - N/A
50  *
51  * Test Procedure:
52  * -# Writing a function deliberately triggers a koops exception.
53  * -# When the log module is enabled, it will log some information
54  *    in the process of exception.
55  * -# The regex in testcase.yaml verify the kernel will dump thread id
56  *    information and error type when exception occurs.
57  *
58  * Expected Test Result:
59  * - The expected log message is caught.
60  *
61  * Pass/Fail Criteria:
62  * - Success if the log matching regex in step 3.
63  * - Failure if the log is not matching regex in step 3.
64  *
65  * Assumptions and Constraints:
66  * - N/A
67  * @ingroup kernel_fatal_tests
68  */
test_message_capture(void)69 void test_message_capture(void)
70 {
71 	unsigned int key;
72 
73 	expected_reason = K_ERR_KERNEL_OOPS;
74 
75 	key = irq_lock();
76 	k_oops();
77 	printk("SHOULD NEVER SEE THIS\n");
78 	irq_unlock(key);
79 }
80 
main(void)81 int main(void)
82 {
83 	/* main() is an essential thread, and we try to OOPS it.  When
84 	 * this test was written, that worked (even though it wasn't
85 	 * supposed to per docs).  Now we trap a different error (a
86 	 * panic and not an oops).  Set the thread non-essential as a
87 	 * workaround.
88 	 */
89 	z_thread_essential_clear(arch_current_thread());
90 
91 	test_message_capture();
92 	return 0;
93 }
94