extmod/modnetwork: Forward if.config(hostname) to network.hostname.
This removes the duplicate code in cyw43, esp32, esp8266 that implements
the same logic as network.hostname.
Renames the `mod_network_hostname` (where we store the hostname value in
`.data`) to `mod_network_hostname_data` to make way for calling the shared
function `mod_network_hostname`.
And uses memcpy for mod_network_hostname_data, because the length of source
is already known and removes reliance on string data being null-terminated.
This work was funded through GitHub Sponsors.
Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
diff --git a/ports/esp32/network_wlan.c b/ports/esp32/network_wlan.c
index f06143b..e1d16b4 100644
--- a/ports/esp32/network_wlan.c
+++ b/ports/esp32/network_wlan.c
@@ -169,8 +169,8 @@
if (!mdns_initialised) {
mdns_init();
#if MICROPY_HW_ENABLE_MDNS_RESPONDER
- mdns_hostname_set(mod_network_hostname);
- mdns_instance_name_set(mod_network_hostname);
+ mdns_hostname_set(mod_network_hostname_data);
+ mdns_instance_name_set(mod_network_hostname_data);
#endif
mdns_initialised = true;
}
@@ -305,7 +305,7 @@
esp_exceptions(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_sta_config));
}
- esp_exceptions(esp_netif_set_hostname(wlan_sta_obj.netif, mod_network_hostname));
+ esp_exceptions(esp_netif_set_hostname(wlan_sta_obj.netif, mod_network_hostname_data));
wifi_sta_reconnects = 0;
// connect to the WiFi AP
@@ -522,12 +522,7 @@
case MP_QSTR_hostname:
case MP_QSTR_dhcp_hostname: {
// TODO: Deprecated. Use network.hostname(name) instead.
- size_t len;
- const char *str = mp_obj_str_get_data(kwargs->table[i].value, &len);
- if (len > MICROPY_PY_NETWORK_HOSTNAME_MAX_LEN) {
- mp_raise_ValueError(NULL);
- }
- strcpy(mod_network_hostname, str);
+ mod_network_hostname(1, &kwargs->table[i].value);
break;
}
case MP_QSTR_max_clients: {
@@ -630,7 +625,7 @@
case MP_QSTR_dhcp_hostname: {
// TODO: Deprecated. Use network.hostname() instead.
req_if = ESP_IF_WIFI_STA;
- val = mp_obj_new_str(mod_network_hostname, strlen(mod_network_hostname));
+ val = mod_network_hostname(0, NULL);
break;
}
case MP_QSTR_max_clients: {