Hey all,
I have a working serial->UDP application and I recently added an HTTPD server for some user config... and that works too -- EXCEPT....
While the httpd server is running, I'm guessing it set up it's bind with options to NOT use SO_REUSEADDR.
So now, my UDP sending functions get the "Address already in use" errno 112 when trying to bind (SRCport:32768, DESTport:4000) (and it's TX only. no RX)
I'm guessing I have to somehow set the HTTP server to allow SO_REUSEADDR -- but how?
Is this an httpd_config.open_fn = <someFunction> operation or something else?
Thanks,
-Ben
[SOLVED] ESP32-S3 IDF 5.2.x - httpd setting socket options SO_REUSE_ADDR?
-
- Posts: 4
- Joined: Tue Mar 26, 2024 1:32 am
[SOLVED] ESP32-S3 IDF 5.2.x - httpd setting socket options SO_REUSE_ADDR?
Last edited by benjammin2068 on Fri May 31, 2024 5:04 pm, edited 1 time in total.
-
- Posts: 9759
- Joined: Thu Nov 26, 2015 4:08 am
Re: ESP32-S3 IDF 5.2.x - httpd setting socket options SO_REUSE_ADDR?
That doesn't make sense - the http server has nothing to do with your UDP ports and should not be affected by whatever port options it sets. You need to set SO_REUSEADDR on your UDP sockets.
-
- Posts: 4
- Joined: Tue Mar 26, 2024 1:32 am
[SOLVED] Re: ESP32-S3 IDF 5.2.x - httpd setting socket options SO_REUSE_ADDR?
And I looked in the source and see SO_REUSEADDR is now included -- so it was just how I was setting up my UDP packet sender.
The last post I searched and saw (from 2019) seemed to imply that SO_REUSEADDR was missing from the http server.
That's no longer the case.
This is in 5.2.x:
So problem solved.
I'll leave this post here in case anyone else is wondering.
The last post I searched and saw (from 2019) seemed to imply that SO_REUSEADDR was missing from the http server.
That's no longer the case.
This is in 5.2.x:
Code: Select all
/* Enable SO_REUSEADDR to allow binding to the same
* address and port when restarting the server */
int enable = 1;
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &enable, sizeof(enable)) < 0) {
/* This will fail if CONFIG_LWIP_SO_REUSE is not enabled. But
* it does not affect the normal working of the HTTP Server */
ESP_LOGW(TAG, LOG_FMT("error in setsockopt SO_REUSEADDR (%d)"), errno);
}
I'll leave this post here in case anyone else is wondering.
Who is online
Users browsing this forum: ESPBoards and 191 guests