Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: mBuino_ENC28_MQTT Nucleo_Web_ENC28J60 Nucleo_Web_ENC28J60_ADC Serial_over_Ethernet ... more
Library for ENC28J60 Ethernet modules.

Ported to mbed from Norbert Truchsess's UIPEthernet  library for Arduino. Thank you Norbert!
- Full support for persistent (streaming) TCP/IP and UDP connections Client and Server each, ARP, ICMP, DHCP and DNS.
- Works with both Mbed OS 2 and Mbed OS 5.
 
Usage:
- Import the library into your project.
- Add #include "UipEthernet.h"tomain.cpp
- Create one instance of the UipEthernet class initialized with the MAC address you'd like to use and SPI pins of the connected Mbed board.
Example programs:
Import programWebSwitch_ENC28J60
HTTP Server serving a simple webpage which enables to remotely turn a digital output on/off. Compile, download, run and type 'IP_address/secret/' (don't forget the last '/') into your web browser and hit ENTER.
Import programHTTPServer_Echo_ENC28J60
A simple HTTP server echoing received requests. Ethernet connection is over an ENC28J60 board. Usage: Type the server's IP address into you web browser and hit <ENTER>.
Import programTcpServer_ENC28J60
Simple TCP/IP Server using the UIPEthernet library for ENC28J60 Ethernet boards.
Import programTcpClient_ENC28J60
Simple TCP/IP Client using the UIPEthernet library for ENC28J60 Ethernet boards.
Import programUdpServer_ENC28J60
Simple UDP Server using the UIPEthernet library for ENC28J60 Ethernet boards.
Import programUdpClient_ENC28J60
Simple UDP Client using the UIPEthernet library for ENC28J60 Ethernet boards.
Import programMQTT_Hello_ENC28J60
MQTT Client example program. Ethernet connection is via an ENC28J60 module.
Diff: UIPUdp.h
- Revision:
- 8:4acb22344932
- Parent:
- 4:d774541a34da
--- a/UIPUdp.h	Tue Apr 26 18:37:14 2016 +0000
+++ b/UIPUdp.h	Fri Jun 30 19:51:28 2017 +0000
@@ -1,5 +1,5 @@
 /*
- UIPUdp.h - Arduino implementation of a uIP wrapper class.
+ UIPUdp.h - Arduino implementation of a UIP wrapper class.
  Copyright (c) 2013 Norbert Truchsess <norbert.truchsess@t-online.de>
  All rights reserved.
 
@@ -19,19 +19,19 @@
  along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 #ifndef UIPUDP_H
-    #define UIPUDP_H
+#define UIPUDP_H
 
-    #include "ethernet_comp.h"
-    #include <mbed.h>
-    #include <Udp.h>
-    #include "utility/mempool.h"
+#include "ethernet_comp.h"
+#include "mbed.h"
+#include "Udp.h"
+#include "utility/mempool.h"
 extern "C"
 {
-    #include "utility/uip.h"
+#include "utility/uip.h"
 }
-    #define UIP_UDP_MAXDATALEN      1500
-    #define UIP_UDP_PHYH_LEN        UIP_LLH_LEN + UIP_IPUDPH_LEN
-    #define UIP_UDP_MAXPACKETSIZE   UIP_UDP_MAXDATALEN + UIP_UDP_PHYH_LEN
+#define UIP_UDP_MAXDATALEN      1500
+#define UIP_UDP_PHYH_LEN        UIP_LLH_LEN + UIP_IPUDPH_LEN
+#define UIP_UDP_MAXPACKETSIZE   UIP_UDP_MAXDATALEN + UIP_UDP_PHYH_LEN
 
 typedef struct
 {
@@ -91,7 +91,6 @@
 
     // Returns the number of characters read, or 0 if none are available
     int         read(char* buffer, size_t len)  { return read((unsigned char*)buffer, len); }
-    ;
 
     // Return the next byte from the current packet without moving on to the next byte
     int         peek(void);
@@ -105,7 +104,7 @@
 private:
     friend void     uipudp_appcall(void);
 
-    friend class    UIPEthernetClass;
+    friend class    UIPEthernet;
     static void     _send(uip_udp_userdata_t* data);
 };
 #endif
    