Difference between revisions of "Component: TCP/IP Dummy (ENC28J60) (Comms: Networking)"
| 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_TCPIP_ENC28J60_Dummy.fcfx FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx] | 
| Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx] | Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx] | ||
| ==Detailed description== | ==Detailed description== | ||
| + | |||
| + | |||
| Line 46: | Line 48: | ||
| ==Examples== | ==Examples== | ||
| + | |||
| + | |||
| Line 76: | Line 80: | ||
| ==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;" | '''PacketSend''' | ||
| + | |- | ||
| + | | colspan="2" | Attempts to transmit a data packet to the ENC28J60 module.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Length | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''MakeTcpSynackFromSyn''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Port | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''MakeArpRequest''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:]] -  | ||
| + | | width="90%" | ServerIP | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''InitialiseDataLengthInfo''' | ||
| + | |- | ||
| + | | colspan="2" | Initialises the data pointers to allow us to craft a response containing data  | ||
| + | |- | ||
| + | |- | ||
| + | | 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;" | '''MakeTcpAckFromAny''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Port | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''PacketReceive''' | ||
| + | |- | ||
| + | | colspan="2" | Attempts to receive a data packet from the ENC28J60 module. Returns the number of bytes received.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | 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;" | '''CheckForTCPType''' | ||
| + | |- | ||
| + | | colspan="2" | Checks to what kind of TCP type the received data is requesting. Returns a bit field specifying the type of request. 0x01 = Ack Requires, 0x02 = Synchronise 0x10 = Ack   | ||
| + | |- | ||
| + | |- | ||
| + | | 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;" | '''CheckArpPacketIsMyreplyArp''' | ||
| + | |- | ||
| + | | 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;" | '''CheckForIp''' | ||
| + | |- | ||
| + | | colspan="2" | Checks to see if the received data is an IP request with my IP address.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Length | ||
| + | |- | ||
| + | | 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;" | '''CheckForTCPPort''' | ||
| + | |- | ||
| + | | colspan="2" | Checks to see if the received data is requesting the server port  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Port | ||
| + | |- | ||
| + | | 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;" | '''CheckForPing''' | ||
| + | |- | ||
| + | | colspan="2" | Checks to see if the received data is a Ping request  | ||
| + | |- | ||
| + | |- | ||
| + | | 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;" | '''GetModuleRevision''' | ||
| + | |- | ||
| + | | colspan="2" | Requets the module revision number and returns the value supplied by the module's firmware.  | ||
| + | |- | ||
| + | |- | ||
| + | | 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;" | '''MakeTcpAckWithData''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | DataLength | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''MakeArpAnswerFromRequest''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | 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;" | '''ReadRegister''' | ||
| + | |- | ||
| + | | colspan="2" | Reads the value from a single register onboard the ENC28J60 module.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | Address | ||
| + | |- | ||
| + | | 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;" | '''CheckForARP''' | ||
| + | |- | ||
| + | | colspan="2" | Checks to see if the received data is an ARP request with my IP address.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Length | ||
| + | |- | ||
| + | | 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;" | '''ClientSendPacket''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | DestPort | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | SourcePort | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | Flags | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | MaxSegmentSize | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | ClearSeqAck | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | NextAckNum | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | DataLength | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | DestMac | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | DestIp | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''MakeEchoReplyFromRequest''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Length | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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;" | '''ControlLEDs''' | ||
| + | |- | ||
| + | | colspan="2" | Allows both the LEDs on the Ethernet socket to be controlled. Useful for checking if the SPI communications are functioning correctly.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | Mode | ||
| + | |- | ||
| + | | colspan="2" | 0=Off, 1=On, 2=Auto  | ||
| + | |- | ||
| + | | 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;" | '''GetDataLength''' | ||
| + | |- | ||
| + | | colspan="2" | Returns the number of received data bytes after the headers  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | 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;" | '''GetTcpDataPointer''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | 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;" | '''WriteRegister''' | ||
| + | |- | ||
| + | | colspan="2" | Writes a value to a single register onboard the ENC28J60 module.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | Address | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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-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;" | '''FillTcpData''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Position | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-string-icon.png]] - STRING | ||
| + | | width="90%" | Data | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | 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;" | '''ReadStringFromBuffer''' | ||
| + | |- | ||
| + | | colspan="2" | Reads a string from the buffer at location specified for the number of bytes specified. If a space character is encountered then the macro will return straight away without the space character in the string.  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | BufferLocation | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | NumberOfBytes | ||
| + | |- | ||
| + | | colspan="2" | Number of bytes to read from the buffer and store into string  | ||
| + | |- | ||
| + | | width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-string-icon.png]] - STRING | ||
| + | | 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;" | '''GetSendersMAC''' | ||
| + | |- | ||
| + | | colspan="2" | Gets the MAC address from locations 6-11 of the IP Header  | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| + | | width="90%" | MAC | ||
| + | |- | ||
| + | | colspan="2" | 6-byte Array to store the MAC address  | ||
| + | |- | ||
| + | | 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;" | '''FillTcpArray''' | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Position | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| + | | width="90%" | Count | ||
| + | |- | ||
| + | | colspan="2" |   | ||
| + | |- | ||
| + | | 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-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 SPI connection to the TCPIP module and sets up some initial values. Flashes the LEDs on and off twice to confirm SPI comms are active. LEDs are then configured to auto functionality.  | ||
| + | |- | ||
| + | |- | ||
| + | | 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'''  | ||
| + | |- | ||
| + | |}==Macro reference== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
Revision as of 10:00, 27 January 2023
| Author | Matrix TSL | 
| Version | 2.0 | 
| Category | Comms: Networking | 
Contents
TCP/IP Dummy component
A set of routines used to control a ENC28J60 TCP/IP Module. Required connections VCC, Reset, GND, SCK, MISO, MOSI, CS. Leave these pins disconnected CLKOUT, ENC_WOL, ENC_INT
Component Source Code
Please click here to download the component source project: FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx
Please click here to view the component source code (Beta): FC_Comp_Source_TCPIP_ENC28J60_Dummy.fcfx
Detailed description
No detailed description exists yet for this component
Examples
Here is a simple example to help get started with the ENC28J60 module.
The example program creates a web page server on the network and will also respond to ping requests.
The HTML to drive the web pages is included in the flowchart near the bottom of the main program loop.
 ENC28J60 Example
ENC28J60 Example
Macro reference
|   | PacketSend | 
| Attempts to transmit a data packet to the ENC28J60 module. | |
|  - UINT | Length | 
|  - VOID | Return | 
|   | MakeTcpSynackFromSyn | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | MakeArpRequest | 
| [[File:]] - | ServerIP | 
|  - VOID | Return | 
|   | InitialiseDataLengthInfo | 
| Initialises the data pointers to allow us to craft a response containing data | |
|  - VOID | Return | 
|   | MakeTcpAckFromAny | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | PacketReceive | 
| Attempts to receive a data packet from the ENC28J60 module. Returns the number of bytes received. | |
|  - UINT | Return | 
|   | CheckForTCPType | 
| Checks to what kind of TCP type the received data is requesting. Returns a bit field specifying the type of request. 0x01 = Ack Requires, 0x02 = Synchronise 0x10 = Ack | |
|  - BYTE | Return | 
|   | CheckArpPacketIsMyreplyArp | 
|  - BYTE | Return | 
|   | CheckForIp | 
| Checks to see if the received data is an IP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | CheckForTCPPort | 
| Checks to see if the received data is requesting the server port | |
|  - UINT | Port | 
|  - BYTE | Return | 
|   | CheckForPing | 
| Checks to see if the received data is a Ping request | |
|  - BYTE | Return | 
|   | GetModuleRevision | 
| Requets the module revision number and returns the value supplied by the module's firmware. | |
|  - BYTE | Return | 
|   | MakeTcpAckWithData | 
|  - UINT | DataLength | 
|  - VOID | Return | 
|   | MakeArpAnswerFromRequest | 
|  - VOID | Return | 
|   | ReadRegister | 
| Reads the value from a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Return | 
|   | CheckForARP | 
| Checks to see if the received data is an ARP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | ClientSendPacket | 
|  - UINT | DestPort | 
|  - UINT | SourcePort | 
|  - BYTE | Flags | 
|  - BYTE | MaxSegmentSize | 
|  - BYTE | ClearSeqAck | 
|  - UINT | NextAckNum | 
|  - UINT | DataLength | 
|  - BYTE | DestMac | 
|  - BYTE | DestIp | 
|  - VOID | Return | 
|   | MakeEchoReplyFromRequest | 
|  - UINT | Length | 
|  - VOID | Return | 
|   | ControlLEDs | 
| Allows both the LEDs on the Ethernet socket to be controlled. Useful for checking if the SPI communications are functioning correctly. | |
|  - BYTE | Mode | 
| 0=Off, 1=On, 2=Auto | |
|  - VOID | Return | 
|   | GetDataLength | 
| Returns the number of received data bytes after the headers | |
|  - UINT | Return | 
|   | GetTcpDataPointer | 
|  - UINT | Return | 
|   | WriteRegister | 
| Writes a value to a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Data | 
|  - VOID | Return | 
|   | FillTcpData | 
|  - UINT | Position | 
|  - STRING | Data | 
|  - UINT | Return | 
|   | GetSendersMAC | 
| Gets the MAC address from locations 6-11 of the IP Header | |
|  - BYTE | MAC | 
| 6-byte Array to store the MAC address | |
|  - VOID | Return | 
|   | FillTcpArray | 
|  - UINT | Position | 
|  - UINT | Count | 
|  - BYTE | Data | 
|  - VOID | Return | 
Property reference
|   | Properties | 
==Macro reference==
|   | PacketSend | 
| Attempts to transmit a data packet to the ENC28J60 module. | |
|  - UINT | Length | 
|  - VOID | Return | 
|   | MakeTcpSynackFromSyn | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | MakeArpRequest | 
| [[File:]] - | ServerIP | 
|  - VOID | Return | 
|   | InitialiseDataLengthInfo | 
| Initialises the data pointers to allow us to craft a response containing data | |
|  - VOID | Return | 
|   | MakeTcpAckFromAny | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | PacketReceive | 
| Attempts to receive a data packet from the ENC28J60 module. Returns the number of bytes received. | |
|  - UINT | Return | 
|   | CheckForTCPType | 
| Checks to what kind of TCP type the received data is requesting. Returns a bit field specifying the type of request. 0x01 = Ack Requires, 0x02 = Synchronise 0x10 = Ack | |
|  - BYTE | Return | 
|   | CheckArpPacketIsMyreplyArp | 
|  - BYTE | Return | 
|   | CheckForIp | 
| Checks to see if the received data is an IP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | CheckForTCPPort | 
| Checks to see if the received data is requesting the server port | |
|  - UINT | Port | 
|  - BYTE | Return | 
|   | CheckForPing | 
| Checks to see if the received data is a Ping request | |
|  - BYTE | Return | 
|   | GetModuleRevision | 
| Requets the module revision number and returns the value supplied by the module's firmware. | |
|  - BYTE | Return | 
|   | MakeTcpAckWithData | 
|  - UINT | DataLength | 
|  - VOID | Return | 
|   | MakeArpAnswerFromRequest | 
|  - VOID | Return | 
|   | ReadRegister | 
| Reads the value from a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Return | 
|   | CheckForARP | 
| Checks to see if the received data is an ARP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | ClientSendPacket | 
|  - UINT | DestPort | 
|  - UINT | SourcePort | 
|  - BYTE | Flags | 
|  - BYTE | MaxSegmentSize | 
|  - BYTE | ClearSeqAck | 
|  - UINT | NextAckNum | 
|  - UINT | DataLength | 
|  - BYTE | DestMac | 
|  - BYTE | DestIp | 
|  - VOID | Return | 
|   | MakeEchoReplyFromRequest | 
|  - UINT | Length | 
|  - VOID | Return | 
|   | ControlLEDs | 
| Allows both the LEDs on the Ethernet socket to be controlled. Useful for checking if the SPI communications are functioning correctly. | |
|  - BYTE | Mode | 
| 0=Off, 1=On, 2=Auto | |
|  - VOID | Return | 
|   | GetDataLength | 
| Returns the number of received data bytes after the headers | |
|  - UINT | Return | 
|   | GetTcpDataPointer | 
|  - UINT | Return | 
|   | WriteRegister | 
| Writes a value to a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Data | 
|  - VOID | Return | 
|   | FillTcpData | 
|  - UINT | Position | 
|  - STRING | Data | 
|  - UINT | Return | 
|   | GetSendersMAC | 
| Gets the MAC address from locations 6-11 of the IP Header | |
|  - BYTE | MAC | 
| 6-byte Array to store the MAC address | |
|  - VOID | Return | 
|   | FillTcpArray | 
|  - UINT | Position | 
|  - UINT | Count | 
|  - BYTE | Data | 
|  - VOID | Return | 
Property reference
|   | Properties | 
==Macro reference==
|   | PacketSend | 
| Attempts to transmit a data packet to the ENC28J60 module. | |
|  - UINT | Length | 
|  - VOID | Return | 
|   | MakeTcpSynackFromSyn | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | MakeArpRequest | 
| [[File:]] - | ServerIP | 
|  - VOID | Return | 
|   | InitialiseDataLengthInfo | 
| Initialises the data pointers to allow us to craft a response containing data | |
|  - VOID | Return | 
|   | MakeTcpAckFromAny | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | PacketReceive | 
| Attempts to receive a data packet from the ENC28J60 module. Returns the number of bytes received. | |
|  - UINT | Return | 
|   | CheckForTCPType | 
| Checks to what kind of TCP type the received data is requesting. Returns a bit field specifying the type of request. 0x01 = Ack Requires, 0x02 = Synchronise 0x10 = Ack | |
|  - BYTE | Return | 
|   | CheckArpPacketIsMyreplyArp | 
|  - BYTE | Return | 
|   | CheckForIp | 
| Checks to see if the received data is an IP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | CheckForTCPPort | 
| Checks to see if the received data is requesting the server port | |
|  - UINT | Port | 
|  - BYTE | Return | 
|   | CheckForPing | 
| Checks to see if the received data is a Ping request | |
|  - BYTE | Return | 
|   | GetModuleRevision | 
| Requets the module revision number and returns the value supplied by the module's firmware. | |
|  - BYTE | Return | 
|   | MakeTcpAckWithData | 
|  - UINT | DataLength | 
|  - VOID | Return | 
|   | MakeArpAnswerFromRequest | 
|  - VOID | Return | 
|   | ReadRegister | 
| Reads the value from a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Return | 
|   | CheckForARP | 
| Checks to see if the received data is an ARP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | ClientSendPacket | 
|  - UINT | DestPort | 
|  - UINT | SourcePort | 
|  - BYTE | Flags | 
|  - BYTE | MaxSegmentSize | 
|  - BYTE | ClearSeqAck | 
|  - UINT | NextAckNum | 
|  - UINT | DataLength | 
|  - BYTE | DestMac | 
|  - BYTE | DestIp | 
|  - VOID | Return | 
|   | MakeEchoReplyFromRequest | 
|  - UINT | Length | 
|  - VOID | Return | 
|   | ControlLEDs | 
| Allows both the LEDs on the Ethernet socket to be controlled. Useful for checking if the SPI communications are functioning correctly. | |
|  - BYTE | Mode | 
| 0=Off, 1=On, 2=Auto | |
|  - VOID | Return | 
|   | GetDataLength | 
| Returns the number of received data bytes after the headers | |
|  - UINT | Return | 
|   | GetTcpDataPointer | 
|  - UINT | Return | 
|   | WriteRegister | 
| Writes a value to a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Data | 
|  - VOID | Return | 
|   | FillTcpData | 
|  - UINT | Position | 
|  - STRING | Data | 
|  - UINT | Return | 
|   | GetSendersMAC | 
| Gets the MAC address from locations 6-11 of the IP Header | |
|  - BYTE | MAC | 
| 6-byte Array to store the MAC address | |
|  - VOID | Return | 
|   | FillTcpArray | 
|  - UINT | Position | 
|  - UINT | Count | 
|  - BYTE | Data | 
|  - VOID | Return | 
Property reference
|   | Properties | 
==Macro reference==
|   | PacketSend | 
| Attempts to transmit a data packet to the ENC28J60 module. | |
|  - UINT | Length | 
|  - VOID | Return | 
|   | MakeTcpSynackFromSyn | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | MakeArpRequest | 
| [[File:]] - | ServerIP | 
|  - VOID | Return | 
|   | InitialiseDataLengthInfo | 
| Initialises the data pointers to allow us to craft a response containing data | |
|  - VOID | Return | 
|   | MakeTcpAckFromAny | 
|  - UINT | Port | 
|  - VOID | Return | 
|   | PacketReceive | 
| Attempts to receive a data packet from the ENC28J60 module. Returns the number of bytes received. | |
|  - UINT | Return | 
|   | CheckForTCPType | 
| Checks to what kind of TCP type the received data is requesting. Returns a bit field specifying the type of request. 0x01 = Ack Requires, 0x02 = Synchronise 0x10 = Ack | |
|  - BYTE | Return | 
|   | CheckArpPacketIsMyreplyArp | 
|  - BYTE | Return | 
|   | CheckForIp | 
| Checks to see if the received data is an IP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | CheckForTCPPort | 
| Checks to see if the received data is requesting the server port | |
|  - UINT | Port | 
|  - BYTE | Return | 
|   | CheckForPing | 
| Checks to see if the received data is a Ping request | |
|  - BYTE | Return | 
|   | GetModuleRevision | 
| Requets the module revision number and returns the value supplied by the module's firmware. | |
|  - BYTE | Return | 
|   | MakeTcpAckWithData | 
|  - UINT | DataLength | 
|  - VOID | Return | 
|   | MakeArpAnswerFromRequest | 
|  - VOID | Return | 
|   | ReadRegister | 
| Reads the value from a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Return | 
|   | CheckForARP | 
| Checks to see if the received data is an ARP request with my IP address. | |
|  - UINT | Length | 
|  - BYTE | Return | 
|   | ClientSendPacket | 
|  - UINT | DestPort | 
|  - UINT | SourcePort | 
|  - BYTE | Flags | 
|  - BYTE | MaxSegmentSize | 
|  - BYTE | ClearSeqAck | 
|  - UINT | NextAckNum | 
|  - UINT | DataLength | 
|  - BYTE | DestMac | 
|  - BYTE | DestIp | 
|  - VOID | Return | 
|   | MakeEchoReplyFromRequest | 
|  - UINT | Length | 
|  - VOID | Return | 
|   | ControlLEDs | 
| Allows both the LEDs on the Ethernet socket to be controlled. Useful for checking if the SPI communications are functioning correctly. | |
|  - BYTE | Mode | 
| 0=Off, 1=On, 2=Auto | |
|  - VOID | Return | 
|   | GetDataLength | 
| Returns the number of received data bytes after the headers | |
|  - UINT | Return | 
|   | GetTcpDataPointer | 
|  - UINT | Return | 
|   | WriteRegister | 
| Writes a value to a single register onboard the ENC28J60 module. | |
|  - BYTE | Address | 
|  - BYTE | Data | 
|  - VOID | Return | 
|   | FillTcpData | 
|  - UINT | Position | 
|  - STRING | Data | 
|  - UINT | Return | 
|   | GetSendersMAC | 
| Gets the MAC address from locations 6-11 of the IP Header | |
|  - BYTE | MAC | 
| 6-byte Array to store the MAC address | |
|  - VOID | Return | 
|   | FillTcpArray | 
|  - UINT | Position | 
|  - UINT | Count | 
|  - BYTE | Data | 
|  - VOID | Return | 
Property reference
|   | Properties | 
