Skip to content

Commit

Permalink
hostapd: fix building mini variants
Browse files Browse the repository at this point in the history
Move function and add ifdef to avoid undefined reference to hmac_sha256_kdf.

Signed-off-by: Felix Fietkau <[email protected]>
  • Loading branch information
nbd168 committed Dec 13, 2024
1 parent b6c7d8a commit 225b84d
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 35 deletions.
39 changes: 39 additions & 0 deletions package/network/services/hostapd/src/src/ap/ucode.c
Original file line number Diff line number Diff line change
Expand Up @@ -817,6 +817,45 @@ void hostapd_ucode_sta_connected(struct hostapd_data *hapd, struct sta_info *sta
ucv_put(val);
}

static uc_value_t *
uc_wpa_rkh_derive_key(uc_vm_t *vm, size_t nargs)
{
#ifdef CONFIG_IEEE80211R_AP
u8 oldkey[16];
char *oldkey_hex;
u8 key[SHA256_MAC_LEN];
size_t key_len = sizeof(key);
char key_hex[2 * ARRAY_SIZE(key) + 1];
uc_value_t *val = uc_fn_arg(0);
int i;

if (ucv_type(val) != UC_STRING)
return NULL;

oldkey_hex = ucv_string_get(val);

if (!hexstr2bin(oldkey_hex, key, key_len))
return ucv_string_new_length(oldkey_hex, 2 * ARRAY_SIZE(key));

if (hexstr2bin(oldkey_hex, oldkey, sizeof(oldkey))) {
wpa_printf(MSG_ERROR, "Invalid RxKH key: '%s'", oldkey_hex);
return NULL;
}

if (hmac_sha256_kdf(oldkey, sizeof(oldkey), "FT OLDKEY", NULL, 0, key, key_len) < 0) {
wpa_printf(MSG_ERROR, "Invalid RxKH key: '%s'", oldkey_hex);
return NULL;
}

for (i = 0; i < ARRAY_SIZE(key); i++)
sprintf(key_hex + 2 * i, "%02x", key[i]);

return ucv_string_new_length(key_hex, 2 * ARRAY_SIZE(key));
#else
return NULL;
#endif
}

int hostapd_ucode_init(struct hapd_interfaces *ifaces)
{
static const uc_function_list_t global_fns[] = {
Expand Down
34 changes: 0 additions & 34 deletions package/network/services/hostapd/src/src/utils/ucode.c
Original file line number Diff line number Diff line change
Expand Up @@ -237,40 +237,6 @@ uc_value_t *uc_wpa_sha1(uc_vm_t *vm, size_t nargs)
return ucv_string_new_length(hash_hex, 2 * ARRAY_SIZE(hash));
}

uc_value_t *uc_wpa_rkh_derive_key(uc_vm_t *vm, size_t nargs)
{
u8 oldkey[16];
char *oldkey_hex;
u8 key[SHA256_MAC_LEN];
size_t key_len = sizeof(key);
char key_hex[2 * ARRAY_SIZE(key) + 1];
uc_value_t *val = uc_fn_arg(0);
int i;

if (ucv_type(val) != UC_STRING)
return NULL;

oldkey_hex = ucv_string_get(val);

if (!hexstr2bin(oldkey_hex, key, key_len))
return ucv_string_new_length(oldkey_hex, 2 * ARRAY_SIZE(key));

if (hexstr2bin(oldkey_hex, oldkey, sizeof(oldkey))) {
wpa_printf(MSG_ERROR, "Invalid RxKH key: '%s'", oldkey_hex);
return NULL;
}

if (hmac_sha256_kdf(oldkey, sizeof(oldkey), "FT OLDKEY", NULL, 0, key, key_len) < 0) {
wpa_printf(MSG_ERROR, "Invalid RxKH key: '%s'", oldkey_hex);
return NULL;
}

for (i = 0; i < ARRAY_SIZE(key); i++)
sprintf(key_hex + 2 * i, "%02x", key[i]);

return ucv_string_new_length(key_hex, 2 * ARRAY_SIZE(key));
}

uc_vm_t *wpa_ucode_create_vm(void)
{
static uc_parse_config_t config = {
Expand Down
1 change: 0 additions & 1 deletion package/network/services/hostapd/src/src/utils/ucode.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ uc_value_t *uc_wpa_udebug_set(uc_vm_t *vm, size_t nargs);
uc_value_t *uc_wpa_printf(uc_vm_t *vm, size_t nargs);
uc_value_t *uc_wpa_getpid(uc_vm_t *vm, size_t nargs);
uc_value_t *uc_wpa_sha1(uc_vm_t *vm, size_t nargs);
uc_value_t *uc_wpa_rkh_derive_key(uc_vm_t *vm, size_t nargs);
uc_value_t *uc_wpa_freq_info(uc_vm_t *vm, size_t nargs);

#endif

0 comments on commit 225b84d

Please sign in to comment.