Morse Micro IoT SDK  2.10.4
porting_assistant.c
Go to the documentation of this file.
1/*
2 * Copyright 2021-2023 Morse Micro
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
27#include "porting_assistant.h"
28#include "mmhal_core.h"
29
30#if defined(ENABLE_EXT_XTAL_INIT) && ENABLE_EXT_XTAL_INIT
31/* The crystal initialization requires chip specific configuration which we do not have access
32 * to in the porting assistant example application. */
33#error "With ENABLE_EXT_XTAL_INIT defined this device is not supported by porting assistant."
34#endif
35
36/* Test step declarations */
37extern const struct test_step test_step_os_malloc;
38extern const struct test_step test_step_os_realloc;
39extern const struct test_step test_step_os_time;
40extern const struct test_step test_step_os_task_creation;
42extern const struct test_step test_step_mmhal_wlan_init;
45extern const struct test_step test_step_read_chip_id;
46extern const struct test_step test_step_bulk_write_read;
47extern const struct test_step test_step_raw_tput;
52extern const struct test_step test_step_verify_busy_pin;
55static const struct test_step *const test_steps[] = {
69};
70
73{
75 unsigned no_result;
77 unsigned pass;
79 unsigned fail;
80};
81
89static const char *result_code_to_string(enum test_result result)
90{
91 switch (result)
92 {
93 case TEST_NO_RESULT:
94 return "";
95 case TEST_PASSED:
96 return F_GREEN("PASS");
97 case TEST_SKIPPED:
98 return F_BLUE("SKIP");
99 case TEST_FAILED:
100 return F_RED("FAIL");
101 case TEST_FAILED_NON_CRITICAL:
102 return F_YELLOW("FAIL");
103 }
104 MMOSAL_ASSERT(false);
105}
106
115static void run_test_steps(const struct test_step *const steps[],
116 size_t num_steps,
117 struct test_counters *ctrs)
118{
119 static char log_buf[1024];
120
121 size_t ii;
122 for (ii = 0; ii < num_steps; ii++)
123 {
124 const struct test_step *step = steps[ii];
125 size_t log_buf_len = sizeof(log_buf);
126 log_buf[0] = '\0';
127
128 LOG_PRINTF(F_BOLD("%-60s "), step->description);
129 LOG_FLUSH();
130
131 enum test_result result = step->exec(log_buf, log_buf_len);
132 if (result != TEST_NO_RESULT)
133 {
134 LOG_PRINTF("[ %s ]", result_code_to_string(result));
135 }
136 LOG_WRITE("\n");
137
138 if (log_buf[0] != '\0')
139 {
140 LOG_WRITE("\n");
141 LOG_WRITE(log_buf);
142 }
143
144 switch (result)
145 {
146 case TEST_NO_RESULT:
147 ctrs->no_result++;
148 break;
149 case TEST_PASSED:
150 ctrs->pass++;
151 break;
152 case TEST_SKIPPED:
153 break;
154 case TEST_FAILED:
155 ctrs->fail++;
156 break;
157 case TEST_FAILED_NON_CRITICAL:
158 ctrs->fail++;
159 break;
160 }
161
162 if (result == TEST_FAILED)
163 {
164 break;
165 }
166 }
167}
168
173void app_init(void)
174{
175 /* Having deep sleep enabled can complicate debugging. Given the purpose of this applications
176 * is to validate that you can communicate to the MM-Chip it will be disabled by default. */
178
179 struct test_counters ctrs = { 0 };
180 unsigned num_tests = sizeof(test_steps) / sizeof(test_steps[0]);
181
182 LOG_WRITE(F_BOLD("\n\nMM-IoT-SDK Porting Assistant\n"));
183 LOG_WRITE("----------------------------\n\n");
184 run_test_steps(test_steps, num_tests, &ctrs);
185
186 LOG_PRINTF("\n\n%u total test steps. %u passed, %u failed, %u no result, %u skipped\n",
187 num_tests,
188 ctrs.pass,
189 ctrs.fail,
190 ctrs.no_result,
191 num_tests - ctrs.no_result - ctrs.pass - ctrs.fail);
192}
void mmhal_set_deep_sleep_veto(uint8_t veto_id)
Sets a deep sleep veto that will prevent the device from entering deep sleep.
@ MMHAL_VETO_ID_APP_MIN
Start of deep sleep veto ID range that is available for application use.
Definition: mmhal_core.h:41
#define MMOSAL_ASSERT(expr)
Assert that the given expression evaluates to true and abort execution if not.
Definition: mmosal.h:934
const struct test_step test_step_mmhal_wlan_validate_bcf
Test definition.
const struct test_step test_step_read_chip_id
Test definition.
const struct test_step test_step_os_malloc
Test definition.
const struct test_step test_step_verify_busy_pin
Test definition.
const struct test_step test_step_os_realloc
Test definition.
const struct test_step test_step_mmhal_wlan_sdio_startup
Test definition.
const struct test_step test_step_raw_tput
Test definition.
const struct test_step test_step_mmhal_wlan_validate_fw
Test definition.
const struct test_step test_step_bulk_write_read
Test definition.
const struct test_step test_step_os_time
Test definition.
const struct test_step test_step_mmhal_wlan_hard_reset
Test definition.
static void run_test_steps(const struct test_step *const steps[], size_t num_steps, struct test_counters *ctrs)
Iterate through the given list of test steps and execute until complete or until a critical failure o...
const struct test_step test_step_os_task_creation
Test definition.
void app_init(void)
Main entry point to the application.
static const struct test_step *const test_steps[]
Array of test steps.
const struct test_step test_step_mmhal_wlan_init
Test definition.
static const char * result_code_to_string(enum test_result result)
Convert a test_result code to string.
Counters to track test runs.
unsigned no_result
Number of tests that did not return a pass/fail result.
unsigned pass
Number of tests that passed.
unsigned fail
Number of tests that failed.
Test step descriptor.
const char * description
Short, user friendly description of the test step.
enum test_result(* exec)(char *log_buf, size_t log_buf_len)
Test step execution function.