custom-board-bundle-sample-.../firmware/controllers/global_shared.h

92 lines
3.1 KiB
C
Raw Normal View History

2018-12-25 13:06:24 -08:00
/*
2019-11-19 22:35:08 -08:00
* @file global_shared.h
2018-12-25 13:06:24 -08:00
*
* part of global.h which is shared between firmware and simulator
* See also common_headers.h
*
* Dec 25, 2018
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2018-12-25 13:06:24 -08:00
*/
2019-11-19 22:35:08 -08:00
#pragma once
2018-12-25 13:06:24 -08:00
/**
* The following obscurantism is a hack to reduce stack usage, maybe even a questionable performance
* optimization.
*
* Of note is that interrupts are NOT serviced on the stack of the thread that was running when the
* interrupt occurred. The only thing that happens on that thread's stack is that its registers are
* pushed (by hardware) when an interrupt occurs, just before swapping the stack pointer out for the
* main stack (currently 0x400=1024 bytes), where the ISR actually runs.
2019-12-13 15:05:08 -08:00
* see also __main_stack_size__
* see also __process_stack_size__
*
* see also http://www.chibios.org/dokuwiki/doku.php?id=chibios:kb:stacks
2018-12-25 13:06:24 -08:00
*
* In the firmware we are using 'extern *Engine' - in the firmware Engine is a signleton
*
* On the other hand, in order to have a meaningful unit test we are passing Engine * engine as a parameter
*/
2019-11-19 22:35:08 -08:00
#include "global.h"
2020-02-26 22:51:21 -08:00
#define EXTERN_ENGINE_CONFIGURATION \
extern engine_configuration_s *engineConfiguration; \
extern persistent_config_container_s persistentState; \
2020-02-26 22:51:21 -08:00
extern persistent_config_s *config;
2020-02-26 22:32:26 -08:00
/**
* this macro allows the compiled to figure out the complete static address, that's a performance
* optimization which is hopefully useful at least for anything trigger-related
*
* this is related to the fact that for unit tests we prefer to explicitly pass references in method signature thus code covered by
* unit tests would need to use by-reference access. These macro allow us to have faster by-address access in real firmware and by-reference
* access in unit tests
*/
#define CONFIG(x) persistentState.persistentConfiguration.engineConfiguration.x
#ifdef __cplusplus
2020-02-26 22:51:21 -08:00
/**
* & is reference in C++ (not C)
* Ref is a pointer that:
* you access with dot instead of arrow
* Cannot be null
* This is about EFI_ACTIVE_CONFIGURATION_IN_FLASH
*/
#define EXTERN_CONFIG \
EXTERN_ENGINE_CONFIGURATION \
extern engine_configuration_s & activeConfiguration; \
2019-01-27 23:59:14 -08:00
#define EXTERN_ENGINE \
extern Engine ___engine; \
extern Engine *engine; \
EXTERN_CONFIG \
extern EnginePins enginePins \
2018-12-25 13:06:24 -08:00
// Use this macro to declare a function which only takes magic references
#define DECLARE_ENGINE_PARAMETER_SIGNATURE void
// Use this version of the macro as the suffix if method has other parameters
#define DECLARE_ENGINE_PARAMETER_SUFFIX
2019-01-27 23:59:14 -08:00
// Pass this if only magic references are needed
2018-12-25 13:06:24 -08:00
#define PASS_ENGINE_PARAMETER_SIGNATURE
// Pass this after some other parameters are passed
#define PASS_ENGINE_PARAMETER_SUFFIX
2019-01-27 20:07:02 -08:00
// these macro are used when we should not have visibility to 'engine'
#define DECLARE_CONFIG_PARAMETER_SIGNATURE void
#define DECLARE_CONFIG_PARAMETER_SUFFIX
#define PASS_CONFIG_PARAMETER_SIGNATURE
#define PASS_CONFIG_PARAMETER_SUFFIX
2019-01-27 23:59:14 -08:00
#define ENGINE(x) ___engine.x
2018-12-25 13:06:24 -08:00
#define DEFINE_CONFIG_PARAM(x, y)
#define CONFIG_PARAM(x) CONFIG(x)
#define PASS_CONFIG_PARAM(x)
2018-12-25 13:06:24 -08:00
#define EXPECTED_REMAINING_STACK 128
2020-02-26 22:32:26 -08:00
#endif /* __cplusplus */