Skip to content

microchip-pic-avr-solutions/ethxxj60-tcpip-solution

Repository files navigation

MCHP

TCP/IP Lite solutions using ETHxxJ60

This repository provides MPLAB X IDE projects that can work out of the box. The solutions that are included in the repository include functionality for UDP, TCP Server and TCP Client Demos. Note that the TCP/IP Lite stack needs to be serviced every 1 second and the timer callback function needs to be set to 1 second.


Related Documentation

More details can be found at the following links:

Software Used

Hardware Used


UDP Solution

  1. Open MPLABX IDE.
    mplabIcon
  2. From the downloaded projects, open ethxxj60-udp-solution.X.
  3. Open Windows Command Prompt application on your PC. Type “ipconfig” to get the IP address of your PC.
  4. Sending UDP Packets: In udp_demo.c, under the function UDP_DEMO_Send ():
    • Modify the Destination IP address with PC’s IP address as noted in Step 3.
    • Destination Port (anything in the range of dynamic ports)
  5. Receiving UDP Packets: In Source Files\MCC generated files\ udpv4_port_handler_table.c, add the following code:
    • In UDP_CallBackTable, add the following code to perform UDP Receive:
  6. Click on Program Device to program the code to the device.
  7. Launch Wireshark. From the Capture menu, click Options.
    Select an Interface from the list to which your board and PC are connected, click Start for capturing packets.
    e.g.: Local Area Network
  8. In Wireshark, notice the DHCP packets handshake to get the device IP address.
  9. In Wireshark, double click on “Offer” packet. Expand “Dynamic Host Configuration Protocol” to get the device IP address.
  10. Open the Java application TCPIP_Demo.exe. Go to the UDP tab and assign the same port number as ‘DestPort’ (65531). Click on ‘Listen’ button. Click “Allow Access” if warning occurs. Assign the IP Address of your board which is found from step 9(192.168.0.37). Click on ‘Claim’ button.
  11. In Wireshark, set the filter field as bootp||udp.port==65531.
  12. In Demo GUI, type data(e.g.: “PIC8F67J60”)inside Send Data box and press the Send button and observe the Wireshark capture.
  13. On the IoT PoE Main Board, press the Switch S1 and observe the Wireshark capture.

TCP Client Solution

  1. Open MPLABX IDE.
    mplabIcon
  2. From the downloaded projects, open ethxxj60-tcp-client-solution.X.
  3. Click on Program Device to program the code to the device.
  4. Launch Wireshark. From the Capture menu, click Options.
    Select an Interface from the list to which your board and PC are connected, click Start for capturing packets.
    e.g.: Local Area Network
  5. In Wireshark, set the filter field as bootp||tcp.port==65534.
  6. Open the Java application TCPIP_Demo.exe. Go to the TCP Server Demo tab and assign the port number as ‘65534’. Click on ‘Listen’ button. The status of the TCP Connection is printed inside the STATUS text box.

  7. After the connection is established:
    • Type text inside the Send text box and click on ‘Send’ button. The text sent is displayed inside the Sent/Received Data box.

  8. Push ‘Disconnect’ button, to close the TCP Connection. A client disconnected message will appear on the STATUS text box.

TCP Server Solution

  1. Open MPLABX IDE.
    mplabIcon
  2. From the downloaded projects, open ethxxj60-tcp-server-solution.X.
  3. Click on Program Device to program the code to the device.
  4. Launch Wireshark. From the Capture menu, click Options.
    Select an Interface from the list to which your board and PC are connected, click Start for capturing packets.
    e.g.: Local Area Network
  5. In Wireshark, notice the DHCP packets handshake to get the device IP address.
  6. In Wireshark, double click on “Offer” packet. Expand “Dynamic Host Configuration Protocol” to get the device IP address.
  7. Open the Java application TCPIP_Demo.exe. Go to the TCP Client Demo tab, assign the device IP address as Server IP address in the GUI. Assign the port number as ‘7’. Click on ‘Connect’ button. The status of the TCP Connection is printed inside the STATUS text box.
  8. After the connection is established:
    • Type text inside the Send text box and click on ‘Send’ button. The text sent is echoed and displayed inside the Sent/Received Data box.
    • Also in Wireshark, observe the TCP packets by setting the filter “tcp.port == 7”
  9. Push ‘Disconnect’ button, to close the TCP Connection. TCP server closing the connection message will appear on the STATUS text box.