|
@@ -149,76 +149,23 @@ static void __macsec_drv_deinit(struct macsec_qca_data *drv)
|
|
|
static void * macsec_qca_init(void *ctx, const char *ifname)
|
|
|
{
|
|
|
struct macsec_qca_data *drv;
|
|
|
- int flags;
|
|
|
|
|
|
drv = os_zalloc(sizeof(*drv));
|
|
|
if (drv == NULL)
|
|
|
return NULL;
|
|
|
- os_strlcpy(drv->common.ifname, ifname, sizeof(drv->common.ifname));
|
|
|
- drv->common.ctx = ctx;
|
|
|
|
|
|
/* Board specific settings */
|
|
|
- if (os_memcmp("eth2", drv->common.ifname, 4) == 0)
|
|
|
+ if (os_memcmp("eth2", ifname, 4) == 0)
|
|
|
drv->secy_id = 1;
|
|
|
- else if (os_memcmp("eth3", drv->common.ifname, 4) == 0)
|
|
|
+ else if (os_memcmp("eth3", ifname, 4) == 0)
|
|
|
drv->secy_id = 2;
|
|
|
else
|
|
|
drv->secy_id = -1;
|
|
|
|
|
|
-#ifdef __linux__
|
|
|
- drv->common.pf_sock = socket(PF_PACKET, SOCK_DGRAM, 0);
|
|
|
- if (drv->common.pf_sock < 0)
|
|
|
- wpa_printf(MSG_ERROR, "socket(PF_PACKET): %s", strerror(errno));
|
|
|
-#else /* __linux__ */
|
|
|
- drv->common.pf_sock = -1;
|
|
|
-#endif /* __linux__ */
|
|
|
-
|
|
|
- if (driver_wired_get_ifflags(ifname, &flags) == 0 &&
|
|
|
- !(flags & IFF_UP) &&
|
|
|
- driver_wired_set_ifflags(ifname, flags | IFF_UP) == 0) {
|
|
|
- drv->common.iff_up = 1;
|
|
|
- }
|
|
|
-
|
|
|
- if (wired_multicast_membership(drv->common.pf_sock,
|
|
|
- if_nametoindex(drv->common.ifname),
|
|
|
- pae_group_addr, 1) == 0) {
|
|
|
- wpa_printf(MSG_DEBUG,
|
|
|
- "%s: Added multicast membership with packet socket",
|
|
|
- __func__);
|
|
|
- drv->common.membership = 1;
|
|
|
- } else if (driver_wired_multi(ifname, pae_group_addr, 1) == 0) {
|
|
|
- wpa_printf(MSG_DEBUG,
|
|
|
- "%s: Added multicast membership with SIOCADDMULTI",
|
|
|
- __func__);
|
|
|
- drv->common.multi = 1;
|
|
|
- } else if (driver_wired_get_ifflags(ifname, &flags) < 0) {
|
|
|
- wpa_printf(MSG_INFO, "%s: Could not get interface flags",
|
|
|
- __func__);
|
|
|
- os_free(drv);
|
|
|
- return NULL;
|
|
|
- } else if (flags & IFF_ALLMULTI) {
|
|
|
- wpa_printf(MSG_DEBUG,
|
|
|
- "%s: Interface is already configured for multicast",
|
|
|
- __func__);
|
|
|
- } else if (driver_wired_set_ifflags(ifname, flags | IFF_ALLMULTI) < 0) {
|
|
|
- wpa_printf(MSG_INFO, "%s: Failed to enable allmulti",
|
|
|
- __func__);
|
|
|
+ if (driver_wired_init_common(&drv->common, ifname, ctx) < 0) {
|
|
|
os_free(drv);
|
|
|
return NULL;
|
|
|
- } else {
|
|
|
- wpa_printf(MSG_DEBUG, "%s: Enabled allmulti mode", __func__);
|
|
|
- drv->common.iff_allmulti = 1;
|
|
|
- }
|
|
|
-#if defined(__FreeBSD__) || defined(__DragonFly__) || defined(__FreeBSD_kernel__)
|
|
|
- {
|
|
|
- int status;
|
|
|
- wpa_printf(MSG_DEBUG, "%s: waiting for link to become active",
|
|
|
- __func__);
|
|
|
- while (driver_wired_get_ifstatus(ifname, &status) == 0 &&
|
|
|
- status == 0)
|
|
|
- sleep(1);
|
|
|
}
|
|
|
-#endif /* defined(__FreeBSD__) || defined(__DragonFly__) || defined(FreeBSD_kernel__) */
|
|
|
|
|
|
return drv;
|
|
|
}
|