/** ************************************************************************** * @dir ../MCU_Wrapper * @brief Папка с исходным кодом оболочки МК. * @details В этой папке содержаться оболочка(англ. wrapper) для запуска и контроля эмуляции микроконтроллеров в MATLAB (любого МК, не только STM). Оболочка представляет собой S-Function - блок в Simulink, который работает по скомпилированому коду. Компиляция происходит с помощью MSVC-компилятора. **************************************************************************/ /** ************************************************************************** * @file mcu_wrapper_conf.h * @brief Заголовочный файл для оболочки МК. ************************************************************************** @details Главный заголовочный файл для матлаба. Включает дейфайны для S-Function, объявляет базовые функции для симуляции МК и подключает базовые библиотеки: - для симуляции "stm32fxxx_matlab_conf.h" - для S-Function "simstruc.h" - для потоков **************************************************************************/ #ifndef _WRAPPER_CONF_H_ #define _WRAPPER_CONF_H_ // Includes #include "simstruc.h" // For S-Function variables #include // For threads #include "mcu_app_includes.h" /** * @defgroup MCU_WRAPPER MCU Wrapper * @brief Всякое для оболочки МК */ /** * @addtogroup WRAPPER_CONF Wrapper Configuration * @ingroup MCU_WRAPPER * @brief Параметры конфигурации для оболочки МК * @details Здесь дефайнами задается параметры оболочки, которые определяют как она будет работать * @{ */ // Parametrs of MCU simulator //#define RUN_APP_THRREAD #define CREATE_SUSPENDED 0x00000004 ///< define from WinBase.h. We dont wanna include "Windows.h" or smth like this, because of HAL there are a lot of redefine errors. #define DEKSTOP_CYCLES_FOR_MCU_APP 0xFFFF ///< number of for() cycles after which MCU thread would be suspended // Parameters of S_Function #define NPARAMS 1 ///< number of input parametrs (only Ts) #define IN_PORT_WIDTH 20 ///< width of input ports #define IN_PORT_NUMB 1 ///< number of input ports #define OUT_PORT_WIDTH 51 ///< width of output ports #define OUT_PORT_NUMB 1 ///< number of output ports #define DISC_STATES_WIDTH OUT_PORT_WIDTH*OUT_PORT_NUMB ///< width of discrete states array #define NPARAMS 1 //кол-во параметров (скаляров и векторов) #define RWORK_0_WIDTH 5 //width of the real-work vector #define IWORK_0_WIDTH 5 //width of the integer-work vector #define MCU_CORE_CLOCK 150000000 /** WRAPPER_CONF * @} */ /** * @addtogroup MCU_WRAPPER * @{ */ typedef void* HANDLE; ///< MCU handle typedef /** * @brief MCU handle Structure definition. * @note Prefixes: h - handle, s - settings, f - flag */ typedef struct { // MCU Thread HANDLE hMCUThread; ///< Хендл для потока МК int idMCUThread; ///< id потока МК (unused) // Flags unsigned fMCU_Stop : 1; ///< флаг для выхода из потока программы МК double SimSampleTime; ///< sample time of simulation double SystemClockDouble; ///< Счетчик в формате double для точной симуляции системных тиков С промежуточными значений long SystemClock; ///< Счетчик тактов для симуляции системных тиков (в целочисленном формате) double SystemClock_step; ///< Шаг тиков для их симуляции, в формате double double SimTime; ///< Текущее время симуляции }SIM__MCUHandleTypeDef; extern SIM__MCUHandleTypeDef hmcu; // extern для видимости переменной во всех файлах //-------------------------------------------------------------// //------------------ SIMULINK WHILE DEFINES -----------------// /* DEFINE TO WHILE WITH SIMULINK WHILE */ /** * @brief Redefine C while statement with sim_while() macro. * @param _expression_ - expression for while. * @details Это while который будет использоваться в симулинке @ref sim_while для подробностей. */ #define while(_expression_) sim_while(_expression_) /* SIMULINK WHILE */ /** * @brief While statement for emulate MCU code in Simulink. * @param _expression_ - expression for while. * @details Данный while необходим, чтобы в конце симуляции, завершить поток МК: * При выставлении флага окончания симуляции, все while будут пропускаться * и поток сможет дойти до конца функции main и завершить себя. */ #define sim_while(_expression_) while((_expression_)&&(hmcu.fMCU_Stop == 0)) /* DEFAULT WHILE */ /** * @brief Default/Native C while statement. * @param _expression_ - expression for while. * @details Данный while - аналог обычного while, без дополнительного функционала. */ #define native_while(_expression_) for(; (_expression_); ) /***************************************************************/ //------------------ SIMULINK WHILE DEFINES -----------------// //-------------------------------------------------------------// //-------------------------------------------------------------// //---------------- SIMULATE FUNCTIONS PROTOTYPES -------------// /* Step simulation */ void MCU_Step_Simulation(SimStruct *S, time_T time); /* MCU peripheral simulation */ void MCU_Periph_Simulation(void); /* Initialize MCU simulation */ void SIM_Initialize_Simulation(void); /* Deinitialize MCU simulation */ void SIM_deInitialize_Simulation(void); /* Read inputs S-function */ void MCU_readInputs(SimStruct* S); /* Write pre-outputs S-function (out_buff states) */ void MCU_writeOutputs(SimStruct* S); /* Write outputs of block of S-Function*/ void SIM_writeOutput(SimStruct* S); //---------------- SIMULATE FUNCTIONS PROTOTYPES -------------// //-------------------------------------------------------------// /** MCU_WRAPPER * @} */ #endif // _WRAPPER_CONF_H_ //-------------------------------------------------------------// //---------------------BAT FILE DESCRIBTION--------------------// /** * @file run_mex.bat * @brief Батник для компиляции оболочки МК. * @details * Вызывается в матлабе из mexing.m. * * Исходный код батника: * @include F:\Work\Projects\MATLAB\matlab_stm_emulate\MCU_Wrapper\run_mex.bat */