-
Notifications
You must be signed in to change notification settings - Fork 106
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
Add hostname support to pico network driver #1173
base: main
Are you sure you want to change the base?
Conversation
2cfae05
to
cfec95d
Compare
@pguyot do you have any opinion about this? |
} else { | ||
buf = interop_term_to_string(hostname_term, &ok); | ||
} | ||
if (!ok || IS_NULL_PTR(buf)) { |
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.
if ok is false, we still need to free buf.
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.
(!ok || IS_NULL_PTR(buf))
might also be normalized to (UNLIKELY(!ok || buf != NULL))
.
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.
I fixed both comments.
free(psk); | ||
return BADARG_ATOM; | ||
} | ||
ap_hostname = malloc(strlen(buf) + 1); |
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.
I am very confused about when this is freed.
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.
At the beginning of this section (line 483 new):
char *ap_hostname = driver_data->ap_hostname;
This is freed when the driver is terminated.
void network_driver_destroy(GlobalContext *global)
{
if (driver_data) {
if (driver_data->hostname) {
free(driver_data->hostname);
}
if (driver_data->ap_hostname) {
free(driver_data->ap_hostname);
...
free(psk); | ||
return BADARG_ATOM; | ||
} | ||
hostname = malloc(strlen(buf) + 1); |
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.
I am confused about this allocation. When is it freed?
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.
see above.
@@ -705,6 +810,12 @@ void network_driver_init(GlobalContext *global) | |||
void network_driver_destroy(GlobalContext *global) | |||
{ | |||
if (driver_data) { | |||
if (driver_data->hostname) { |
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.
if is not required here AFAIK
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.
The per interface hostname resides in driver_data until the driver terminates at which point it is freed, but I realize now I wrote this before I fully understood how the driver_destroy functions work. This code should be placed in network:stop/0
which this driver does not yet support.
In the Pico-SDK netif_set_hostname() is defined as:
#define netif_set_hostname(netif, name) do { if((netif) != NULL) { (netif)->hostname = name; }}while(0)
If the hostname is freed the interface hostname will immediately revert to PicoW
, since NULL has the same effect as the hostname being unset.
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.
In examples for Pico-SDK that set a hostname it is always hardcoded in a string in flash, so there is no additional memory consumed, but to have this set programmatically we don't have that luxury. Perhaps we could come up with an NVS like solution to store this kind of data?
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.
Sorry for the confusion. I meant that:
if (ptr) {
free(ptr);
}
is equivalent to:
free(ptr);
as free accepts NULL.
cfec95d
to
7d3972b
Compare
@@ -705,6 +810,12 @@ void network_driver_init(GlobalContext *global) | |||
void network_driver_destroy(GlobalContext *global) | |||
{ | |||
if (driver_data) { | |||
if (driver_data->hostname) { |
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.
Sorry for the confusion. I meant that:
if (ptr) {
free(ptr);
}
is equivalent to:
free(ptr);
as free accepts NULL.
} | ||
return BADARG_ATOM; | ||
} | ||
driver_data->ap_hostname = malloc(strlen(buf) + 1); |
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.
You could use strdup(3) which would do the computation of the length, the allocation and the copy in a single call. Alternatively, if it's not available in some SDKs (it's part of C89), you could save the length to avoid computing it twice.
free(psk); | ||
return BADARG_ATOM; | ||
} | ||
driver_data->hostname = malloc(strlen(buf) + 1); |
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.
You could use strdup(3) which would do the computation of the length, the allocation and the copy in a single call. Alternatively, if it's not available in some SDKs (it's part of C89), you could save the length to avoid computing it twice.
free(ssid); | ||
free(psk); | ||
return OUT_OF_MEMORY_ATOM; | ||
} else { |
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.
Let's be coherent with what is done on line 293 and remove else here.
free(ssid); | ||
free(psk); | ||
return OUT_OF_MEMORY_ATOM; | ||
} else { |
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.
Let's be coherent with what is done on line 293 and remove else here.
free(ssid); | ||
free(psk); | ||
return OUT_OF_MEMORY_ATOM; | ||
} else { |
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.
Let's be coherent with what is done on line 514 and remove else here.
free(ssid); | ||
free(psk); | ||
return OUT_OF_MEMORY_ATOM; | ||
} else { |
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.
Let's be coherent with what is done on line 514 and remove else here.
7d3972b
to
2e0e53f
Compare
Fixes a leak in `get_default_device_name()`, if the driver if stopped the memory holding the device name is never free'd. This could be especially problematic if the driver is stopped and restarted multiple times, as may be the case with a battery powered device. Fixes a potential memory leak of `psk` used for the ap if the given `psk` is invalid due to not meeting the minimum size requirement. Signed-off-by: Winford <winford@object.stream>
Adds support for setting `dhcp_hostname` from `sta_config_options()` and/or `ap_config_options()`, or, if undefined, sets the hostname to the default device name of `atomvm-${DEVICE_MAC}`. Formerly all pico_w devices tried to register to an access point with the factory default `PicoW` hostname, which would make all subsequent pico devices to connect to an access point, after the first one, unreachable by hostname. Closes atomvm#1094 Signed-off-by: Winford <winford@object.stream>
2e0e53f
to
e9ef1ca
Compare
Adds support for setting a unique default device
hostname
(as the ESP32 platform does), and setting per interfacehostname
in the interface configuration (honoring thedhcp_hostname
key value).closes #1094
These changes are made under both the "Apache 2.0" and the "GNU Lesser General
Public License 2.1 or later" license terms (dual license).
SPDX-License-Identifier: Apache-2.0 OR LGPL-2.1-or-later