#define S_FUNCTION_NAME MCU #define S_FUNCTION_LEVEL 2 #include "mcu_wrapper_conf.h" double SIM_Sample_Time; #define MDL_UPDATE /* Function: mdlUpdate ==================================================== * Abstract: * This function is called once for every major integration time step. * Discrete states are typically updated here, but this function is useful * for performing any tasks that should only take place once per * integration step. */ static void mdlUpdate(SimStruct *S, int_T tid) { // get S_Func "periphery" const real_T *IN = ssGetInputPortRealSignal(S,0); real_T *DISC = ssGetDiscStates(S); time_T TIME = ssGetT(S); //---------------SIMULATE MCU--------------- MCU_Step_Simulation(S, IN, DISC, TIME); // SIMULATE MCU //------------------------------------------ }//end mdlUpdate /* Function: mdlOutputs =================================================== * Abstract: * In this function, you compute the outputs of your S-function * block. Generally outputs are placed in the output vector(s), * ssGetOutputPortSignal. */ static void mdlOutputs(SimStruct *S, int_T tid) { real_T *PORTA = ssGetOutputPortRealSignal(S,0); real_T *PORTE = ssGetOutputPortRealSignal(S,1); real_T *DISC = ssGetDiscStates(S); //-------------WRITTING GPIOS--------------- for (int i=0; i < PORT_WIDTH; i++) { PORTA[i] = DISC[i]; DISC[i] = 0; PORTE[i] = DISC[PORT_WIDTH + i]; DISC[PORT_WIDTH + i] = 0; } //------------------------------------------ }//end mdlOutputs #define MDL_CHECK_PARAMETERS /* Change to #undef to remove function */ #if defined(MDL_CHECK_PARAMETERS) && defined(MATLAB_MEX_FILE) static void mdlCheckParameters(SimStruct *S) { int i; // Проверяем и принимаем параметры и разрешаем или запрещаем их менять // в процессе моделирования for (i=0; i<1; i++) { // Input parameter must be scalar or vector of type double if (!mxIsDouble(ssGetSFcnParam(S,i)) || mxIsComplex(ssGetSFcnParam(S,i)) || mxIsEmpty(ssGetSFcnParam(S,i))) { ssSetErrorStatus(S,"Input parameter must be of type double"); return; } // Параметр м.б. только скаляром, вектором или матрицей if (mxGetNumberOfDimensions(ssGetSFcnParam(S,i)) > 2) { ssSetErrorStatus(S,"Параметр м.б. только скаляром, вектором или матрицей"); return; } // sim_dt = mxGetPr(ssGetSFcnParam(S,0))[0]; // Parameter not tunable // ssSetSFcnParamTunable(S, i, SS_PRM_NOT_TUNABLE); // Parameter tunable (we must create a corresponding run-time parameter) ssSetSFcnParamTunable(S, i, SS_PRM_TUNABLE); // Parameter tunable only during simulation // ssSetSFcnParamTunable(S, i, SS_PRM_SIM_ONLY_TUNABLE); }//for (i=0; i