-
Notifications
You must be signed in to change notification settings - Fork 13.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
make WiFi/Ethernet interface compatible with Arduino Ethernet API #8645
Merged
Merged
Changes from 3 commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
bd46cc1
make WiFi/Ethernet interface compatible with Arduino Ethernet API
d-a-v 7abe4b6
move ethernet compat globals to EthernetCompat.h
d-a-v 1a358da
LegacyEthernet: add UDP example
d-a-v a3ab8eb
adjust comments
d-a-v d02bd4f
Merge branch 'master' into ArduinoEthernetCompat
mcspr File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
126 changes: 126 additions & 0 deletions
126
libraries/lwIP_Ethernet/examples/LegacyAdvancedChatServer/LegacyAdvancedChatServer.ino
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
/* | ||
Advanced Chat Server | ||
|
||
A more advanced server that distributes any incoming messages | ||
to all connected clients but the client the message comes from. | ||
To use, telnet to your device's IP address and type. | ||
You can see the client's input in the serial monitor as well. | ||
Using an Arduino Wiznet Ethernet shield. | ||
|
||
Circuit: | ||
* Ethernet shield attached to pins 10, 11, 12, 13 | ||
|
||
created 18 Dec 2009 | ||
by David A. Mellis | ||
modified 9 Apr 2012 | ||
by Tom Igoe | ||
redesigned to make use of operator== 25 Nov 2013 | ||
by Norbert Truchsess | ||
|
||
*/ | ||
|
||
// specific to esp8266 w/lwIP | ||
#include <EthernetCompat.h> | ||
ArduinoWiznet5500lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoWiznet5100lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoENC28J60lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
|
||
|
||
|
||
// Enter a MAC address and IP address for your controller below. | ||
// The IP address will be dependent on your local network. | ||
// gateway and subnet are optional: | ||
byte notNeededButAllowed_mac[] = { | ||
0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED | ||
}; | ||
byte* mac = nullptr; // automatic mac | ||
IPAddress ip(192, 168, 1, 177); | ||
IPAddress myDns(192, 168, 1, 1); | ||
IPAddress gateway(192, 168, 1, 1); | ||
IPAddress subnet(255, 255, 0, 0); | ||
|
||
|
||
// telnet defaults to port 23 | ||
EthernetServer server(23); | ||
|
||
EthernetClient clients[8]; | ||
|
||
void setup() { | ||
// You can use Ethernet.init(pin) to configure the CS pin | ||
// Ethernet.init(10); // Most Arduino shields | ||
// Ethernet.init(5); // MKR ETH shield | ||
// Ethernet.init(0); // Teensy 2.0 | ||
// Ethernet.init(20); // Teensy++ 2.0 | ||
// Ethernet.init(15); // ESP8266 with Adafruit Featherwing Ethernet | ||
// Ethernet.init(33); // ESP32 with Adafruit Featherwing Ethernet | ||
// // esp8266 w/lwIP: SS set in Ethernet constructor | ||
|
||
// initialize the Ethernet device | ||
Ethernet.begin(mac, ip, myDns, gateway, subnet); | ||
|
||
// Open serial communications and wait for port to open: | ||
Serial.begin(9600); | ||
while (!Serial) { | ||
; // wait for serial port to connect. Needed for native USB port only | ||
} | ||
|
||
// Check for Ethernet hardware present | ||
if (Ethernet.hardwareStatus() == EthernetNoHardware) { | ||
Serial.println("Ethernet shield was not found. Sorry, can't run without hardware. :("); | ||
while (true) { | ||
delay(1); // do nothing, no point running without Ethernet hardware | ||
} | ||
} | ||
if (Ethernet.linkStatus() == LinkOFF) { | ||
Serial.println("Ethernet cable is not connected."); | ||
} | ||
|
||
// start listening for clients | ||
server.begin(); | ||
|
||
Serial.print("Chat server address:"); | ||
Serial.println(Ethernet.localIP()); | ||
} | ||
|
||
void loop() { | ||
// check for any new client connecting, and say hello (before any incoming data) | ||
EthernetClient newClient = server.accept(); | ||
if (newClient) { | ||
for (byte i = 0; i < 8; i++) { | ||
if (!clients[i]) { | ||
Serial.print("We have a new client #"); | ||
Serial.println(i); | ||
newClient.print("Hello, client number: "); | ||
newClient.println(i); | ||
// Once we "accept", the client is no longer tracked by EthernetServer | ||
// so we must store it into our list of clients | ||
clients[i] = newClient; | ||
break; | ||
} | ||
} | ||
} | ||
|
||
// check for incoming data from all clients | ||
for (byte i = 0; i < 8; i++) { | ||
if (clients[i] && clients[i].available() > 0) { | ||
// read bytes from a client | ||
byte buffer[80]; | ||
int count = clients[i].read(buffer, 80); | ||
// write the bytes to all other connected clients | ||
for (byte j = 0; j < 8; j++) { | ||
if (j != i && clients[j].connected()) { | ||
clients[j].write(buffer, count); | ||
} | ||
} | ||
} | ||
} | ||
|
||
// stop any clients which disconnect | ||
for (byte i = 0; i < 8; i++) { | ||
if (clients[i] && !clients[i].connected()) { | ||
Serial.print("disconnect client #"); | ||
Serial.println(i); | ||
clients[i].stop(); | ||
} | ||
} | ||
} |
105 changes: 105 additions & 0 deletions
105
libraries/lwIP_Ethernet/examples/LegacyChatServer/LegacyChatServer.ino
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
/* | ||
Chat Server | ||
|
||
A simple server that distributes any incoming messages to all | ||
connected clients. To use, telnet to your device's IP address and type. | ||
You can see the client's input in the serial monitor as well. | ||
Using an Arduino Wiznet Ethernet shield. | ||
|
||
Circuit: | ||
* Ethernet Wiznet5500/Wiznet5100/ENC28J60 on esp8266 | ||
|
||
created 18 Dec 2009 | ||
by David A. Mellis | ||
modified 9 Apr 2012 | ||
by Tom Igoe | ||
|
||
*/ | ||
|
||
|
||
// specific to esp8266 w/lwIP | ||
#include <EthernetCompat.h> | ||
ArduinoWiznet5500lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoWiznet5100lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoENC28J60lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
|
||
|
||
|
||
// Enter a MAC address and IP address for your controller below. | ||
// The IP address will be dependent on your local network. | ||
// gateway and subnet are optional: | ||
byte notNeededButAllowed_mac[] = { | ||
0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED | ||
}; | ||
byte* mac = nullptr; // automatic mac | ||
IPAddress ip(192, 168, 1, 177); | ||
IPAddress myDns(192, 168, 1, 1); | ||
IPAddress gateway(192, 168, 1, 1); | ||
IPAddress subnet(255, 255, 0, 0); | ||
|
||
|
||
// telnet defaults to port 23 | ||
EthernetServer server(23); | ||
bool alreadyConnected = false; // whether or not the client was connected previously | ||
|
||
void setup() { | ||
// You can use Ethernet.init(pin) to configure the CS pin | ||
// Ethernet.init(10); // Most Arduino shields | ||
// Ethernet.init(5); // MKR ETH shield | ||
// Ethernet.init(0); // Teensy 2.0 | ||
// Ethernet.init(20); // Teensy++ 2.0 | ||
// Ethernet.init(15); // ESP8266 with Adafruit Featherwing Ethernet | ||
// Ethernet.init(33); // ESP32 with Adafruit Featherwing Ethernet | ||
// // esp8266 w/lwIP: SS set in Ethernet constructor | ||
|
||
// initialize the ethernet device | ||
Ethernet.begin(mac, ip, myDns, gateway, subnet); | ||
|
||
// Open serial communications and wait for port to open: | ||
Serial.begin(9600); | ||
while (!Serial) { | ||
; // wait for serial port to connect. Needed for native USB port only | ||
} | ||
|
||
// Check for Ethernet hardware present | ||
if (Ethernet.hardwareStatus() == EthernetNoHardware) { | ||
Serial.println("Ethernet shield was not found. Sorry, can't run without hardware. :("); | ||
while (true) { | ||
delay(1); // do nothing, no point running without Ethernet hardware | ||
} | ||
} | ||
if (Ethernet.linkStatus() == LinkOFF) { | ||
Serial.println("Ethernet cable is not connected."); | ||
} | ||
|
||
// start listening for clients | ||
server.begin(); | ||
|
||
Serial.print("Chat server address:"); | ||
Serial.println(Ethernet.localIP()); | ||
} | ||
|
||
void loop() { | ||
// wait for a new client: | ||
EthernetClient client = server.available(); | ||
|
||
// when the client sends the first byte, say hello: | ||
if (client) { | ||
if (!alreadyConnected) { | ||
// clear out the input buffer: | ||
client.flush(); | ||
Serial.println("We have a new client"); | ||
client.println("Hello, client!"); | ||
alreadyConnected = true; | ||
} | ||
|
||
if (client.available() > 0) { | ||
// read the bytes incoming from the client: | ||
char thisChar = client.read(); | ||
// echo the bytes back to the client: | ||
server.write(thisChar); | ||
// echo the bytes to the server as well: | ||
Serial.write(thisChar); | ||
} | ||
} | ||
} |
101 changes: 101 additions & 0 deletions
101
libraries/lwIP_Ethernet/examples/LegacyDhcpAddressPrinter/LegacyDhcpAddressPrinter.ino
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
/* | ||
DHCP-based IP printer | ||
|
||
This sketch uses the DHCP extensions to the Ethernet library | ||
to get an IP address via DHCP and print the address obtained. | ||
using an Arduino Wiznet Ethernet shield. | ||
|
||
Circuit: | ||
Ethernet shield attached to pins 10, 11, 12, 13 | ||
|
||
created 12 April 2011 | ||
modified 9 Apr 2012 | ||
by Tom Igoe | ||
modified 02 Sept 2015 | ||
by Arturo Guadalupi | ||
|
||
*/ | ||
|
||
// specific to esp8266 w/lwIP | ||
#include <EthernetCompat.h> | ||
ArduinoWiznet5500lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoWiznet5100lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
// ArduinoENC28J60lwIP Ethernet(/*SS*/ 16); // <== adapt to your hardware | ||
|
||
|
||
// Enter a MAC address for your controller below. | ||
// Newer Ethernet shields have a MAC address printed on a sticker on the shield | ||
byte notNeededButAllowed_mac[] = { | ||
0x00, 0xAA, 0xBB, 0xCC, 0xDE, 0x02 | ||
}; | ||
byte* mac = nullptr; // automatic mac | ||
|
||
void setup() { | ||
// You can use Ethernet.init(pin) to configure the CS pin | ||
// Ethernet.init(10); // Most Arduino shields | ||
// Ethernet.init(5); // MKR ETH shield | ||
// Ethernet.init(0); // Teensy 2.0 | ||
// Ethernet.init(20); // Teensy++ 2.0 | ||
// Ethernet.init(15); // ESP8266 with Adafruit Featherwing Ethernet | ||
// Ethernet.init(33); // ESP32 with Adafruit Featherwing Ethernet | ||
// // esp8266 w/lwIP: SS set in Ethernet constructor | ||
|
||
|
||
// Open serial communications and wait for port to open: | ||
Serial.begin(9600); | ||
while (!Serial) { | ||
; // wait for serial port to connect. Needed for native USB port only | ||
} | ||
|
||
// start the Ethernet connection: | ||
Serial.println("Initialize Ethernet with DHCP:"); | ||
if (Ethernet.begin(mac) == 0) { | ||
Serial.println("Failed to configure Ethernet using DHCP"); | ||
if (Ethernet.hardwareStatus() == EthernetNoHardware) { | ||
Serial.println("Ethernet shield was not found. Sorry, can't run without hardware. :("); | ||
} else if (Ethernet.linkStatus() == LinkOFF) { | ||
Serial.println("Ethernet cable is not connected."); | ||
} | ||
// no point in carrying on, so do nothing forevermore: | ||
while (true) { | ||
delay(1); | ||
} | ||
} | ||
// print your local IP address: | ||
Serial.print("My IP address: "); | ||
Serial.println(Ethernet.localIP()); | ||
} | ||
|
||
void loop() { | ||
switch (Ethernet.maintain()) { | ||
case 1: | ||
// renewed fail | ||
Serial.println("Error: renewed fail"); | ||
break; | ||
|
||
case 2: | ||
// renewed success | ||
Serial.println("Renewed success"); | ||
// print your local IP address: | ||
Serial.print("My IP address: "); | ||
Serial.println(Ethernet.localIP()); | ||
break; | ||
|
||
case 3: | ||
// rebind fail | ||
Serial.println("Error: rebind fail"); | ||
break; | ||
|
||
case 4: | ||
// rebind success | ||
Serial.println("Rebind success"); | ||
// print your local IP address: | ||
Serial.print("My IP address: "); | ||
Serial.println(Ethernet.localIP()); | ||
break; | ||
|
||
default: | ||
// nothing happened | ||
break; | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
no need