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

more lwIP physical interfaces #6680

Merged
merged 118 commits into from
Dec 22, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
118 commits
Select commit Hold shift + click to select a range
04bcb88
Extracts dhcp server from lwip2 and add it to the core.
d-a-v Oct 1, 2019
1793b27
ethernet wip
d-a-v Oct 3, 2019
cb198b4
Merge branch 'master' into ethernet
d-a-v Oct 3, 2019
de4a287
ethernet wip
d-a-v Oct 3, 2019
d279c66
ethernet wip
d-a-v Oct 4, 2019
9229ca5
Merge branch 'master' into ethernet
d-a-v Oct 4, 2019
05d5b68
ethernet wip
d-a-v Oct 5, 2019
9a3df51
ethernet wip
d-a-v Oct 5, 2019
c5c921e
ethernet wip: dhcpserver in a class wip
d-a-v Oct 5, 2019
04b5ed7
ethernet wip
d-a-v Oct 6, 2019
cc2c2ce
now needed: void preinit(){ESP8266WiFiClass::preinitWiFiOff();}
d-a-v Oct 6, 2019
f893c32
ethernet wip
d-a-v Oct 6, 2019
7df15f3
ethernet wip
d-a-v Oct 6, 2019
19146a6
lwip2: no more dhcp inside
d-a-v Oct 7, 2019
e89f352
Merge branch 'master' into ethernet
d-a-v Oct 7, 2019
5898985
ethernet wip
d-a-v Oct 7, 2019
833d3af
Merge branch 'master' into ethernet
d-a-v Oct 7, 2019
deebbcb
ethernet wip
d-a-v Oct 8, 2019
a3b1d91
ethernet wip: dhcp server working for legacy AP on boot, and external…
d-a-v Oct 10, 2019
b8485d1
Merge branch 'master' into ethernet
d-a-v Oct 10, 2019
919839d
ethernet wip
d-a-v Oct 12, 2019
16ddd26
Merge branch 'master' into ethernet
d-a-v Oct 24, 2019
574be13
ppp server updates
d-a-v Oct 26, 2019
8d10e91
restyle
d-a-v Oct 26, 2019
756ce0c
PPPServer: example
d-a-v Oct 26, 2019
5b38c0d
astyle
d-a-v Oct 26, 2019
b79d841
comments
d-a-v Oct 28, 2019
3fec74a
argument reorder common function for ::config()
d-a-v Oct 28, 2019
f15a93c
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Oct 28, 2019
6ac98da
fix upstream url
d-a-v Oct 28, 2019
f35f712
Merge branch 'master' into ethernet
d-a-v Oct 28, 2019
a8e231b
sync with lwip2
d-a-v Oct 28, 2019
6be2382
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Oct 28, 2019
c6c3805
sync with lwip2
d-a-v Oct 28, 2019
7bdadd4
missing file
d-a-v Oct 29, 2019
3282a3f
fix dhcp server on AP
d-a-v Oct 30, 2019
370bd62
Merge branch 'master' into ethernet
d-a-v Oct 30, 2019
fc6fb1d
fix example
d-a-v Oct 30, 2019
900c594
fix former declaration of dhcp server, and its current use
d-a-v Oct 30, 2019
4b5a2c4
fix dhcp server when ipv6 is enabled
d-a-v Oct 30, 2019
4ebd5c8
fixes for lwip1
d-a-v Oct 30, 2019
1366903
fi macro arithmetic
d-a-v Oct 30, 2019
d09d62e
fix example
d-a-v Oct 30, 2019
d9d9339
add missing files (ppp)
d-a-v Oct 30, 2019
5816590
fix emulation on host
d-a-v Oct 30, 2019
04d02c3
fix example warnings
d-a-v Oct 30, 2019
6ee5df9
Merge branch 'master' into ethernet
devyte Nov 5, 2019
8f57757
Merge branch 'master' into ethernet
d-a-v Nov 14, 2019
9eb9dee
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Nov 23, 2019
6b27eaa
Merge branch 'master' into ethernet
d-a-v Nov 23, 2019
bd8b32a
move hostname() from STA to generic interface
d-a-v Nov 23, 2019
55b874c
Merge branch 'master' into ethernet
d-a-v Nov 24, 2019
21694be
Merge branch 'master' into ethernet
d-a-v Nov 28, 2019
9d77d1d
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Nov 28, 2019
a81d110
Merge branch 'master' into ethernet
d-a-v Dec 4, 2019
b3acf27
Merge branch 'master' into ethernet
d-a-v Dec 6, 2019
df04b3c
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Dec 21, 2019
51aca37
Merge branch 'master' into ethernet
d-a-v Dec 21, 2019
6e12d9e
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Feb 18, 2020
540e446
sync with lwip2
d-a-v Feb 18, 2020
29d3de7
Merge branch 'master' into ethernet
d-a-v Feb 25, 2020
50fec05
Merge branch 'master' into ethernet
d-a-v Feb 25, 2020
488ae3e
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Feb 27, 2020
21ffcfe
Merge branch 'master' into ethernet
d-a-v Feb 27, 2020
0b4689b
style
d-a-v Feb 27, 2020
043d32c
fix using softserial API
d-a-v Feb 27, 2020
cc2be53
fix warning with macro
d-a-v Feb 27, 2020
0dcfc84
fix include file with lwip1.4
d-a-v Feb 27, 2020
967c349
lwIP-1.4 include fix
d-a-v Feb 27, 2020
0f133cc
lwIP-1.4 include fix
d-a-v Feb 27, 2020
3c15b76
+ comments
d-a-v Apr 30, 2020
e0e7cdb
remove non readable characters from comments
d-a-v Apr 30, 2020
af93802
magic_cookie is part of bootp rfc
d-a-v Apr 30, 2020
639ef04
more comments
d-a-v Apr 30, 2020
a60ffaa
rebuild lwip lib
d-a-v Apr 30, 2020
0673d0d
Merge branch 'master' into ethernet
d-a-v Apr 30, 2020
44a680d
rebuild lwip libs
d-a-v Apr 30, 2020
147f5a9
rebuild lwip libs
d-a-v Apr 30, 2020
b18ec7b
fix copy from pointer
d-a-v May 1, 2020
e258e16
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Jun 2, 2020
fef264e
Merge branch 'master' into ethernet
d-a-v Jun 2, 2020
59fe44e
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Jun 2, 2020
d80cd31
do not filter mac address from within driver (https://github.com/d-a-…
d-a-v Jun 2, 2020
50d9e83
fix compilation problem with IPv6
d-a-v Jun 2, 2020
8b81709
per https://github.com/d-a-v/W5500lwIP/issues/17#issuecomment-638229509
d-a-v Jun 3, 2020
08dca76
Merge branch 'master' into ethernet
d-a-v Jun 3, 2020
03b0670
update
d-a-v Jul 16, 2020
24f0e9a
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Jul 16, 2020
90da681
Merge branch 'master' into ethernet
d-a-v Jul 16, 2020
f8c7f10
fix compilation without local lwip1.4
d-a-v Jul 16, 2020
63354f2
merge with master
d-a-v Jul 16, 2020
5af7382
recompile lwip2
d-a-v Jul 16, 2020
49068fd
fix example
d-a-v Jul 16, 2020
96eb899
Merge branch 'master' into ethernet
d-a-v Jul 30, 2020
8be6533
ppp server: release resource on fail
d-a-v Aug 1, 2020
30a2aa7
reorder members
d-a-v Aug 1, 2020
a0239ac
per review and fixes
d-a-v Aug 1, 2020
b2dac9b
Merge branch 'master' into ethernet
d-a-v Aug 15, 2020
5928211
Merge branch 'master' into ethernet
d-a-v Aug 16, 2020
55ef5ef
Merge branch 'master' into ethernet
d-a-v Aug 21, 2020
27ff946
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Sep 5, 2020
94fb55e
Merge branch 'master' into ethernet
d-a-v Sep 5, 2020
97ad7ab
Merge branch 'master' into ethernet
d-a-v Sep 21, 2020
509999b
Merge branch 'master' into ethernet
d-a-v Sep 27, 2020
0a0f8a5
lwip2: recompiled PPP branch after sync w/ master
d-a-v Sep 27, 2020
788928c
fix file name case confusion after merging from master
d-a-v Sep 27, 2020
38fbe41
fix include file name, remove private constructor
d-a-v Sep 27, 2020
a3aaa49
fix emulatio on host too
d-a-v Sep 27, 2020
29a3e29
Merge branch 'master' into ethernet
d-a-v Oct 15, 2020
dbc55c0
Merge branch 'master' into ethernet
d-a-v Oct 24, 2020
723bed1
Merge branch 'master' into ethernet
earlephilhower Oct 26, 2020
ee5acfe
add lwip_hook_dhcp_parse_option()
d-a-v Nov 9, 2020
8094f2d
Merge branch 'ethernet' of github.com:d-a-v/Arduino into ethernet
d-a-v Nov 9, 2020
823a245
Merge branch 'master' into ethernet
d-a-v Dec 6, 2020
e67e830
Merge branch 'master' into ethernet
d-a-v Dec 22, 2020
3d459da
lwIP recompilation
d-a-v Dec 22, 2020
c5461f6
+ethernet tcp client example in w5500 library examples
d-a-v Dec 22, 2020
90f434f
add cores/esp8266/Lwip* files under AllmanStyle control
d-a-v Dec 22, 2020
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
64 changes: 64 additions & 0 deletions cores/esp8266/LwipDhcpServer-NonOS.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
/*
lwIPDhcpServer-NonOS.cpp - DHCP server wrapper

Copyright (c) 2020 esp8266 arduino. All rights reserved.
This file is part of the esp8266 core for Arduino environment.

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/

// STARTS/STOPS DHCP SERVER ON WIFI AP INTERFACE
// these functions must exists as-is with "C" interface,
// nonos-sdk calls them at boot time and later

#include <lwip/init.h> // LWIP_VERSION

#include <lwip/netif.h>
#include "LwipDhcpServer.h"

extern netif netif_git[2];

// global DHCP instance for softAP interface
DhcpServer dhcpSoftAP(&netif_git[SOFTAP_IF]);

extern "C"
{

void dhcps_start(struct ip_info *info, netif* apnetif)
{
// apnetif is esp interface, replaced by lwip2's
// netif_git[SOFTAP_IF] interface in constructor
(void)apnetif;

#if 0
// can't use C++ now, global ctors are not initialized yet
dhcpSoftAP.begin(info);
#else
(void)info;
// initial version: emulate nonos-sdk in DhcpServer class before
// trying to change legacy behavor
// `fw_has_started_softap_dhcps` will be read in DhcpServer::DhcpServer
// which is called when c++ ctors are initialized, specifically
// dhcpSoftAP intialized with AP interface number above.
fw_has_started_softap_dhcps = 1;
#endif
}

void dhcps_stop()
{
dhcpSoftAP.end();
}

} // extern "C"
Loading