struct most_interface *iface)
 {
        struct net_dev_context *nd, *tmp;
+       unsigned long flags;
 
-       spin_lock(&list_lock);
+       spin_lock_irqsave(&list_lock, flags);
        list_for_each_entry_safe(nd, tmp, &net_devices, list) {
                if (nd->iface == iface) {
-                       spin_unlock(&list_lock);
+                       spin_unlock_irqrestore(&list_lock, flags);
                        return nd;
                }
        }
-       spin_unlock(&list_lock);
+       spin_unlock_irqrestore(&list_lock, flags);
        return NULL;
 }
 
 {
        struct net_dev_context *nd;
        struct net_dev_channel *ch;
+       unsigned long flags;
 
        if (!iface)
                return -EINVAL;
 
                nd->iface = iface;
 
-               spin_lock(&list_lock);
+               spin_lock_irqsave(&list_lock, flags);
                list_add(&nd->list, &net_devices);
-               spin_unlock(&list_lock);
+               spin_unlock_irqrestore(&list_lock, flags);
        }
 
        ch = ccfg->direction == MOST_CH_TX ? &nd->tx : &nd->rx;
 {
        struct net_dev_context *nd;
        struct net_dev_channel *ch;
+       unsigned long flags;
 
        nd = get_net_dev_context(iface);
        if (!nd)
        most_net_rm_netdev_safe(nd);
 
        if (!nd->rx.linked && !nd->tx.linked) {
-               spin_lock(&list_lock);
+               spin_lock_irqsave(&list_lock, flags);
                list_del(&nd->list);
-               spin_unlock(&list_lock);
+               spin_unlock_irqrestore(&list_lock, flags);
                kfree(nd);
        }
 
 static void __exit most_net_exit(void)
 {
        struct net_dev_context *nd, *tmp;
+       unsigned long flags;
 
-       spin_lock(&list_lock);
+       spin_lock_irqsave(&list_lock, flags);
        list_for_each_entry_safe(nd, tmp, &net_devices, list) {
                list_del(&nd->list);
-               spin_unlock(&list_lock);
+               spin_unlock_irqrestore(&list_lock, flags);
                /*
                 * do not call most_stop_channel() here, because channels are
                 * going to be closed in ndo_stop() after unregister_netdev()
                 */
                most_net_rm_netdev_safe(nd);
                kfree(nd);
-               spin_lock(&list_lock);
+               spin_lock_irqsave(&list_lock, flags);
        }
-       spin_unlock(&list_lock);
+       spin_unlock_irqrestore(&list_lock, flags);
 
        most_deregister_aim(&aim);
        pr_info("most_net_exit()\n");