sched: Pass shutdown reason code via longjmp() parameter

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2017-07-02 14:29:16 -04:00
parent cf662b842b
commit 09140a51d5
2 changed files with 9 additions and 7 deletions

View File

@ -102,11 +102,13 @@ ctr_lookup_output(const char *str)
return fmt % ("".join(encoder_defs).strip(), "".join(encoder_code).strip(), return fmt % ("".join(encoder_defs).strip(), "".join(encoder_code).strip(),
"".join(output_code).strip()) "".join(output_code).strip())
STATIC_STRING_MIN = 2
def build_static_strings(static_strings): def build_static_strings(static_strings):
code = [] code = []
for i, s in enumerate(static_strings): for i, s in enumerate(static_strings):
code.append(' if (__builtin_strcmp(str, "%s") == 0)\n' code.append(' if (__builtin_strcmp(str, "%s") == 0)\n'
' return %d;\n' % (s, i)) ' return %d;\n' % (s, i + STATIC_STRING_MIN))
fmt = """ fmt = """
uint8_t __always_inline uint8_t __always_inline
ctr_lookup_static_string(const char *str) ctr_lookup_static_string(const char *str)
@ -187,7 +189,7 @@ def build_identify(cmd_by_id, msg_to_id, responses, static_strings
data['messages'] = messages data['messages'] = messages
data['commands'] = sorted(cmd_by_id.keys()) data['commands'] = sorted(cmd_by_id.keys())
data['responses'] = sorted(responses) data['responses'] = sorted(responses)
data['static_strings'] = { i: static_strings[i] data['static_strings'] = { i + STATIC_STRING_MIN: static_strings[i]
for i in range(len(static_strings)) } for i in range(len(static_strings)) }
data['config'] = constants data['config'] = constants
data['version'] = version data['version'] = version

View File

@ -205,9 +205,11 @@ sched_clear_shutdown(void)
// Invoke all shutdown functions (as declared by DECL_SHUTDOWN) // Invoke all shutdown functions (as declared by DECL_SHUTDOWN)
static void static void
run_shutdown(void) run_shutdown(int reason)
{ {
uint32_t cur = timer_read_time(); uint32_t cur = timer_read_time();
if (!shutdown_status)
shutdown_reason = reason;
shutdown_status = 2; shutdown_status = 2;
extern void ctr_run_shutdownfuncs(void); extern void ctr_run_shutdownfuncs(void);
ctr_run_shutdownfuncs(); ctr_run_shutdownfuncs();
@ -239,9 +241,7 @@ void
sched_shutdown(uint_fast8_t reason) sched_shutdown(uint_fast8_t reason)
{ {
irq_disable(); irq_disable();
if (!shutdown_status) longjmp(shutdown_jmp, reason);
shutdown_reason = reason;
longjmp(shutdown_jmp, 1);
} }
@ -261,7 +261,7 @@ sched_main(void)
int ret = setjmp(shutdown_jmp); int ret = setjmp(shutdown_jmp);
if (ret) if (ret)
run_shutdown(); run_shutdown(ret);
for (;;) for (;;)
ctr_run_taskfuncs(); ctr_run_taskfuncs();