Fix segmentation fault for NULL confname in SAVE_CONFIG
When wpa_supplicant interface is added without a configuration file, the SAVE_CONFIG command causes a segmentation fault due to referencing a NULL pointer if the update_config parameter is first explicitly enabled. Fix the issue by checking the confname for NULL before saving configuration. Signed-off-by: Jouni Malinen <jouni@codeaurora.org>
This commit is contained in:
parent
81621eab7c
commit
87775e32f6
1 changed files with 9 additions and 2 deletions
|
@ -1612,9 +1612,16 @@ int wpa_config_write(const char *name, struct wpa_config *config)
|
|||
#endif /* CONFIG_NO_CONFIG_BLOBS */
|
||||
int ret = 0;
|
||||
const char *orig_name = name;
|
||||
int tmp_len = os_strlen(name) + 5; /* allow space for .tmp suffix */
|
||||
char *tmp_name = os_malloc(tmp_len);
|
||||
int tmp_len;
|
||||
char *tmp_name;
|
||||
|
||||
if (!name) {
|
||||
wpa_printf(MSG_ERROR, "No configuration file for writing");
|
||||
return -1;
|
||||
}
|
||||
|
||||
tmp_len = os_strlen(name) + 5; /* allow space for .tmp suffix */
|
||||
tmp_name = os_malloc(tmp_len);
|
||||
if (tmp_name) {
|
||||
os_snprintf(tmp_name, tmp_len, "%s.tmp", name);
|
||||
name = tmp_name;
|
||||
|
|
Loading…
Reference in a new issue