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
diff -r 1bc7e6120801 -r 4acb22344932 UIPUdp.h
--- 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
