Marking local functions: Siul2_Port_Ip_GetMSCRConfiguration Siul2_Port_Ip_PinInit Marking externally visible functions: Siul2_Port_Ip_GetPinConfiguration Siul2_Port_Ip_RevertPinConfiguration Siul2_Port_Ip_SetPinDirection Siul2_Port_Ip_SetInputBuffer Siul2_Port_Ip_SetOutputBuffer Siul2_Port_Ip_SetPullSel Siul2_Port_Ip_Init Siul2_Port_Ip_SetGPDO Siul2_Port_Ip_SetIMCR Siul2_Port_Ip_ReadMSCR Siul2_Port_Ip_SetMSCR Marking externally visible variables: Reclaiming functions: Reclaiming variables: Clearing address taken flags: Symbol table: Siul2_Port_Ip_GetPinConfiguration/16 (Siul2_Port_Ip_GetPinConfiguration) @060a22a0 Type: function definition analyzed Visibility: externally_visible public References: pPort_Setting/2 (read)u32MaxPinConfigured/3 (read) Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_GetMSCRConfiguration/5 Siul2_Port_Ip_RevertPinConfiguration/15 (Siul2_Port_Ip_RevertPinConfiguration) @060a2d20 Type: function definition analyzed Visibility: externally_visible public References: pPort_Setting/2 (read)u32MaxPinConfigured/3 (read) Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_PinInit/4 Siul2_Port_Ip_SetPinDirection/14 (Siul2_Port_Ip_SetPinDirection) @060a2a80 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_SetInputBuffer/13 (Siul2_Port_Ip_SetInputBuffer) @060a2620 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_SetOutputBuffer/12 (Siul2_Port_Ip_SetOutputBuffer) @060a21c0 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_SetPullSel/11 (Siul2_Port_Ip_SetPullSel) @05ddaa80 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_Init/10 (Siul2_Port_Ip_Init) @05dda540 Type: function definition analyzed Visibility: externally_visible public References: pPort_Setting/2 (write)u32MaxPinConfigured/3 (write) Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_PinInit/4 Siul2_Port_Ip_SetGPDO/9 (Siul2_Port_Ip_SetGPDO) @05ddaee0 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Siul2_Port_Ip_PinInit/4 Calls: Siul2_Port_Ip_SetIMCR/8 (Siul2_Port_Ip_SetIMCR) @05ddac40 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_ReadMSCR/7 (Siul2_Port_Ip_ReadMSCR) @05dda9a0 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_SetMSCR/6 (Siul2_Port_Ip_SetMSCR) @05dda700 Type: function definition analyzed Visibility: externally_visible public References: Referring: Availability: available Function flags: body optimize_size Called by: Calls: Siul2_Port_Ip_GetMSCRConfiguration/5 (Siul2_Port_Ip_GetMSCRConfiguration) @05dda460 Type: function definition analyzed Visibility: prevailing_def_ironly References: Referring: Availability: local Function flags: body local optimize_size Called by: Siul2_Port_Ip_GetPinConfiguration/16 Calls: Siul2_Port_Ip_PinInit/4 (Siul2_Port_Ip_PinInit) @05dda1c0 Type: function definition analyzed Visibility: prevailing_def_ironly References: Referring: Availability: local Function flags: body local optimize_size Called by: Siul2_Port_Ip_RevertPinConfiguration/15 Siul2_Port_Ip_Init/10 Calls: Siul2_Port_Ip_SetGPDO/9 u32MaxPinConfigured/3 (u32MaxPinConfigured) @05dd3ea0 Type: variable definition analyzed Visibility: prevailing_def_ironly References: Referring: Siul2_Port_Ip_Init/10 (write)Siul2_Port_Ip_RevertPinConfiguration/15 (read)Siul2_Port_Ip_GetPinConfiguration/16 (read) Availability: available Varpool flags: pPort_Setting/2 (pPort_Setting) @05dd3e10 Type: variable definition analyzed Visibility: prevailing_def_ironly References: Referring: Siul2_Port_Ip_Init/10 (write)Siul2_Port_Ip_RevertPinConfiguration/15 (read)Siul2_Port_Ip_GetPinConfiguration/16 (read) Availability: available Varpool flags: Siul2_Port_Ip_GetPinConfiguration (const struct Siul2_Port_Ip_PortType * const base, struct Siul2_Port_Ip_PinSettingsConfig * config, uint16 pin) { uint8 inputMuxIterator; uint16 u16PinIdx; uint32 u32MscrBase; uint32 u32MscrId; uint32 portNumber; uint32 MaxPinConfigured; const struct Siul2_Port_Ip_PinSettingsConfig * ConfigPtr; : # DEBUG BEGIN_STMT ConfigPtr = pPort_Setting; # DEBUG BEGIN_STMT MaxPinConfigured = u32MaxPinConfigured; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT u32MscrBase = 1076429376; # DEBUG BEGIN_STMT base.5_1 = (long unsigned int) base; _2 = base.5_1 - u32MscrBase; portNumber = _2 / 64; # DEBUG BEGIN_STMT _3 = portNumber << 4; _4 = (long unsigned int) pin; u32MscrId = _3 + _4; # DEBUG BEGIN_STMT u16PinIdx = 0; goto ; [INV] : # DEBUG BEGIN_STMT _5 = (unsigned int) u16PinIdx; _6 = _5 * 64; _7 = ConfigPtr + _6; _8 = _7->pinPortIdx; if (u32MscrId == _8) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _9 = (unsigned int) u16PinIdx; _10 = _9 * 64; _11 = ConfigPtr + _10; _12 = _11->base; config->base = _12; # DEBUG BEGIN_STMT _13 = (unsigned int) u16PinIdx; _14 = _13 * 64; _15 = ConfigPtr + _14; _16 = _15->pinPortIdx; config->pinPortIdx = _16; # DEBUG BEGIN_STMT _17 = (unsigned int) u16PinIdx; _18 = _17 * 64; _19 = ConfigPtr + _18; _20 = _19->initValue; config->initValue = _20; # DEBUG BEGIN_STMT inputMuxIterator = 0; goto ; [INV] : # DEBUG BEGIN_STMT _21 = (unsigned int) u16PinIdx; _22 = _21 * 64; _23 = ConfigPtr + _22; _24 = (int) inputMuxIterator; _25 = (int) inputMuxIterator; _26 = _23->inputMuxReg[_24]; config->inputMuxReg[_25] = _26; # DEBUG BEGIN_STMT _27 = (unsigned int) u16PinIdx; _28 = _27 * 64; _29 = ConfigPtr + _28; _30 = (int) inputMuxIterator; _31 = (int) inputMuxIterator; _32 = _29->inputMux[_30]; config->inputMux[_31] = _32; # DEBUG BEGIN_STMT inputMuxIterator.6_33 = inputMuxIterator; inputMuxIterator = inputMuxIterator.6_33 + 1; : # DEBUG BEGIN_STMT if (inputMuxIterator <= 7) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT Siul2_Port_Ip_GetMSCRConfiguration (config, base, pin); # DEBUG BEGIN_STMT goto ; [INV] : # DEBUG BEGIN_STMT u16PinIdx.7_34 = u16PinIdx; u16PinIdx = u16PinIdx.7_34 + 1; : # DEBUG BEGIN_STMT _35 = (long unsigned int) u16PinIdx; if (MaxPinConfigured > _35) goto ; [INV] else goto ; [INV] : return; } Siul2_Port_Ip_RevertPinConfiguration (const struct Siul2_Port_Ip_PortType * const base, uint16 pin) { uint32 u32MscrId; uint32 portNumber; uint32 MaxPinConfigured; const struct Siul2_Port_Ip_PinSettingsConfig * ConfigPtr; uint32 u32RegVal; uint16 u16PinIdx; uint32 D.5032; : # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT u32RegVal = 4294967295; # DEBUG BEGIN_STMT ConfigPtr = pPort_Setting; # DEBUG BEGIN_STMT MaxPinConfigured = u32MaxPinConfigured; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT base.3_1 = (long unsigned int) base; _2 = base.3_1 + 3218537920; portNumber = _2 >> 6; # DEBUG BEGIN_STMT _3 = portNumber << 4; _4 = (long unsigned int) pin; u32MscrId = _3 + _4; # DEBUG BEGIN_STMT u16PinIdx = 0; goto ; [INV] : # DEBUG BEGIN_STMT _5 = (unsigned int) u16PinIdx; _6 = _5 * 64; _7 = ConfigPtr + _6; _8 = _7->pinPortIdx; if (u32MscrId == _8) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _9 = (unsigned int) u16PinIdx; _10 = _9 * 64; _11 = ConfigPtr + _10; Siul2_Port_Ip_PinInit (_11); # DEBUG BEGIN_STMT _12 = (int) pin; u32RegVal = base->MSCR[_12]; # DEBUG BEGIN_STMT goto ; [INV] : # DEBUG BEGIN_STMT u16PinIdx.4_13 = u16PinIdx; u16PinIdx = u16PinIdx.4_13 + 1; : # DEBUG BEGIN_STMT _14 = (long unsigned int) u16PinIdx; if (MaxPinConfigured > _14) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT D.5032 = u32RegVal; return D.5032; } Siul2_Port_Ip_SetPinDirection (struct Siul2_Port_Ip_PortType * const base, uint16 pin, Siul2_Port_Ip_PortDirectionType direction) { : # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT _1 = (int) direction; switch (_1) [INV], case 0: [INV], case 1: [INV], case 2: [INV], case 3: [INV]> : : # DEBUG BEGIN_STMT _2 = (int) pin; _3 = base->MSCR[_2]; _4 = (int) pin; _5 = _3 & 4292870143; base->MSCR[_4] = _5; # DEBUG BEGIN_STMT _6 = (int) pin; _7 = base->MSCR[_6]; _8 = (int) pin; _9 = _7 | 524288; base->MSCR[_8] = _9; # DEBUG BEGIN_STMT goto ; [INV] : : # DEBUG BEGIN_STMT _10 = (int) pin; _11 = base->MSCR[_10]; _12 = (int) pin; _13 = _11 & 4294443007; base->MSCR[_12] = _13; # DEBUG BEGIN_STMT _14 = (int) pin; _15 = base->MSCR[_14]; _16 = (int) pin; _17 = _15 | 2097152; base->MSCR[_16] = _17; # DEBUG BEGIN_STMT goto ; [INV] : : # DEBUG BEGIN_STMT _18 = (int) pin; _19 = base->MSCR[_18]; _20 = (int) pin; _21 = _19 | 2621440; base->MSCR[_20] = _21; # DEBUG BEGIN_STMT goto ; [INV] : : # DEBUG BEGIN_STMT _22 = (int) pin; _23 = base->MSCR[_22]; _24 = (int) pin; _25 = _23 & 4292345855; base->MSCR[_24] = _25; # DEBUG BEGIN_STMT : : return; } Siul2_Port_Ip_SetInputBuffer (struct Siul2_Port_Ip_PortType * const base, uint16 pin, boolean enable, uint32 inputMuxReg, Siul2_Port_Ip_PortInputMux inputMux) { uint32 imcrVal; uint32 imcrRegIdx; struct SIUL2_Type * siul2Base; long unsigned int iftmp.2; : # DEBUG BEGIN_STMT siul2Base = 4294967295B; # DEBUG BEGIN_STMT imcrRegIdx = inputMuxReg; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT if (base != 0B) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _1 = (int) pin; _2 = base->MSCR[_1]; _3 = (int) pin; _4 = _2 & 4294443007; base->MSCR[_3] = _4; # DEBUG BEGIN_STMT _5 = (int) pin; _6 = base->MSCR[_5]; if (enable != 0) goto ; [INV] else goto ; [INV] : iftmp.2 = 524288; goto ; [INV] : iftmp.2 = 0; : _7 = (int) pin; _8 = iftmp.2 | _6; base->MSCR[_7] = _8; : # DEBUG BEGIN_STMT if (inputMux != 16) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT if (imcrRegIdx <= 511) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT siul2Base = 1076428800B; : # DEBUG BEGIN_STMT _9 = imcrRegIdx & 511; imcrVal = siul2Base->IMCR[_9]; # DEBUG BEGIN_STMT imcrVal = imcrVal & 4294967280; # DEBUG BEGIN_STMT _10 = (long unsigned int) inputMux; _11 = _10 & 15; imcrVal = imcrVal | _11; # DEBUG BEGIN_STMT _12 = imcrRegIdx & 511; siul2Base->IMCR[_12] = imcrVal; : return; } Siul2_Port_Ip_SetOutputBuffer (struct Siul2_Port_Ip_PortType * const base, uint16 pin, boolean enable, Siul2_Port_Ip_PortMux mux) { long unsigned int iftmp.1; : # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT _1 = (int) pin; _2 = base->MSCR[_1]; _3 = (int) pin; _4 = _2 & 4292870143; base->MSCR[_3] = _4; # DEBUG BEGIN_STMT _5 = (int) pin; _6 = base->MSCR[_5]; if (enable != 0) goto ; [INV] else goto ; [INV] : iftmp.1 = 2097152; goto ; [INV] : iftmp.1 = 0; : _7 = (int) pin; _8 = iftmp.1 | _6; base->MSCR[_7] = _8; # DEBUG BEGIN_STMT _9 = (int) pin; _10 = base->MSCR[_9]; _11 = (int) pin; _12 = _10 & 4294967288; base->MSCR[_11] = _12; # DEBUG BEGIN_STMT _13 = (int) pin; _14 = base->MSCR[_13]; _15 = (long unsigned int) mux; _16 = _15 & 7; _17 = (int) pin; _18 = _14 | _16; base->MSCR[_17] = _18; return; } Siul2_Port_Ip_SetPullSel (struct Siul2_Port_Ip_PortType * const base, uint16 pin, Siul2_Port_Ip_PortPullConfig pullConfig) { uint32 pusVal; uint32 pueVal; uint32 regVal; : # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT pueVal = 8192; # DEBUG BEGIN_STMT pusVal = 2048; # DEBUG BEGIN_STMT _1 = (int) pullConfig; switch (_1) [INV], case 0: [INV], case 1: [INV], case 2: [INV]> : : # DEBUG BEGIN_STMT _2 = (int) pin; _3 = base->MSCR[_2]; _4 = ~pueVal; _5 = (int) pin; _6 = _3 & _4; base->MSCR[_5] = _6; # DEBUG BEGIN_STMT goto ; [INV] : : # DEBUG BEGIN_STMT _7 = (int) pin; regVal = base->MSCR[_7]; # DEBUG BEGIN_STMT regVal = regVal | pueVal; # DEBUG BEGIN_STMT _8 = ~pusVal; regVal = regVal & _8; # DEBUG BEGIN_STMT _9 = (int) pin; base->MSCR[_9] = regVal; # DEBUG BEGIN_STMT goto ; [INV] : : # DEBUG BEGIN_STMT _10 = (int) pin; regVal = base->MSCR[_10]; # DEBUG BEGIN_STMT regVal = regVal | pueVal; # DEBUG BEGIN_STMT regVal = regVal | pusVal; # DEBUG BEGIN_STMT _11 = (int) pin; base->MSCR[_11] = regVal; # DEBUG BEGIN_STMT : : return; } Siul2_Port_Ip_Init (uint32 pinCount, const struct Siul2_Port_Ip_PinSettingsConfig * config) { uint32 i; Siul2_Port_Ip_PortStatusType D.4998; : # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT pPort_Setting = config; # DEBUG BEGIN_STMT u32MaxPinConfigured = pinCount; # DEBUG BEGIN_STMT i = 0; goto ; [INV] : # DEBUG BEGIN_STMT _1 = i * 64; _2 = config + _1; Siul2_Port_Ip_PinInit (_2); # DEBUG BEGIN_STMT i = i + 1; : # DEBUG BEGIN_STMT if (i < pinCount) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT D.4998 = 0; return D.4998; } Siul2_Port_Ip_SetGPDO (uint8 SiulInstance, uint16 GpdoInstance, uint8 value) { : # DEBUG BEGIN_STMT if (value != 2) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _1 = (int) SiulInstance; _2 = 1076428800; _3 = GpdoInstance ^ 3; _4 = (long unsigned int) _3; _5 = _2 + _4; _6 = _5 + 4864; _7 = (volatile uint8 *) _6; *_7 = value; : return; } Siul2_Port_Ip_SetIMCR (uint8 SiulInstance, uint16 ImcrInstance, uint32 value) { : # DEBUG BEGIN_STMT _1 = (int) SiulInstance; _2 = 1076428800; _3 = (long unsigned int) ImcrInstance; _4 = _3 << 2; _5 = _2 + _4; _6 = _5 + 2624; _7 = (volatile uint32 *) _6; *_7 = value; return; } Siul2_Port_Ip_ReadMSCR (uint8 SiulInstance, uint16 MscrInstance) { uint32 D.4994; : # DEBUG BEGIN_STMT _1 = (int) SiulInstance; _2 = 1076428800; _3 = (long unsigned int) MscrInstance; _4 = _3 << 2; _5 = _2 + _4; _6 = _5 + 576; _7 = (volatile uint32 *) _6; D.4994 = *_7; return D.4994; } Siul2_Port_Ip_SetMSCR (uint8 SiulInstance, uint16 MscrInstance, uint32 value) { : # DEBUG BEGIN_STMT _1 = (int) SiulInstance; _2 = 1076428800; _3 = (long unsigned int) MscrInstance; _4 = _3 << 2; _5 = _2 + _4; _6 = _5 + 576; _7 = (volatile uint32 *) _6; *_7 = value; return; } Siul2_Port_Ip_GetMSCRConfiguration (struct Siul2_Port_Ip_PinSettingsConfig * config, const struct Siul2_Port_Ip_PortType * const base, uint16 pin) { Siul2_Port_Ip_PortPullConfig pullValue; uint32 u32RegVal; : # DEBUG BEGIN_STMT u32RegVal = 4294967295; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT _1 = (int) pin; u32RegVal = base->MSCR[_1]; # DEBUG BEGIN_STMT _2 = (unsigned char) u32RegVal; _3 = _2 & 7; config->mux = _3; # DEBUG BEGIN_STMT _4 = u32RegVal >> 5; _5 = _4 & 1; _6 = () _5; config->safeMode = _6; # DEBUG BEGIN_STMT _7 = u32RegVal & 8192; if (_7 == 0) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT pullValue = 2; goto ; [INV] : # DEBUG BEGIN_STMT _8 = u32RegVal >> 11; _9 = _8 & 1; pullValue = (Siul2_Port_Ip_PortPullConfig) _9; : # DEBUG BEGIN_STMT config->pullConfig = pullValue; # DEBUG BEGIN_STMT _10 = u32RegVal >> 14; _11 = _10 & 1; _12 = () _11; config->slewRateCtrlSel = _12; # DEBUG BEGIN_STMT _13 = u32RegVal >> 8; _14 = _13 & 1; _15 = () _14; config->driveStrength = _15; # DEBUG BEGIN_STMT _16 = u32RegVal >> 6; _17 = _16 & 1; _18 = () _17; config->inputFilter = _18; # DEBUG BEGIN_STMT _19 = u32RegVal >> 17; _20 = _19 & 1; _21 = () _20; config->invert = _21; # DEBUG BEGIN_STMT _22 = u32RegVal >> 16; _23 = _22 & 1; _24 = () _23; config->pullKeep = _24; # DEBUG BEGIN_STMT _25 = u32RegVal >> 19; _26 = _25 & 1; _27 = () _26; config->inputBuffer = _27; # DEBUG BEGIN_STMT _28 = u32RegVal >> 21; _29 = _28 & 1; _30 = () _29; config->outputBuffer = _30; return; } Siul2_Port_Ip_PinInit (const struct Siul2_Port_Ip_PinSettingsConfig * config) { struct SIUL2_Type * imcrBase; uint8 siulInstance; uint32 imcrRegIdx; uint8 inputMuxIterator; uint32 pinsValues; : # DEBUG BEGIN_STMT pinsValues = 0; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT siulInstance = 0; # DEBUG BEGIN_STMT imcrBase = 1076428800B; # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT # DEBUG BEGIN_STMT _1 = config->base; if (_1 == 1076428800B) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT siulInstance = 0; : # DEBUG BEGIN_STMT _2 = config->pullConfig; if (_2 != 2) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT pinsValues = pinsValues | 8192; # DEBUG BEGIN_STMT _3 = config->pullConfig; _4 = (long unsigned int) _3; _5 = _4 << 11; _6 = _5 & 2048; pinsValues = pinsValues | _6; : # DEBUG BEGIN_STMT _7 = config->outputBuffer; _8 = (long unsigned int) _7; _9 = _8 << 21; _10 = _9 & 2097152; pinsValues = pinsValues | _10; # DEBUG BEGIN_STMT _11 = config->invert; _12 = (long unsigned int) _11; _13 = _12 << 17; _14 = _13 & 131072; pinsValues = pinsValues | _14; # DEBUG BEGIN_STMT _15 = config->pullKeep; _16 = (long unsigned int) _15; _17 = _16 << 16; _18 = _17 & 65536; pinsValues = pinsValues | _18; # DEBUG BEGIN_STMT _19 = config->driveStrength; _20 = (long unsigned int) _19; _21 = _20 << 8; _22 = _21 & 256; pinsValues = pinsValues | _22; # DEBUG BEGIN_STMT _23 = config->inputBuffer; _24 = (long unsigned int) _23; _25 = _24 << 19; _26 = _25 & 524288; pinsValues = pinsValues | _26; # DEBUG BEGIN_STMT _27 = config->slewRateCtrlSel; _28 = (long unsigned int) _27; _29 = _28 << 14; _30 = _29 & 16384; pinsValues = pinsValues | _30; # DEBUG BEGIN_STMT _31 = config->safeMode; _32 = (long unsigned int) _31; _33 = _32 << 5; _34 = _33 & 32; pinsValues = pinsValues | _34; # DEBUG BEGIN_STMT _35 = config->mux; _36 = (long unsigned int) _35; _37 = _36 & 7; pinsValues = pinsValues | _37; # DEBUG BEGIN_STMT _38 = config->mux; if (_38 == 0) goto ; [INV] else goto ; [INV] : _39 = config->outputBuffer; if (_39 == 1) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _40 = config->pinPortIdx; _41 = (short unsigned int) _40; _42 = config->initValue; Siul2_Port_Ip_SetGPDO (siulInstance, _41, _42); : # DEBUG BEGIN_STMT _43 = config->base; _44 = config->pinPortIdx; _43->MSCR[_44] = pinsValues; # DEBUG BEGIN_STMT _45 = config->inputBuffer; if (_45 == 1) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT inputMuxIterator = 0; goto ; [INV] : # DEBUG BEGIN_STMT _46 = (int) inputMuxIterator; _47 = config->inputMux[_46]; if (_47 != 16) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT _48 = (int) inputMuxIterator; imcrRegIdx = config->inputMuxReg[_48]; # DEBUG BEGIN_STMT if (imcrRegIdx <= 511) goto ; [INV] else goto ; [INV] : # DEBUG BEGIN_STMT imcrBase = 1076428800B; : # DEBUG BEGIN_STMT _49 = (int) inputMuxIterator; _50 = config->inputMux[_49]; _51 = (long unsigned int) _50; _52 = imcrRegIdx & 511; _53 = _51 & 15; imcrBase->IMCR[_52] = _53; : # DEBUG BEGIN_STMT inputMuxIterator.0_54 = inputMuxIterator; inputMuxIterator = inputMuxIterator.0_54 + 1; : # DEBUG BEGIN_STMT if (inputMuxIterator <= 7) goto ; [INV] else goto ; [INV] : return; }