/* * CANTest.c * * Academic License - for use in teaching, academic research, and meeting * course requirements at degree granting institutions only. Not for * government, commercial, or other organizational use. * * Code generation for model "CANTest". * * Model version : 1.360 * Simulink Coder version : 8.14 (R2018a) 06-Feb-2018 * C source code generated on : Tue Jul 11 11:56:08 2023 * * Target selection: slrt.tlc * Note: GRT includes extra infrastructure and instrumentation for prototyping * Embedded hardware selection: Generic->32-bit x86 compatible * Code generation objectives: Unspecified * Validation result: Not run */ #include "rt_logging_mmi.h" #include "CANTest_capi.h" #include "CANTest.h" #include "CANTest_private.h" /* Block signals (default storage) */ B_CANTest_T CANTest_B; /* Block states (default storage) */ DW_CANTest_T CANTest_DW; /* Real-time model */ RT_MODEL_CANTest_T CANTest_M_; RT_MODEL_CANTest_T *const CANTest_M = &CANTest_M_; /* Model output function */ static void CANTest_output(void) { int32_T s1_iter; /* Gain: '/ContM' incorporates: * Constant: '/ContMode' */ CANTest_B.ContMode = CANTest_P.ContM_Gain * CANTest_P.ContMode_Value; /* Constant: '/Constant' */ CANTest_B.Ready = CANTest_P.Constant_Value; /* Constant: '/Constant1' */ CANTest_B.Gear = CANTest_P.Constant1_Value; /* Constant: '/Constant2' */ CANTest_B.BMS = CANTest_P.Constant2_Value; /* Constant: '/Constant3' */ CANTest_B.PosTQLim = CANTest_P.Constant3_Value; /* Constant: '/Constant4' */ CANTest_B.NegTQLim = CANTest_P.Constant4_Value; /* UnitDelay: '/d1' */ CANTest_B.d1 = CANTest_DW.d1_DSTATE; /* Sum: '/Sum3' incorporates: * Constant: '/TQCom' */ CANTest_B.Sum3 = CANTest_P.TQCom_Value + CANTest_B.d1; /* Gain: '/gain' */ CANTest_B.gain = CANTest_P.Ts * CANTest_B.Sum3; /* Gain: '/gain2' incorporates: * Constant: '/Constant1' */ CANTest_B.gain2 = CANTest_P.gain2_Gain * CANTest_P.Constant1_Value_j; /* Product: '/Product2' incorporates: * Constant: '/Constant1' */ CANTest_B.Product2 = CANTest_P.Constant1_Value_a / CANTest_B.gain2; /* Gain: '/gain1' */ CANTest_B.gain1 = CANTest_P.gain1_Gain * CANTest_B.Product2; /* Sum: '/Sum1' incorporates: * Constant: '/Constant' */ CANTest_B.Sum1 = CANTest_B.gain1 - CANTest_P.Ts; /* UnitDelay: '/d' */ CANTest_B.d = CANTest_DW.d_DSTATE; /* Product: '/Product11' */ CANTest_B.Product11 = CANTest_B.Sum1 * CANTest_B.d; /* Sum: '/Sum2' */ CANTest_B.Sum2 = CANTest_B.gain + CANTest_B.Product11; /* Sum: '/Sum4' incorporates: * Constant: '/Constant' */ CANTest_B.Sum4 = CANTest_B.gain1 + CANTest_P.Ts; /* Product: '/Product1' */ CANTest_B.Product1 = CANTest_B.Sum2 / CANTest_B.Sum4; /* S-Function (scanpack): '/CAN Pack' */ /* S-Function (scanpack): '/CAN Pack' */ CANTest_B.CANPack.ID = 592U; CANTest_B.CANPack.Length = 8U; CANTest_B.CANPack.Extended = 0U; CANTest_B.CANPack.Remote = 0; CANTest_B.CANPack.Data[0] = 0; CANTest_B.CANPack.Data[1] = 0; CANTest_B.CANPack.Data[2] = 0; CANTest_B.CANPack.Data[3] = 0; CANTest_B.CANPack.Data[4] = 0; CANTest_B.CANPack.Data[5] = 0; CANTest_B.CANPack.Data[6] = 0; CANTest_B.CANPack.Data[7] = 0; { /* --------------- START Packing signal 0 ------------------ * startBit = 0 * length = 1 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.ContMode; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(1)) { packedValue = (uint8_T) 1; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<0); } } } } } } /* --------------- START Packing signal 1 ------------------ * startBit = 1 * length = 1 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Ready; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(1)) { packedValue = (uint8_T) 1; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<1); } } } } } } /* --------------- START Packing signal 2 ------------------ * startBit = 2 * length = 1 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Ready; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(1)) { packedValue = (uint8_T) 1; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<2); } } } } } } /* --------------- START Packing signal 3 ------------------ * startBit = 3 * length = 1 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Ready; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(1)) { packedValue = (uint8_T) 1; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<3); } } } } } } /* --------------- START Packing signal 4 ------------------ * startBit = 4 * length = 4 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Gear; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(15)) { packedValue = (uint8_T) 15; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<4); } { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 1)) >> 1)<<5); } { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 2)) >> 2)<<6); } { CANTest_B.CANPack.Data[0] = CANTest_B.CANPack.Data[0] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 3)) >> 3)<<7); } } } } } } /* --------------- START Packing signal 5 ------------------ * startBit = 8 * length = 2 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Ready; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(3)) { packedValue = (uint8_T) 3; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<0); } { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 1)) >> 1)<<1); } } } } } } /* --------------- START Packing signal 6 ------------------ * startBit = 10 * length = 3 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.BMS; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(7)) { packedValue = (uint8_T) 7; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<2); } { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 1)) >> 1)<<3); } { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 2)) >> 2)<<4); } } } } } } /* --------------- START Packing signal 7 ------------------ * startBit = 13 * length = 2 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = 0.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Ready; /* no scaling required */ outValue = result; } { { uint8_T packedValue; if (outValue > (real64_T)(3)) { packedValue = (uint8_T) 3; } else if (outValue < (real64_T)(0)) { packedValue = (uint8_T) 0; } else { packedValue = (uint8_T) (outValue); } { { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 0)) >> 0)<<5); } { CANTest_B.CANPack.Data[1] = CANTest_B.CANPack.Data[1] | (uint8_T) ((uint8_T)((uint8_T)(packedValue & (uint8_T)(((uint8_T)(1)) << 1)) >> 1)<<6); } } } } } } /* --------------- START Packing signal 8 ------------------ * startBit = 16 * length = 16 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 0.1 * offset = -200.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.PosTQLim; /* full scaling operation */ result = (result - -200.0) * (1 / 0.1); outValue = result; } { { uint16_T packedValue; if (outValue > (real64_T)(65535)) { packedValue = (uint16_T) 65535; } else if (outValue < (real64_T)(0)) { packedValue = (uint16_T) 0; } else { packedValue = (uint16_T) (outValue); } { { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 0)) >> 0)<<0); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 1)) >> 1)<<1); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 2)) >> 2)<<2); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 3)) >> 3)<<3); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 4)) >> 4)<<4); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 5)) >> 5)<<5); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 6)) >> 6)<<6); } { CANTest_B.CANPack.Data[2] = CANTest_B.CANPack.Data[2] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 7)) >> 7)<<7); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 8)) >> 8)<<0); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 9)) >> 9)<<1); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 10)) >> 10)<<2); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 11)) >> 11)<<3); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 12)) >> 12)<<4); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 13)) >> 13)<<5); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 14)) >> 14)<<6); } { CANTest_B.CANPack.Data[3] = CANTest_B.CANPack.Data[3] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 15)) >> 15)<<7); } } } } } } /* --------------- START Packing signal 9 ------------------ * startBit = 32 * length = 16 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 0.1 * offset = -200.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.NegTQLim; /* full scaling operation */ result = (result - -200.0) * (1 / 0.1); outValue = result; } { { uint16_T packedValue; if (outValue > (real64_T)(65535)) { packedValue = (uint16_T) 65535; } else if (outValue < (real64_T)(0)) { packedValue = (uint16_T) 0; } else { packedValue = (uint16_T) (outValue); } { { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 0)) >> 0)<<0); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 1)) >> 1)<<1); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 2)) >> 2)<<2); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 3)) >> 3)<<3); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 4)) >> 4)<<4); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 5)) >> 5)<<5); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 6)) >> 6)<<6); } { CANTest_B.CANPack.Data[4] = CANTest_B.CANPack.Data[4] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 7)) >> 7)<<7); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 8)) >> 8)<<0); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 9)) >> 9)<<1); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 10)) >> 10)<<2); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 11)) >> 11)<<3); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 12)) >> 12)<<4); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 13)) >> 13)<<5); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 14)) >> 14)<<6); } { CANTest_B.CANPack.Data[5] = CANTest_B.CANPack.Data[5] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 15)) >> 15)<<7); } } } } } } /* --------------- START Packing signal 10 ------------------ * startBit = 48 * length = 16 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 0.1 * offset = -200.0 * minimum = 0.0 * maximum = 0.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { real64_T result = CANTest_B.Product1; /* full scaling operation */ result = (result - -200.0) * (1 / 0.1); outValue = result; } { { uint16_T packedValue; if (outValue > (real64_T)(65535)) { packedValue = (uint16_T) 65535; } else if (outValue < (real64_T)(0)) { packedValue = (uint16_T) 0; } else { packedValue = (uint16_T) (outValue); } { { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 0)) >> 0)<<0); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 1)) >> 1)<<1); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 2)) >> 2)<<2); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 3)) >> 3)<<3); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 4)) >> 4)<<4); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 5)) >> 5)<<5); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 6)) >> 6)<<6); } { CANTest_B.CANPack.Data[6] = CANTest_B.CANPack.Data[6] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 7)) >> 7)<<7); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 8)) >> 8)<<0); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 9)) >> 9)<<1); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 10)) >> 10)<<2); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 11)) >> 11)<<3); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 12)) >> 12)<<4); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 13)) >> 13)<<5); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 14)) >> 14)<<6); } { CANTest_B.CANPack.Data[7] = CANTest_B.CANPack.Data[7] | (uint8_T) ((uint8_T)((uint16_T)(packedValue & (uint16_T)(((uint16_T)(1)) << 15)) >> 15)<<7); } } } } } } } /* S-Function (sg_IO61X_write_s): '/CAN Write1' */ /* Level2 S-Function Block: '/CAN Write1' (sg_IO61X_write_s) */ { SimStruct *rts = CANTest_M->childSfunctions[2]; sfcnOutputs(rts,0); } /* Outputs for Iterator SubSystem: '/DAQ_In' incorporates: * WhileIterator: '/While Iterator' */ s1_iter = 1; do { /* Level2 S-Function Block: '/CAN Setup' (sg_IO613_setup_s) */ { SimStruct *rts = CANTest_M->childSfunctions[0]; sfcnOutputs(rts,0); } /* Level2 S-Function Block: '/CAN Read1' (sg_IO61X_read_s) */ { SimStruct *rts = CANTest_M->childSfunctions[1]; sfcnOutputs(rts,0); } { /* S-Function (scanunpack): '/CAN Unpack2' */ if ((8 == CANTest_B.CANRead1_o2.Length) && (CANTest_B.CANRead1_o2.ID != INVALID_CAN_ID) ) { if ((768U == CANTest_B.CANRead1_o2.ID) && (0U == CANTest_B.CANRead1_o2.Extended) ) { { /* --------------- START Unpacking signal 0 ------------------ * startBit = 32 * length = 16 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 1.0 * offset = -32768.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { { uint16_T unpackedValue = 0; { uint16_T tempValue = (uint16_T) (0); { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 0)) >> 0)<<0); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 1)) >> 1)<<1); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 2)) >> 2)<<2); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 3)) >> 3)<<3); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 4)) >> 4)<<4); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 5)) >> 5)<<5); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 6)) >> 6)<<6); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[4]) & (uint16_T) ( (uint16_T) (1)<< 7)) >> 7)<<7); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 0)) >> 0)<<8); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 1)) >> 1)<<9); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 2)) >> 2)<<10); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 3)) >> 3)<<11); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 4)) >> 4)<<12); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 5)) >> 5)<<13); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 6)) >> 6)<<14); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[5]) & (uint16_T) ( (uint16_T) (1)<< 7)) >> 7)<<15); } unpackedValue = tempValue; } outValue = (real64_T) (unpackedValue); } } { real64_T result = (real64_T) outValue; result = result + -32768.0; CANTest_B.RPM = result; } } } /* --------------- START Unpacking signal 1 ------------------ * startBit = 48 * length = 16 * desiredSignalByteLayout = LITTLEENDIAN * dataType = UNSIGNED * factor = 0.1 * offset = -200.0 * -----------------------------------------------------------------------*/ { { real64_T outValue = 0; { { uint16_T unpackedValue = 0; { uint16_T tempValue = (uint16_T) (0); { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 0)) >> 0)<<0); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 1)) >> 1)<<1); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 2)) >> 2)<<2); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 3)) >> 3)<<3); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 4)) >> 4)<<4); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 5)) >> 5)<<5); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 6)) >> 6)<<6); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[6]) & (uint16_T) ( (uint16_T) (1)<< 7)) >> 7)<<7); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 0)) >> 0)<<8); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 1)) >> 1)<<9); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 2)) >> 2)<<10); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 3)) >> 3)<<11); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 4)) >> 4)<<12); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 5)) >> 5)<<13); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 6)) >> 6)<<14); } { tempValue = tempValue | (uint16_T)((uint16_T)((uint16_T) ((CANTest_B.CANRead1_o2.Data[7]) & (uint16_T) ( (uint16_T) (1)<< 7)) >> 7)<<15); } unpackedValue = tempValue; } outValue = (real64_T) (unpackedValue); } } { real64_T result = (real64_T) outValue; result = (result * 0.1) + -200.0; CANTest_B.TQ = result; } } } } } } } s1_iter++; } while (CANTest_B.CANRead1_o1 && (s1_iter <= 501)); /* End of Outputs for SubSystem: '/DAQ_In' */ } /* Model update function */ static void CANTest_update(void) { /* Update for UnitDelay: '/d1' incorporates: * Constant: '/TQCom' */ CANTest_DW.d1_DSTATE = CANTest_P.TQCom_Value; /* Update for UnitDelay: '/d' */ CANTest_DW.d_DSTATE = CANTest_B.Product1; /* Update absolute time for base rate */ /* The "clockTick0" counts the number of times the code of this task has * been executed. The absolute time is the multiplication of "clockTick0" * and "Timing.stepSize0". Size of "clockTick0" ensures timer will not * overflow during the application lifespan selected. * Timer of this task consists of two 32 bit unsigned integers. * The two integers represent the low bits Timing.clockTick0 and the high bits * Timing.clockTickH0. When the low bit overflows to 0, the high bits increment. */ if (!(++CANTest_M->Timing.clockTick0)) { ++CANTest_M->Timing.clockTickH0; } CANTest_M->Timing.t[0] = CANTest_M->Timing.clockTick0 * CANTest_M->Timing.stepSize0 + CANTest_M->Timing.clockTickH0 * CANTest_M->Timing.stepSize0 * 4294967296.0; } /* Model initialize function */ static void CANTest_initialize(void) { /* Start for Constant: '/Constant' */ CANTest_B.Ready = CANTest_P.Constant_Value; /* Start for Constant: '/Constant1' */ CANTest_B.Gear = CANTest_P.Constant1_Value; /* Start for Constant: '/Constant2' */ CANTest_B.BMS = CANTest_P.Constant2_Value; /* Start for Constant: '/Constant3' */ CANTest_B.PosTQLim = CANTest_P.Constant3_Value; /* Start for Constant: '/Constant4' */ CANTest_B.NegTQLim = CANTest_P.Constant4_Value; /* Start for S-Function (sg_IO61X_write_s): '/CAN Write1' */ /* Level2 S-Function Block: '/CAN Write1' (sg_IO61X_write_s) */ { SimStruct *rts = CANTest_M->childSfunctions[2]; sfcnStart(rts); if (ssGetErrorStatus(rts) != (NULL)) return; } /* Start for Iterator SubSystem: '/DAQ_In' */ /* Start for S-Function (sg_IO613_setup_s): '/CAN Setup' */ /* Level2 S-Function Block: '/CAN Setup' (sg_IO613_setup_s) */ { SimStruct *rts = CANTest_M->childSfunctions[0]; sfcnStart(rts); if (ssGetErrorStatus(rts) != (NULL)) return; } /* Start for S-Function (sg_IO61X_read_s): '/CAN Read1' */ /* Level2 S-Function Block: '/CAN Read1' (sg_IO61X_read_s) */ { SimStruct *rts = CANTest_M->childSfunctions[1]; sfcnStart(rts); if (ssGetErrorStatus(rts) != (NULL)) return; } /* Start for S-Function (scanunpack): '/CAN Unpack2' */ /*-----------S-Function Block: /CAN Unpack2 -----------------*/ /* End of Start for SubSystem: '/DAQ_In' */ /* InitializeConditions for UnitDelay: '/d1' */ CANTest_DW.d1_DSTATE = CANTest_P.d1_InitialCondition; /* InitializeConditions for UnitDelay: '/d' */ CANTest_DW.d_DSTATE = CANTest_P.d_InitialCondition; } /* Model terminate function */ static void CANTest_terminate(void) { /* Terminate for S-Function (sg_IO61X_write_s): '/CAN Write1' */ /* Level2 S-Function Block: '/CAN Write1' (sg_IO61X_write_s) */ { SimStruct *rts = CANTest_M->childSfunctions[2]; sfcnTerminate(rts); } /* Terminate for Iterator SubSystem: '/DAQ_In' */ /* Terminate for S-Function (sg_IO613_setup_s): '/CAN Setup' */ /* Level2 S-Function Block: '/CAN Setup' (sg_IO613_setup_s) */ { SimStruct *rts = CANTest_M->childSfunctions[0]; sfcnTerminate(rts); } /* Terminate for S-Function (sg_IO61X_read_s): '/CAN Read1' */ /* Level2 S-Function Block: '/CAN Read1' (sg_IO61X_read_s) */ { SimStruct *rts = CANTest_M->childSfunctions[1]; sfcnTerminate(rts); } /* End of Terminate for SubSystem: '/DAQ_In' */ } /*========================================================================* * Start of Classic call interface * *========================================================================*/ void MdlOutputs(int_T tid) { CANTest_output(); UNUSED_PARAMETER(tid); } void MdlUpdate(int_T tid) { CANTest_update(); UNUSED_PARAMETER(tid); } void MdlInitializeSizes(void) { } void MdlInitializeSampleTimes(void) { } void MdlInitialize(void) { } void MdlStart(void) { CANTest_initialize(); } void MdlTerminate(void) { CANTest_terminate(); } /* Registration function */ RT_MODEL_CANTest_T *CANTest(void) { /* Registration code */ /* initialize non-finites */ rt_InitInfAndNaN(sizeof(real_T)); /* initialize real-time model */ (void) memset((void *)CANTest_M, 0, sizeof(RT_MODEL_CANTest_T)); rtsiSetSolverName(&CANTest_M->solverInfo,"FixedStepDiscrete"); CANTest_M->solverInfoPtr = (&CANTest_M->solverInfo); /* Initialize timing info */ { int_T *mdlTsMap = CANTest_M->Timing.sampleTimeTaskIDArray; mdlTsMap[0] = 0; CANTest_M->Timing.sampleTimeTaskIDPtr = (&mdlTsMap[0]); CANTest_M->Timing.sampleTimes = (&CANTest_M->Timing.sampleTimesArray[0]); CANTest_M->Timing.offsetTimes = (&CANTest_M->Timing.offsetTimesArray[0]); /* task periods */ CANTest_M->Timing.sampleTimes[0] = (0.002); /* task offsets */ CANTest_M->Timing.offsetTimes[0] = (0.0); } rtmSetTPtr(CANTest_M, &CANTest_M->Timing.tArray[0]); { int_T *mdlSampleHits = CANTest_M->Timing.sampleHitArray; mdlSampleHits[0] = 1; CANTest_M->Timing.sampleHits = (&mdlSampleHits[0]); } rtmSetTFinal(CANTest_M, -1); CANTest_M->Timing.stepSize0 = 0.002; /* Setup for data logging */ { static RTWLogInfo rt_DataLoggingInfo; rt_DataLoggingInfo.loggingInterval = NULL; CANTest_M->rtwLogInfo = &rt_DataLoggingInfo; } /* Setup for data logging */ { /* * Set pointers to the data and signal info each state */ { static int_T rt_LoggedStateWidths[] = { 1, 1 }; static int_T rt_LoggedStateNumDimensions[] = { 1, 1 }; static int_T rt_LoggedStateDimensions[] = { 1, 1 }; static boolean_T rt_LoggedStateIsVarDims[] = { 0, 0 }; static BuiltInDTypeId rt_LoggedStateDataTypeIds[] = { SS_DOUBLE, SS_DOUBLE }; static int_T rt_LoggedStateComplexSignals[] = { 0, 0 }; static RTWPreprocessingFcnPtr rt_LoggingStatePreprocessingFcnPtrs[] = { (NULL), (NULL) }; static const char_T *rt_LoggedStateLabels[] = { "DSTATE", "DSTATE" }; static const char_T *rt_LoggedStateBlockNames[] = { "CANTest/Mon_Cont/LPFM/d1", "CANTest/Mon_Cont/LPFM/d" }; static const char_T *rt_LoggedStateNames[] = { "", "" }; static boolean_T rt_LoggedStateCrossMdlRef[] = { 0, 0 }; static RTWLogDataTypeConvert rt_RTWLogDataTypeConvert[] = { { 0, SS_DOUBLE, SS_DOUBLE, 0, 0, 0, 1.0, 0, 0.0 }, { 0, SS_DOUBLE, SS_DOUBLE, 0, 0, 0, 1.0, 0, 0.0 } }; static RTWLogSignalInfo rt_LoggedStateSignalInfo = { 2, rt_LoggedStateWidths, rt_LoggedStateNumDimensions, rt_LoggedStateDimensions, rt_LoggedStateIsVarDims, (NULL), (NULL), rt_LoggedStateDataTypeIds, rt_LoggedStateComplexSignals, (NULL), rt_LoggingStatePreprocessingFcnPtrs, { rt_LoggedStateLabels }, (NULL), (NULL), (NULL), { rt_LoggedStateBlockNames }, { rt_LoggedStateNames }, rt_LoggedStateCrossMdlRef, rt_RTWLogDataTypeConvert }; static void * rt_LoggedStateSignalPtrs[2]; rtliSetLogXSignalPtrs(CANTest_M->rtwLogInfo, (LogSignalPtrsType) rt_LoggedStateSignalPtrs); rtliSetLogXSignalInfo(CANTest_M->rtwLogInfo, &rt_LoggedStateSignalInfo); rt_LoggedStateSignalPtrs[0] = (void*)&CANTest_DW.d1_DSTATE; rt_LoggedStateSignalPtrs[1] = (void*)&CANTest_DW.d_DSTATE; } rtliSetLogT(CANTest_M->rtwLogInfo, "tout"); rtliSetLogX(CANTest_M->rtwLogInfo, "xout"); rtliSetLogXFinal(CANTest_M->rtwLogInfo, ""); rtliSetLogVarNameModifier(CANTest_M->rtwLogInfo, "rt_"); rtliSetLogFormat(CANTest_M->rtwLogInfo, 2); rtliSetLogMaxRows(CANTest_M->rtwLogInfo, 0); rtliSetLogDecimation(CANTest_M->rtwLogInfo, 1); rtliSetLogY(CANTest_M->rtwLogInfo, ""); rtliSetLogYSignalInfo(CANTest_M->rtwLogInfo, (NULL)); rtliSetLogYSignalPtrs(CANTest_M->rtwLogInfo, (NULL)); } CANTest_M->solverInfoPtr = (&CANTest_M->solverInfo); CANTest_M->Timing.stepSize = (0.002); rtsiSetFixedStepSize(&CANTest_M->solverInfo, 0.002); rtsiSetSolverMode(&CANTest_M->solverInfo, SOLVER_MODE_SINGLETASKING); /* block I/O */ CANTest_M->blockIO = ((void *) &CANTest_B); (void) memset(((void *) &CANTest_B), 0, sizeof(B_CANTest_T)); { CANTest_B.CANPack = CAN_DATATYPE_GROUND; CANTest_B.CANRead1_o2 = CAN_DATATYPE_GROUND; CANTest_B.ContMode = 0.0; CANTest_B.Ready = 0.0; CANTest_B.Gear = 0.0; CANTest_B.BMS = 0.0; CANTest_B.PosTQLim = 0.0; CANTest_B.NegTQLim = 0.0; CANTest_B.d1 = 0.0; CANTest_B.Sum3 = 0.0; CANTest_B.gain = 0.0; CANTest_B.gain2 = 0.0; CANTest_B.Product2 = 0.0; CANTest_B.gain1 = 0.0; CANTest_B.Sum1 = 0.0; CANTest_B.d = 0.0; CANTest_B.Product11 = 0.0; CANTest_B.Sum2 = 0.0; CANTest_B.Sum4 = 0.0; CANTest_B.Product1 = 0.0; CANTest_B.RPM = 0.0; CANTest_B.TQ = 0.0; } /* parameters */ CANTest_M->defaultParam = ((real_T *)&CANTest_P); /* states (dwork) */ CANTest_M->dwork = ((void *) &CANTest_DW); (void) memset((void *)&CANTest_DW, 0, sizeof(DW_CANTest_T)); CANTest_DW.d1_DSTATE = 0.0; CANTest_DW.d_DSTATE = 0.0; /* Initialize DataMapInfo substructure containing ModelMap for C API */ CANTest_InitializeDataMapInfo(); /* child S-Function registration */ { RTWSfcnInfo *sfcnInfo = &CANTest_M->NonInlinedSFcns.sfcnInfo; CANTest_M->sfcnInfo = (sfcnInfo); rtssSetErrorStatusPtr(sfcnInfo, (&rtmGetErrorStatus(CANTest_M))); rtssSetNumRootSampTimesPtr(sfcnInfo, &CANTest_M->Sizes.numSampTimes); CANTest_M->NonInlinedSFcns.taskTimePtrs[0] = &(rtmGetTPtr(CANTest_M)[0]); rtssSetTPtrPtr(sfcnInfo,CANTest_M->NonInlinedSFcns.taskTimePtrs); rtssSetTStartPtr(sfcnInfo, &rtmGetTStart(CANTest_M)); rtssSetTFinalPtr(sfcnInfo, &rtmGetTFinal(CANTest_M)); rtssSetTimeOfLastOutputPtr(sfcnInfo, &rtmGetTimeOfLastOutput(CANTest_M)); rtssSetStepSizePtr(sfcnInfo, &CANTest_M->Timing.stepSize); rtssSetStopRequestedPtr(sfcnInfo, &rtmGetStopRequested(CANTest_M)); rtssSetDerivCacheNeedsResetPtr(sfcnInfo, &CANTest_M->derivCacheNeedsReset); rtssSetZCCacheNeedsResetPtr(sfcnInfo, &CANTest_M->zCCacheNeedsReset); rtssSetContTimeOutputInconsistentWithStateAtMajorStepPtr(sfcnInfo, &CANTest_M->CTOutputIncnstWithState); rtssSetSampleHitsPtr(sfcnInfo, &CANTest_M->Timing.sampleHits); rtssSetPerTaskSampleHitsPtr(sfcnInfo, &CANTest_M->Timing.perTaskSampleHits); rtssSetSimModePtr(sfcnInfo, &CANTest_M->simMode); rtssSetSolverInfoPtr(sfcnInfo, &CANTest_M->solverInfoPtr); } CANTest_M->Sizes.numSFcns = (3); /* register each child */ { (void) memset((void *)&CANTest_M->NonInlinedSFcns.childSFunctions[0], 0, 3*sizeof(SimStruct)); CANTest_M->childSfunctions = (&CANTest_M-> NonInlinedSFcns.childSFunctionPtrs[0]); CANTest_M->childSfunctions[0] = (&CANTest_M-> NonInlinedSFcns.childSFunctions[0]); CANTest_M->childSfunctions[1] = (&CANTest_M-> NonInlinedSFcns.childSFunctions[1]); CANTest_M->childSfunctions[2] = (&CANTest_M-> NonInlinedSFcns.childSFunctions[2]); /* Level2 S-Function Block: CANTest//CAN Setup (sg_IO613_setup_s) */ { SimStruct *rts = CANTest_M->childSfunctions[0]; /* timing info */ time_T *sfcnPeriod = CANTest_M->NonInlinedSFcns.Sfcn0.sfcnPeriod; time_T *sfcnOffset = CANTest_M->NonInlinedSFcns.Sfcn0.sfcnOffset; int_T *sfcnTsMap = CANTest_M->NonInlinedSFcns.Sfcn0.sfcnTsMap; (void) memset((void*)sfcnPeriod, 0, sizeof(time_T)*1); (void) memset((void*)sfcnOffset, 0, sizeof(time_T)*1); ssSetSampleTimePtr(rts, &sfcnPeriod[0]); ssSetOffsetTimePtr(rts, &sfcnOffset[0]); ssSetSampleTimeTaskIDPtr(rts, sfcnTsMap); { ssSetBlkInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.blkInfo2[0]); } _ssSetBlkInfo2PortInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.inputOutputPortInfo2[0]); /* Set up the mdlInfo pointer */ ssSetRTWSfcnInfo(rts, CANTest_M->sfcnInfo); /* Allocate memory of model methods 2 */ { ssSetModelMethods2(rts, &CANTest_M->NonInlinedSFcns.methods2[0]); } /* Allocate memory of model methods 3 */ { ssSetModelMethods3(rts, &CANTest_M->NonInlinedSFcns.methods3[0]); } /* Allocate memory of model methods 4 */ { ssSetModelMethods4(rts, &CANTest_M->NonInlinedSFcns.methods4[0]); } /* Allocate memory for states auxilliary information */ { ssSetStatesInfo2(rts, &CANTest_M->NonInlinedSFcns.statesInfo2[0]); ssSetPeriodicStatesInfo(rts, &CANTest_M->NonInlinedSFcns.periodicStatesInfo[0]); } /* path info */ ssSetModelName(rts, "CAN Setup"); ssSetPath(rts, "CANTest/DAQ_In/CAN Setup"); ssSetRTModel(rts,CANTest_M); ssSetParentSS(rts, (NULL)); ssSetRootSS(rts, rts); ssSetVersion(rts, SIMSTRUCT_VERSION_LEVEL2); /* parameters */ { mxArray **sfcnParams = (mxArray **) &CANTest_M->NonInlinedSFcns.Sfcn0.params; ssSetSFcnParamsCount(rts, 24); ssSetSFcnParamsPtr(rts, &sfcnParams[0]); ssSetSFcnParam(rts, 0, (mxArray*)CANTest_P.CANSetup_P1_Size); ssSetSFcnParam(rts, 1, (mxArray*)CANTest_P.CANSetup_P2_Size); ssSetSFcnParam(rts, 2, (mxArray*)CANTest_P.CANSetup_P3_Size); ssSetSFcnParam(rts, 3, (mxArray*)CANTest_P.CANSetup_P4_Size); ssSetSFcnParam(rts, 4, (mxArray*)CANTest_P.CANSetup_P5_Size); ssSetSFcnParam(rts, 5, (mxArray*)CANTest_P.CANSetup_P6_Size); ssSetSFcnParam(rts, 6, (mxArray*)CANTest_P.CANSetup_P7_Size); ssSetSFcnParam(rts, 7, (mxArray*)CANTest_P.CANSetup_P8_Size); ssSetSFcnParam(rts, 8, (mxArray*)CANTest_P.CANSetup_P9_Size); ssSetSFcnParam(rts, 9, (mxArray*)CANTest_P.CANSetup_P10_Size); ssSetSFcnParam(rts, 10, (mxArray*)CANTest_P.CANSetup_P11_Size); ssSetSFcnParam(rts, 11, (mxArray*)CANTest_P.CANSetup_P12_Size); ssSetSFcnParam(rts, 12, (mxArray*)CANTest_P.CANSetup_P13_Size); ssSetSFcnParam(rts, 13, (mxArray*)CANTest_P.CANSetup_P14_Size); ssSetSFcnParam(rts, 14, (mxArray*)CANTest_P.CANSetup_P15_Size); ssSetSFcnParam(rts, 15, (mxArray*)CANTest_P.CANSetup_P16_Size); ssSetSFcnParam(rts, 16, (mxArray*)CANTest_P.CANSetup_P17_Size); ssSetSFcnParam(rts, 17, (mxArray*)CANTest_P.CANSetup_P18_Size); ssSetSFcnParam(rts, 18, (mxArray*)CANTest_P.CANSetup_P19_Size); ssSetSFcnParam(rts, 19, (mxArray*)CANTest_P.CANSetup_P20_Size); ssSetSFcnParam(rts, 20, (mxArray*)CANTest_P.CANSetup_P21_Size); ssSetSFcnParam(rts, 21, (mxArray*)CANTest_P.CANSetup_P22_Size); ssSetSFcnParam(rts, 22, (mxArray*)CANTest_P.CANSetup_P23_Size); ssSetSFcnParam(rts, 23, (mxArray*)CANTest_P.CANSetup_P24_Size); } /* work vectors */ ssSetIWork(rts, (int_T *) &CANTest_DW.CANSetup_IWORK); { struct _ssDWorkRecord *dWorkRecord = (struct _ssDWorkRecord *) &CANTest_M->NonInlinedSFcns.Sfcn0.dWork; struct _ssDWorkAuxRecord *dWorkAuxRecord = (struct _ssDWorkAuxRecord *) &CANTest_M->NonInlinedSFcns.Sfcn0.dWorkAux; ssSetSFcnDWork(rts, dWorkRecord); ssSetSFcnDWorkAux(rts, dWorkAuxRecord); _ssSetNumDWork(rts, 1); /* IWORK */ ssSetDWorkWidth(rts, 0, 1); ssSetDWorkDataType(rts, 0,SS_INTEGER); ssSetDWorkComplexSignal(rts, 0, 0); ssSetDWork(rts, 0, &CANTest_DW.CANSetup_IWORK); } /* registration */ sg_IO613_setup_s(rts); sfcnInitializeSizes(rts); sfcnInitializeSampleTimes(rts); /* adjust sample time */ ssSetSampleTime(rts, 0, 0.002); ssSetOffsetTime(rts, 0, 0.0); sfcnTsMap[0] = 0; /* set compiled values of dynamic vector attributes */ ssSetNumNonsampledZCs(rts, 0); /* Update connectivity flags for each port */ /* Update the BufferDstPort flags for each input port */ } /* Level2 S-Function Block: CANTest//CAN Read1 (sg_IO61X_read_s) */ { SimStruct *rts = CANTest_M->childSfunctions[1]; /* timing info */ time_T *sfcnPeriod = CANTest_M->NonInlinedSFcns.Sfcn1.sfcnPeriod; time_T *sfcnOffset = CANTest_M->NonInlinedSFcns.Sfcn1.sfcnOffset; int_T *sfcnTsMap = CANTest_M->NonInlinedSFcns.Sfcn1.sfcnTsMap; (void) memset((void*)sfcnPeriod, 0, sizeof(time_T)*1); (void) memset((void*)sfcnOffset, 0, sizeof(time_T)*1); ssSetSampleTimePtr(rts, &sfcnPeriod[0]); ssSetOffsetTimePtr(rts, &sfcnOffset[0]); ssSetSampleTimeTaskIDPtr(rts, sfcnTsMap); { ssSetBlkInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.blkInfo2[1]); } _ssSetBlkInfo2PortInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.inputOutputPortInfo2[1]); /* Set up the mdlInfo pointer */ ssSetRTWSfcnInfo(rts, CANTest_M->sfcnInfo); /* Allocate memory of model methods 2 */ { ssSetModelMethods2(rts, &CANTest_M->NonInlinedSFcns.methods2[1]); } /* Allocate memory of model methods 3 */ { ssSetModelMethods3(rts, &CANTest_M->NonInlinedSFcns.methods3[1]); } /* Allocate memory of model methods 4 */ { ssSetModelMethods4(rts, &CANTest_M->NonInlinedSFcns.methods4[1]); } /* Allocate memory for states auxilliary information */ { ssSetStatesInfo2(rts, &CANTest_M->NonInlinedSFcns.statesInfo2[1]); ssSetPeriodicStatesInfo(rts, &CANTest_M->NonInlinedSFcns.periodicStatesInfo[1]); } /* outputs */ { ssSetPortInfoForOutputs(rts, &CANTest_M->NonInlinedSFcns.Sfcn1.outputPortInfo[0]); _ssSetNumOutputPorts(rts, 2); _ssSetPortInfo2ForOutputUnits(rts, &CANTest_M->NonInlinedSFcns.Sfcn1.outputPortUnits[0]); ssSetOutputPortUnit(rts, 0, 0); ssSetOutputPortUnit(rts, 1, 0); _ssSetPortInfo2ForOutputCoSimAttribute(rts, &CANTest_M->NonInlinedSFcns.Sfcn1.outputPortCoSimAttribute[0]); ssSetOutputPortIsContinuousQuantity(rts, 0, 0); ssSetOutputPortIsContinuousQuantity(rts, 1, 0); /* port 0 */ { _ssSetOutputPortNumDimensions(rts, 0, 1); ssSetOutputPortWidth(rts, 0, 1); ssSetOutputPortSignal(rts, 0, ((boolean_T *) &CANTest_B.CANRead1_o1)); } /* port 1 */ { _ssSetOutputPortNumDimensions(rts, 1, 1); ssSetOutputPortWidth(rts, 1, 1); ssSetOutputPortSignal(rts, 1, ((CAN_DATATYPE *) &CANTest_B.CANRead1_o2)); } } /* path info */ ssSetModelName(rts, "CAN Read1"); ssSetPath(rts, "CANTest/DAQ_In/CAN Read1"); ssSetRTModel(rts,CANTest_M); ssSetParentSS(rts, (NULL)); ssSetRootSS(rts, rts); ssSetVersion(rts, SIMSTRUCT_VERSION_LEVEL2); /* parameters */ { mxArray **sfcnParams = (mxArray **) &CANTest_M->NonInlinedSFcns.Sfcn1.params; ssSetSFcnParamsCount(rts, 6); ssSetSFcnParamsPtr(rts, &sfcnParams[0]); ssSetSFcnParam(rts, 0, (mxArray*)CANTest_P.CANRead1_P1_Size); ssSetSFcnParam(rts, 1, (mxArray*)CANTest_P.CANRead1_P2_Size); ssSetSFcnParam(rts, 2, (mxArray*)CANTest_P.CANRead1_P3_Size); ssSetSFcnParam(rts, 3, (mxArray*)CANTest_P.CANRead1_P4_Size); ssSetSFcnParam(rts, 4, (mxArray*)CANTest_P.CANRead1_P5_Size); ssSetSFcnParam(rts, 5, (mxArray*)CANTest_P.CANRead1_P6_Size); } /* work vectors */ ssSetIWork(rts, (int_T *) &CANTest_DW.CANRead1_IWORK); { struct _ssDWorkRecord *dWorkRecord = (struct _ssDWorkRecord *) &CANTest_M->NonInlinedSFcns.Sfcn1.dWork; struct _ssDWorkAuxRecord *dWorkAuxRecord = (struct _ssDWorkAuxRecord *) &CANTest_M->NonInlinedSFcns.Sfcn1.dWorkAux; ssSetSFcnDWork(rts, dWorkRecord); ssSetSFcnDWorkAux(rts, dWorkAuxRecord); _ssSetNumDWork(rts, 1); /* IWORK */ ssSetDWorkWidth(rts, 0, 1); ssSetDWorkDataType(rts, 0,SS_INTEGER); ssSetDWorkComplexSignal(rts, 0, 0); ssSetDWork(rts, 0, &CANTest_DW.CANRead1_IWORK); } /* registration */ sg_IO61X_read_s(rts); sfcnInitializeSizes(rts); sfcnInitializeSampleTimes(rts); /* adjust sample time */ ssSetSampleTime(rts, 0, 0.002); ssSetOffsetTime(rts, 0, 0.0); sfcnTsMap[0] = 0; /* set compiled values of dynamic vector attributes */ ssSetNumNonsampledZCs(rts, 0); /* Update connectivity flags for each port */ _ssSetOutputPortConnected(rts, 0, 1); _ssSetOutputPortConnected(rts, 1, 1); _ssSetOutputPortBeingMerged(rts, 0, 0); _ssSetOutputPortBeingMerged(rts, 1, 0); /* Update the BufferDstPort flags for each input port */ } /* Level2 S-Function Block: CANTest//CAN Write1 (sg_IO61X_write_s) */ { SimStruct *rts = CANTest_M->childSfunctions[2]; /* timing info */ time_T *sfcnPeriod = CANTest_M->NonInlinedSFcns.Sfcn2.sfcnPeriod; time_T *sfcnOffset = CANTest_M->NonInlinedSFcns.Sfcn2.sfcnOffset; int_T *sfcnTsMap = CANTest_M->NonInlinedSFcns.Sfcn2.sfcnTsMap; (void) memset((void*)sfcnPeriod, 0, sizeof(time_T)*1); (void) memset((void*)sfcnOffset, 0, sizeof(time_T)*1); ssSetSampleTimePtr(rts, &sfcnPeriod[0]); ssSetOffsetTimePtr(rts, &sfcnOffset[0]); ssSetSampleTimeTaskIDPtr(rts, sfcnTsMap); { ssSetBlkInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.blkInfo2[2]); } _ssSetBlkInfo2PortInfo2Ptr(rts, &CANTest_M->NonInlinedSFcns.inputOutputPortInfo2[2]); /* Set up the mdlInfo pointer */ ssSetRTWSfcnInfo(rts, CANTest_M->sfcnInfo); /* Allocate memory of model methods 2 */ { ssSetModelMethods2(rts, &CANTest_M->NonInlinedSFcns.methods2[2]); } /* Allocate memory of model methods 3 */ { ssSetModelMethods3(rts, &CANTest_M->NonInlinedSFcns.methods3[2]); } /* Allocate memory of model methods 4 */ { ssSetModelMethods4(rts, &CANTest_M->NonInlinedSFcns.methods4[2]); } /* Allocate memory for states auxilliary information */ { ssSetStatesInfo2(rts, &CANTest_M->NonInlinedSFcns.statesInfo2[2]); ssSetPeriodicStatesInfo(rts, &CANTest_M->NonInlinedSFcns.periodicStatesInfo[2]); } /* inputs */ { _ssSetNumInputPorts(rts, 1); ssSetPortInfoForInputs(rts, &CANTest_M->NonInlinedSFcns.Sfcn2.inputPortInfo[0]); _ssSetPortInfo2ForInputUnits(rts, &CANTest_M->NonInlinedSFcns.Sfcn2.inputPortUnits[0]); ssSetInputPortUnit(rts, 0, 0); _ssSetPortInfo2ForInputCoSimAttribute(rts, &CANTest_M->NonInlinedSFcns.Sfcn2.inputPortCoSimAttribute[0]); ssSetInputPortIsContinuousQuantity(rts, 0, 0); /* port 0 */ { ssSetInputPortRequiredContiguous(rts, 0, 1); ssSetInputPortSignal(rts, 0, &CANTest_B.CANPack); _ssSetInputPortNumDimensions(rts, 0, 1); ssSetInputPortWidth(rts, 0, 1); } } /* path info */ ssSetModelName(rts, "CAN Write1"); ssSetPath(rts, "CANTest/DAQ_Out/CANBoard/CAN Write1"); ssSetRTModel(rts,CANTest_M); ssSetParentSS(rts, (NULL)); ssSetRootSS(rts, rts); ssSetVersion(rts, SIMSTRUCT_VERSION_LEVEL2); /* parameters */ { mxArray **sfcnParams = (mxArray **) &CANTest_M->NonInlinedSFcns.Sfcn2.params; ssSetSFcnParamsCount(rts, 7); ssSetSFcnParamsPtr(rts, &sfcnParams[0]); ssSetSFcnParam(rts, 0, (mxArray*)CANTest_P.CANWrite1_P1_Size); ssSetSFcnParam(rts, 1, (mxArray*)CANTest_P.CANWrite1_P2_Size); ssSetSFcnParam(rts, 2, (mxArray*)CANTest_P.CANWrite1_P3_Size); ssSetSFcnParam(rts, 3, (mxArray*)CANTest_P.CANWrite1_P4_Size); ssSetSFcnParam(rts, 4, (mxArray*)CANTest_P.CANWrite1_P5_Size); ssSetSFcnParam(rts, 5, (mxArray*)CANTest_P.CANWrite1_P6_Size); ssSetSFcnParam(rts, 6, (mxArray*)CANTest_P.CANWrite1_P7_Size); } /* work vectors */ ssSetIWork(rts, (int_T *) &CANTest_DW.CANWrite1_IWORK); ssSetPWork(rts, (void **) &CANTest_DW.CANWrite1_PWORK); { struct _ssDWorkRecord *dWorkRecord = (struct _ssDWorkRecord *) &CANTest_M->NonInlinedSFcns.Sfcn2.dWork; struct _ssDWorkAuxRecord *dWorkAuxRecord = (struct _ssDWorkAuxRecord *) &CANTest_M->NonInlinedSFcns.Sfcn2.dWorkAux; ssSetSFcnDWork(rts, dWorkRecord); ssSetSFcnDWorkAux(rts, dWorkAuxRecord); _ssSetNumDWork(rts, 2); /* IWORK */ ssSetDWorkWidth(rts, 0, 1); ssSetDWorkDataType(rts, 0,SS_INTEGER); ssSetDWorkComplexSignal(rts, 0, 0); ssSetDWork(rts, 0, &CANTest_DW.CANWrite1_IWORK); /* PWORK */ ssSetDWorkWidth(rts, 1, 1); ssSetDWorkDataType(rts, 1,SS_POINTER); ssSetDWorkComplexSignal(rts, 1, 0); ssSetDWork(rts, 1, &CANTest_DW.CANWrite1_PWORK); } /* registration */ sg_IO61X_write_s(rts); sfcnInitializeSizes(rts); sfcnInitializeSampleTimes(rts); /* adjust sample time */ ssSetSampleTime(rts, 0, 0.002); ssSetOffsetTime(rts, 0, 0.0); sfcnTsMap[0] = 0; /* set compiled values of dynamic vector attributes */ ssSetNumNonsampledZCs(rts, 0); /* Update connectivity flags for each port */ _ssSetInputPortConnected(rts, 0, 1); /* Update the BufferDstPort flags for each input port */ ssSetInputPortBufferDstPort(rts, 0, -1); } } /* Initialize Sizes */ CANTest_M->Sizes.numContStates = (0);/* Number of continuous states */ CANTest_M->Sizes.numY = (0); /* Number of model outputs */ CANTest_M->Sizes.numU = (0); /* Number of model inputs */ CANTest_M->Sizes.sysDirFeedThru = (0);/* The model is not direct feedthrough */ CANTest_M->Sizes.numSampTimes = (1); /* Number of sample times */ CANTest_M->Sizes.numBlocks = (39); /* Number of blocks */ CANTest_M->Sizes.numBlockIO = (23); /* Number of block outputs */ CANTest_M->Sizes.numBlockPrms = (163);/* Sum of parameter "widths" */ return CANTest_M; } /*========================================================================* * End of Classic call interface * *========================================================================*/