Please refer to the following links for updated solutions for PICs and AVRs:
- https://github.com/microchip-pic-avr-solutions/pic-tcpip-lite-encx24j600-solution
- https://github.com/microchip-pic-avr-solutions/avr-tcpip-lite-encx24j600-solution
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.
More details can be found at the following links:
- Microchip Ethernet Controllers
- ENCx24J600
- Ethernet PICtail Plus Daughter Board
- Explorer 8 Development Board
- MPLAB® X IDE v5.40 or later (microchip.com/mplab/mplab-x-ide)
- MPLAB® XC8 v2.20 or later (microchip.com/mplab/compilers)
- TCP/IP Lite Stack v3.0.0
- Ethernet Drivers Library v3.0.0
- TCPIP Demo GUI v2.0
- Wireshark Tool
- Explorer 8 Development Kit (DM160228)
- Fast 100Mbps Ethernet PICtail Plus Daughter Board (AC164132)
- PIC18F87K22
- Open MPLABX IDE.
- From the downloaded projects, open encx24j600-udp-solution.X.
- Open Windows Command Prompt application on your PC. Type “ipconfig” to get the IP address of your PC.
- Sending UDP Packets: In udp_demo.c, under the function DEMO_UDP_Send():
- Receiving UDP Packets: In Source Files\MCC generated files\ udpv4_port_handler_table.c, add the following code:
- Click on Program Device to program the code to the device.
- 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. Check the IP address of the Explorer 8 Development Board which is displayed on the LCD. Note it down. 9. 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 displayed on the LCD(192.168.0.46). Click on ‘Claim’ button.
10. In Wireshark, set the filter field as bootp||udp.port==65531. 11. In Demo GUI, click on LED 1, 2, 3, 4 to light the LEDs D1, D2, D3, D4, respectively and observe the Wireshark capture.
12. In Demo GUI, type data(e.g.: “Microchip PIC18F87K22”) inside Send Data box and press the Send button and observe the Wireshark capture.
13. On the Explorer 8 Board, press the Switch S1 and observe the Wireshark capture.
- Open MPLABX IDE.
- From the downloaded projects, open encx24j600-tcp-client-solution.X.
- Check the IP address of the Explorer 8 Development Board which is displayed on the LCD. Note it down.
- In main.c, add the following code:
- Click on Program Device to program the code to the device.
- 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.
Also you can observe the same on Wireshark with filter as “bootp||tcp.port==65534”. - After the connection is established:
- Push ‘Disconnect’ button, to close the TCP Connection. A client disconnected message will appear on the STATUS text box.
- Open MPLABX IDE.
- From the downloaded projects, open encx24j600-tcp-server-solution.X.
- Click on Program Device to program the code to the device.
- Open the Java application TCPIP_Demo.exe. Go to the TCP Client Demo tab, observe the IP address of your board i.e., on the LCD and assign it 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.
- After the connection is established:
- Push ‘Disconnect’ button, to close the TCP Connection. TCP server closing the connection message will appear on the STATUS text box.