Difference between revisions of "Component: LIN Slave (Comms: Interface)"
From Flowcode Help
Jump to navigationJump to search| Line 17: | Line 17: | ||
==Component Source Code==  | ==Component Source Code==  | ||
| − | Please click here to download the component source project: [https://www.flowcode.co.uk/  | + | Please click here to download the component source project: [https://www.flowcode.co.uk/wiki/componentsource/FC_Comp_Source_LinSlaveV2.fcfx FC_Comp_Source_LinSlaveV2.fcfx]  | 
Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_LinSlaveV2.fcfx FC_Comp_Source_LinSlaveV2.fcfx]  | Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_LinSlaveV2.fcfx FC_Comp_Source_LinSlaveV2.fcfx]  | ||
==Detailed description==  | ==Detailed description==  | ||
| + | |||
| + | |||
| Line 34: | Line 36: | ||
==Examples==  | ==Examples==  | ||
| + | |||
| + | |||
| Line 46: | Line 50: | ||
==Macro reference==  | ==Macro reference==  | ||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''PowerDown'''  | ||
| + | |-  | ||
| + | | colspan="2" | Puts the bus into the Powered Down state driving the CS pin low.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-void-icon.png]] - VOID  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''ListenForMessages'''  | ||
| + | |-  | ||
| + | | colspan="2" | Listens for messages with Timeout and returns the state. Returns 255 for timeout, 254 for CRC error and 0 for none matching ID received. Returns 1-8 for a valid ID received.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Timeout  | ||
| + | |-  | ||
| + | | colspan="2" | timeout in milliseconds to wait for incoming message, 255=Wait Forever   | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''ReadDataCount'''  | ||
| + | |-  | ||
| + | | colspan="2" | Return the data count size for Message   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Message  | ||
| + | |-  | ||
| + | | colspan="2" | Range: 1 - Num Messages   | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''ReadData'''  | ||
| + | |-  | ||
| + | | colspan="2" | Get the Message data automatically received from a specific message as part of the ListenForMessages macro.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Message  | ||
| + | |-  | ||
| + | | colspan="2" | Message index to be read. Range: 1 - Num Messages   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Data  | ||
| + | |-  | ||
| + | | colspan="2" |    | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''SetData'''  | ||
| + | |-  | ||
| + | | colspan="2" | Set the Message data to be automatically sent for a specific message as part of the ListenForMessages macro.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Message  | ||
| + | |-  | ||
| + | | colspan="2" | Message index to write. Range: 1 - Num Messages   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" | Data  | ||
| + | |-  | ||
| + | | colspan="2" |    | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u8-icon.png]] - BYTE  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''WakeUp'''  | ||
| + | |-  | ||
| + | | colspan="2" | Puts the bus into the Wake state driving the CS pin high.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-void-icon.png]] - VOID  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''Initialise'''  | ||
| + | |-  | ||
| + | | colspan="2" | Initialises the device ready for communications from the master. Puts the bus into the Wake state driving the CS pin high.   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-void-icon.png]] - VOID  | ||
| + | | width="90%" style="border-top: 2px solid #000;" | ''Return''  | ||
| + | |}  | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | ==Property reference==  | ||
| + | |||
| + | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#D8C9D8;" | [[File:Fc9-prop-icon.png]]  | ||
| + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''Properties'''   | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#EAE1EA;" | [[File:Fc9-conn-icon.png]]  | ||
| + | | width="90%" style="background-color:#EAE1EA; color:#4B008D;" | Bus Options  | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Channel  | ||
| + | |-  | ||
| + | | colspan="2" | UART Channel selector Software channels are bit banged using generic I/O pins but are not as reliable as hardware channels. Hardware channels use the selected peripheral on-board the target microcontroller.   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Baud Options  | ||
| + | |-  | ||
| + | | colspan="2" | Baud rate option selector   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-14-icon.png]]  | ||
| + | | width="90%" | Baud Rate  | ||
| + | |-  | ||
| + | | colspan="2" |    | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Messages  | ||
| + | |-  | ||
| + | | colspan="2" | Number of messages the firmware is designed to listen for   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Checksum Type  | ||
| + | |-  | ||
| + | | colspan="2" |    | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#EAE1EA;" | [[File:Fc9-conn-icon.png]]  | ||
| + | | width="90%" style="background-color:#EAE1EA; color:#4B008D;" | Connections  | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-5-icon.png]]  | ||
| + | | width="90%" | TX  | ||
| + | |-  | ||
| + | | colspan="2" | Pin to be used for Transmit data   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-5-icon.png]]  | ||
| + | | width="90%" | RX  | ||
| + | |-  | ||
| + | | colspan="2" | Pin to be used for Receive data   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-5-icon.png]]  | ||
| + | | width="90%" | CS pin  | ||
| + | |-  | ||
| + | | colspan="2" | LIN bus chip select pin    | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#EAE1EA;" | [[File:Fc9-conn-icon.png]]  | ||
| + | | width="90%" style="background-color:#EAE1EA; color:#4B008D;" | MESSAGE1  | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-14-icon.png]]  | ||
| + | | width="90%" | ID  | ||
| + | |-  | ||
| + | | colspan="2" | Message identifier to listen for   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | BYTES  | ||
| + | |-  | ||
| + | | colspan="2" | Number of bytes to expent in the packet   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | TX_RX  | ||
| + | |-  | ||
| + | | colspan="2" | Data direction for packet   | ||
| + | |-  | ||
| + | | width="10%" align="center" style="background-color:#EAE1EA;" | [[File:Fc9-conn-icon.png]]  | ||
| + | | width="90%" style="background-color:#EAE1EA; color:#4B008D;" | Simulation  | ||
| + | |-  | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-7-icon.png]]  | ||
| + | | width="90%" | Scope Traces  | ||
| + | |-  | ||
| + | | colspan="2" | Selects if the scope traces are automatically added to the data recorder window or not.     Simulation - draws an approximation of the UART data onto the scope trace.     ICT - sets up the scope trace for incoming data and adds UART packet decoding at the correct BAUD.   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-7-icon.png]]  | ||
| + | | width="90%" | Console Data  | ||
| + | |-  | ||
| + | | colspan="2" | Selects if the console data is automatically generated or not   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Console Format  | ||
| + | |-  | ||
| + | | colspan="2" | Controls if the data is shown as a log with time and date stamps or just as raw data   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-21-icon.png]]  | ||
| + | | width="90%" | Console Columns  | ||
| + | |-  | ||
| + | | colspan="2" | Number of characters that can be displayed on a single line of the console.   | ||
| + | |-  | ||
| + | | width="10%" align="center" | [[File:Fc9-type-16-icon.png]]  | ||
| + | | width="90%" | Data Source  | ||
| + | |-  | ||
| + | | colspan="2" | Simulation data source used to allow the component to connect to various remote devices     Nothing - Simulation data is ignored     COM port - Routes the communication data to and from a physical or virtual COM port      API - Routes the communication data via a data injector component on the Panel.   | ||
| + | |}==Macro reference==  | ||
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | {| class="wikitable" style="width:60%; background-color:#FFFFFF;"  | ||
Revision as of 09:58, 27 January 2023
| Author | Matrix Ltd | 
| Version | 1.2 | 
| Category | Comms: Interface | 
Contents
LIN Slave component
Low level routines for controlling the LIN bus (1.3 / 2.0) slave interface.
Component Source Code
Please click here to download the component source project: FC_Comp_Source_LinSlaveV2.fcfx
Please click here to view the component source code (Beta): FC_Comp_Source_LinSlaveV2.fcfx
Detailed description
No detailed description exists yet for this component
Examples
No additional examples
Macro reference
| PowerDown | |
| Puts the bus into the Powered Down state driving the CS pin low. | |
| Return | |
| ReadDataCount | |
| Return the data count size for Message | |
| Message | |
| Range: 1 - Num Messages | |
| Return | |
| WakeUp | |
| Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
| Initialise | |
| Initialises the device ready for communications from the master. Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
Property reference
==Macro reference==
| PowerDown | |
| Puts the bus into the Powered Down state driving the CS pin low. | |
| Return | |
| ReadDataCount | |
| Return the data count size for Message | |
| Message | |
| Range: 1 - Num Messages | |
| Return | |
| WakeUp | |
| Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
| Initialise | |
| Initialises the device ready for communications from the master. Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
Property reference
==Macro reference==
| PowerDown | |
| Puts the bus into the Powered Down state driving the CS pin low. | |
| Return | |
| ReadDataCount | |
| Return the data count size for Message | |
| Message | |
| Range: 1 - Num Messages | |
| Return | |
| WakeUp | |
| Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
| Initialise | |
| Initialises the device ready for communications from the master. Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
Property reference
==Macro reference==
| PowerDown | |
| Puts the bus into the Powered Down state driving the CS pin low. | |
| Return | |
| ReadDataCount | |
| Return the data count size for Message | |
| Message | |
| Range: 1 - Num Messages | |
| Return | |
| WakeUp | |
| Puts the bus into the Wake state driving the CS pin high. | |
| Return | |
| Initialise | |
| Initialises the device ready for communications from the master. Puts the bus into the Wake state driving the CS pin high. | |
| Return | |