diff -Naur a/src/wl/sys/wl_linux.c b/src/wl/sys/wl_linux.c --- a/src/wl/sys/wl_linux.c 2022-06-11 18:19:57.777547764 +0300 +++ b/src/wl/sys/wl_linux.c 2022-06-11 18:20:38.615861293 +0300 @@ -93,6 +93,10 @@ #include +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5, 17, 0)) +#define PDE_DATA pde_data +#endif + static void wl_timer( #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 15, 0) struct timer_list *tl @@ -492,6 +496,12 @@ #endif } +#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 15, 0) +static inline void eth_hw_addr_set(struct net_device *dev, const void *addr) { + memcpy(dev->dev_addr, addr, ETHER_ADDR_LEN); +} +#endif + static wl_info_t * wl_attach(uint16 vendor, uint16 device, ulong regs, uint bustype, void *btparam, uint irq, uchar* bar1_addr, uint32 bar1_size) @@ -643,7 +653,7 @@ WL_ERROR(("wl%d: Error setting MAC ADDRESS\n", unit)); } #endif - bcopy(&wl->pub->cur_etheraddr, dev->dev_addr, ETHER_ADDR_LEN); + eth_hw_addr_set(dev, wl->pub->cur_etheraddr.octet); online_cpus = 1; @@ -1845,7 +1855,7 @@ WL_LOCK(wl); - bcopy(sa->sa_data, dev->dev_addr, ETHER_ADDR_LEN); + eth_hw_addr_set(dev, sa->sa_data); err = wlc_iovar_op(wl->wlc, "cur_etheraddr", NULL, 0, sa->sa_data, ETHER_ADDR_LEN, IOV_SET, (WL_DEV_IF(dev))->wlcif); WL_UNLOCK(wl); @@ -3022,7 +3032,7 @@ else dev->type = ARPHRD_IEEE80211_RADIOTAP; - bcopy(wl->dev->dev_addr, dev->dev_addr, ETHER_ADDR_LEN); + eth_hw_addr_set(dev, wl->dev->dev_addr); #if defined(WL_USE_NETDEV_OPS) dev->netdev_ops = &wl_netdev_monitor_ops;