Skip to content
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

IPv6 on esp8266-nonos-sdk and arduino #5136

Merged
merged 127 commits into from
Nov 27, 2018
Merged
Changes from 1 commit
Commits
Show all changes
127 commits
Select commit Hold shift + click to select a range
6c64759
wip
d-a-v Aug 22, 2018
746ec81
cc wip
d-a-v Aug 22, 2018
53c9222
cc wip
d-a-v Aug 22, 2018
6de50d4
cc comments
d-a-v Aug 22, 2018
2dd152d
wip cc
d-a-v Aug 24, 2018
f87602a
+sync, get/set default nodelay, sync
d-a-v Aug 27, 2018
6be4b6f
default nodelay=1
d-a-v Aug 28, 2018
8f7fb1e
update flush()
d-a-v Aug 28, 2018
c0bea2b
fix return value
d-a-v Aug 28, 2018
d00ac35
ClientContext: put things together
d-a-v Aug 28, 2018
53a19a8
Merge branch 'master' into ClientContext
devyte Sep 5, 2018
a662bfc
use ip4_addr instead of ip_addr
d-a-v May 23, 2018
b751983
ip4* -> ipv4*
d-a-v Aug 30, 2018
fc1719e
ipv6 wip
d-a-v Aug 30, 2018
68c207c
wip ipv6
d-a-v Sep 5, 2018
e18c276
wip ipv6
d-a-v Sep 5, 2018
090c5d5
ipv6: now compiles and links
d-a-v Sep 6, 2018
2fcd96c
wip ipv6: simplification of IPAddress + fix nasty reinterpret_cast bug
d-a-v Sep 6, 2018
eb666fb
wip ipv6
d-a-v Sep 6, 2018
ad02962
wip ipv6
d-a-v Sep 7, 2018
6718fe6
wip ipv6 lwIP-2.1rc0, menus
d-a-v Sep 10, 2018
95e8afe
wip ipv6
d-a-v Sep 10, 2018
de36650
wip ipv6
d-a-v Sep 11, 2018
d21916d
use ip4_addr instead of ip_addr
d-a-v May 23, 2018
0b11b17
ip4* -> ipv4*
d-a-v Aug 30, 2018
537b4da
ipv6 wip
d-a-v Aug 30, 2018
8f2ad74
wip ipv6
d-a-v Sep 5, 2018
c398663
wip ipv6
d-a-v Sep 5, 2018
b26701a
ipv6: now compiles and links
d-a-v Sep 6, 2018
9903be1
wip ipv6: simplification of IPAddress + fix nasty reinterpret_cast bug
d-a-v Sep 6, 2018
20bbdb3
wip ipv6
d-a-v Sep 6, 2018
b05dd81
wip ipv6
d-a-v Sep 7, 2018
b96c1c0
Merge branch 'ipv6' of github.com:d-a-v/Arduino into ipv6
d-a-v Sep 13, 2018
643036f
wip ipv6: now tcp server is working too :)
d-a-v Sep 14, 2018
86ba377
Merge branch 'ClientContext' into ipv6-test
d-a-v Sep 14, 2018
347130e
Merge branch 'master' into ipv6-test
devyte Sep 14, 2018
3c6ecb7
ipv6 fixes from lwip2 (dhcp6 working, beware: your esp is now accessi…
d-a-v Sep 15, 2018
5799d7e
parse and show standard ipv6 + WiFi.localIP6Link()/localIP6Global()
d-a-v Sep 16, 2018
d93ff6f
IPv6 initial example sketch
d-a-v Sep 17, 2018
54a50e2
liblwip2.a -> liblwip2_536.a
d-a-v Sep 17, 2018
43c5c9f
getFullVersion: lwIP version was displayed twice
d-a-v Sep 17, 2018
a777aa3
udp with IPV6 fixes
d-a-v Sep 17, 2018
1f48ad7
fix generic ip type management
d-a-v Sep 17, 2018
e3da355
lwip2: disable debug
d-a-v Sep 17, 2018
22f5701
lwip2: disable debug
d-a-v Sep 17, 2018
389bf07
lwip2: disable debug
d-a-v Sep 17, 2018
402c35e
update example with UDP showing remote v4 or v6 address
d-a-v Sep 17, 2018
53931c5
wip
d-a-v Aug 22, 2018
81ec0f4
cc wip
d-a-v Aug 22, 2018
fbf1dd1
cc wip
d-a-v Aug 22, 2018
b4a918f
cc comments
d-a-v Aug 22, 2018
c14eeef
wip cc
d-a-v Aug 24, 2018
238610e
+sync, get/set default nodelay, sync
d-a-v Aug 27, 2018
d0036a1
default nodelay=1
d-a-v Aug 28, 2018
e4c187b
update flush()
d-a-v Aug 28, 2018
d31d6f2
fix return value
d-a-v Aug 28, 2018
5cf60b6
ClientContext: put things together
d-a-v Aug 28, 2018
a058506
Move SSLContext to its own header (#5121)
earlephilhower Sep 17, 2018
a7a5959
Fix connection options and update github pubkey (#5120)
earlephilhower Sep 17, 2018
d06cac2
ClientContext: fix debugging messages
d-a-v Sep 18, 2018
976b749
Merge branch 'ClientContext' into ipv6-test
d-a-v Sep 18, 2018
ad61dfc
Esp.getFullVersion: show when IPv6 is enabled
d-a-v Sep 18, 2018
ede6e44
fixes lwip-v2 compatibilities with lwip-1.4 (check IPAddress.h's begi…
d-a-v Sep 18, 2018
2693714
enable nagle by default
d-a-v Sep 18, 2018
1bc5bc8
minor update to IPv6 example
d-a-v Sep 18, 2018
e67b6f0
astyled example
d-a-v Sep 18, 2018
c7859ba
LLMNR: restore a removed test
d-a-v Sep 18, 2018
636aa28
mDNSlib porting (multicast api changes like for MMNR SSDP)
d-a-v Sep 18, 2018
17ba0f6
fix: IPAddress is now rich, and cast to uint32_t is sometimes ambiguo…
d-a-v Sep 18, 2018
afa747d
port OTA
d-a-v Sep 18, 2018
0bbd791
IPAddress cosmetic
d-a-v Sep 18, 2018
4708451
add const to Ethernet and friends
d-a-v Sep 18, 2018
e8c659e
Merge branch 'master' into ClientContext
earlephilhower Sep 18, 2018
63e1da7
fix DNS
d-a-v Sep 18, 2018
b9f79f5
Merge branch 'master' into ipv6-test
d-a-v Sep 18, 2018
f271b2a
WiFiClient: move static members out of the class, add comments
d-a-v Sep 18, 2018
7f57694
Merge branch 'ClientContext' of github.com:d-a-v/Arduino into ClientC…
d-a-v Sep 18, 2018
888bdb8
remove circular dependency
d-a-v Sep 19, 2018
9d31c78
Merge branch 'ClientContext' into ipv6-test
d-a-v Sep 19, 2018
15e7dfe
IPAddress needs to be copied
d-a-v Sep 19, 2018
c8a81e5
IPAddress needs to be copied
d-a-v Sep 19, 2018
254c252
IPaddress: fix nullptr
d-a-v Sep 19, 2018
c2b0b96
add missing files (due to update to lwIP-2.1rc1)
d-a-v Sep 19, 2018
8f53b52
ipv6 example: use ipv6.google.com, shows status in udp:23, show versions
d-a-v Sep 19, 2018
0b7456b
Merge branch 'master' into ipv6-test
devyte Sep 21, 2018
64802a0
interface list for c++
d-a-v Sep 22, 2018
b7cd735
Merge branch 'master' into ipv6-test
d-a-v Sep 22, 2018
ba4a4d0
Merge branch 'master' into ipv6-test
d-a-v Sep 24, 2018
0393171
Merge branch 'master' into ipv6-test
d-a-v Sep 25, 2018
f63d2c7
Merge branch 'ipv6-test' of github.com:d-a-v/Arduino into ipv6-test
d-a-v Sep 25, 2018
0cde770
+ IfList: interface iterator
d-a-v Sep 26, 2018
e855977
Merge branch 'ipv6-test' of github.com:d-a-v/Arduino into ipv6-test
d-a-v Sep 26, 2018
4f97603
rename ifList to addrList, more accessors, updated example
d-a-v Sep 26, 2018
a6faa9d
Merge branch 'master' into ipv6-test
d-a-v Sep 27, 2018
b1e9cb5
Merge branch 'master' into ipv6-test
d-a-v Sep 28, 2018
10638ba
Merge branch 'master' into ipv6-test
d-a-v Sep 29, 2018
5948b93
Merge branch 'master' into ipv6-test
d-a-v Oct 1, 2018
bd85431
update example & comments and AddrList API
d-a-v Oct 1, 2018
0de3365
Merge branch 'ipv6-test' of github.com:d-a-v/Arduino into ipv6-test
d-a-v Oct 1, 2018
f986cfe
astyle
d-a-v Oct 1, 2018
190c016
Merge branch 'master' into ipv6-test
d-a-v Oct 2, 2018
94eef5f
Merge branch 'master' into ipv6-test2
d-a-v Oct 9, 2018
f4cb3a6
cleaning
d-a-v Oct 9, 2018
bc654a3
Merge branch 'master' into ipv6-test
d-a-v Nov 26, 2018
849f87a
Merge branch 'ipv6-test' of github.com:d-a-v/Arduino into ipv6-test
d-a-v Nov 26, 2018
29618dc
use CONST in place of constv2
d-a-v Nov 26, 2018
38efc64
Merge branch 'master' into ipv6-test
d-a-v Nov 26, 2018
1d78618
+ IPAddress::fromString4()
d-a-v Nov 26, 2018
bcd8fcd
use StringStream:: for ::toString()
d-a-v Nov 26, 2018
53b099b
use periodic timeout
d-a-v Nov 26, 2018
366d3a7
minor updates on interface iterator
d-a-v Nov 26, 2018
2dcf863
check for IPv4 addresses for softAP intialization
d-a-v Nov 26, 2018
82eecf3
comment
d-a-v Nov 27, 2018
0d7cd7d
document preprocessing #error directive
d-a-v Nov 27, 2018
523aa05
remove lowpan*
d-a-v Nov 27, 2018
97d2032
fix example
d-a-v Nov 27, 2018
ece7393
pio build
d-a-v Nov 27, 2018
b526eef
remove ifList from ESP8266WiFi.cpp
d-a-v Nov 27, 2018
d377bad
fix boards.txt
d-a-v Nov 27, 2018
271e94f
cast return type
d-a-v Nov 27, 2018
326f705
Merge branch 'ipv6-test' of github.com:d-a-v/Arduino into ipv6-test
d-a-v Nov 27, 2018
d2bad35
rename IfList -> AddrList
d-a-v Nov 27, 2018
9ea8f0e
rename IfList to AddrList
d-a-v Nov 27, 2018
f530d84
fix example
d-a-v Nov 27, 2018
c16a111
check WiFi.config args for v4()
d-a-v Nov 27, 2018
72a64f0
remove tools/sdk/include/mesh.h
d-a-v Nov 27, 2018
fdcca1f
update lwIP to 2.1.2 stable, glue tagged 1.0 stable
d-a-v Nov 27, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
ClientContext: put things together
d-a-v committed Sep 18, 2018

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit 5cf60b6e9a8ed439ec9aa8162907ec0e501332b2
18 changes: 8 additions & 10 deletions libraries/ESP8266WiFi/src/WiFiClient.cpp
Original file line number Diff line number Diff line change
@@ -171,14 +171,14 @@ bool WiFiClient::getNoDelay() const {

void WiFiClient::setSync(bool sync)
{
if(!_client)
if (!_client)
return;
_client->setSync(sync);
}

bool WiFiClient::getSync() const
{
if(!_client)
if (!_client)
return false;
return _client->getSync();
}
@@ -285,21 +285,19 @@ size_t WiFiClient::peekBytes(uint8_t *buffer, size_t length) {
return _client->peekBytes((char *)buffer, count);
}

bool WiFiClient::flush(int maxWaitMs)
void WiFiClient::flush()
{
if (_client)
return !_client || _client->wait_until_sent(maxWaitMs);
return true;
_client->wait_until_sent();
}

bool WiFiClient::stop(int maxWaitMs)
void WiFiClient::stop()
{
if (!_client)
return true;
return;

bool ok = _client->wait_until_sent(maxWaitMs);
ok &= _client->close() == ERR_OK;
return ok;
_client->wait_until_sent();
_client->close();
}

uint8_t WiFiClient::connected()
6 changes: 2 additions & 4 deletions libraries/ESP8266WiFi/src/WiFiClient.h
Original file line number Diff line number Diff line change
@@ -72,10 +72,8 @@ class WiFiClient : public Client, public SList<WiFiClient> {
size_t peekBytes(char *buffer, size_t length) {
return peekBytes((uint8_t *) buffer, length);
}
bool flush(int maxWaitMs);
bool stop(int maxWaitMs);
virtual void flush() { flush(WIFICLIENT_MAX_FLUSH_WAIT_MS); }
virtual void stop() { stop(WIFICLIENT_MAX_FLUSH_WAIT_MS); }
virtual void flush();
virtual void stop();
virtual uint8_t connected();
virtual operator bool();

39 changes: 18 additions & 21 deletions libraries/ESP8266WiFi/src/include/ClientContext.h
Original file line number Diff line number Diff line change
@@ -296,31 +296,29 @@ class ClientContext
_rx_buf_offset = 0;
}

bool wait_until_sent(int max_wait_ms = WIFICLIENT_MAX_FLUSH_WAIT_MS)
void wait_until_sent()
{
if (!_pcb)
return true;

tcp_output(_pcb);

// https://github.com/esp8266/Arduino/pull/3967#pullrequestreview-83451496
// option 1 done
// option 2 / _write_some() not necessary since _datasource is always nullptr here

max_wait_ms++;
if (!_pcb)
return;

tcp_output(_pcb);

int max_wait_ms = WIFICLIENT_MAX_FLUSH_WAIT_MS + 1;

// wait for peer's acks flushing lwIP's output buffer
while (state() == ESTABLISHED && tcp_sndbuf(_pcb) != TCP_SND_BUF && --max_wait_ms)
delay(1); // esp_ schedule+yield
delay(1); // yields

#ifdef DEBUGV
if (max_wait_ms == 0) {
// wait until sent: timeout
DEBUGV(":wustmo\n");
}
#endif

return max_wait_ms > 0;
}

uint8_t state() const
@@ -461,13 +459,15 @@ class ClientContext
if (!next_chunk_size)
break;
const uint8_t* buf = _datasource->get_buffer(next_chunk_size);
// TCP_WRITE_FLAG_MORE to remove PUSH flag from packet (lwIP's doc), implicitely disables nagle (see lwIP's tcp_out.c)
// use TCP_WRITE_FLAG_MORE to remove PUSH flag from packet (lwIP's doc),
// because PUSH implicitely disables nagle (see lwIP's tcp_out.c)
// Notes:
// PUSH is for peer, telling to give to user app as soon as received
// PUSH may be set when sender has finished sending a meaningful data block
// Nagle is for delaying local stack, to send less and bigger packets
uint8_t flags = TCP_WRITE_FLAG_MORE; // do not tcp-PuSH (XXX always?)
// PUSH is for peer, telling to give data to user app as soon as received
// PUSH "may be set" when sender has finished sending a meaningful data block
// Nagle is for delaying local data, to send less/bigger packets
uint8_t flags = TCP_WRITE_FLAG_MORE; // do not tcp-PuSH
if (!_sync)
// user data will not stay in place when data are sent but not acknowledged
flags |= TCP_WRITE_FLAG_COPY;
err_t err = tcp_write(_pcb, buf, next_chunk_size, flags);
DEBUGV(":wrc %d %d %d\r\n", next_chunk_size, will_send, (int)err);
@@ -484,8 +484,8 @@ class ClientContext

if (has_written && (_sync || tcp_nagle_disabled(_pcb)))
{
// handle nagle manually because of TCP_WRITE_FLAG_MORE
// lwIP's tcp_output: "Find out what we can send and send it"
// handle no-Nagle manually because of TCP_WRITE_FLAG_MORE
// lwIP's tcp_output doc: "Find out what we can send and send it"
tcp_output(_pcb);
}

@@ -494,13 +494,10 @@ class ClientContext

void _write_some_from_cb()
{
// lwIP needs feeding
_write_some();

if (_send_waiting == 1) {
_send_waiting--;
esp_schedule();
}
esp_schedule();
}

err_t _acked(tcp_pcb* pcb, uint16_t len)