#include "ethsw.h"
 
-static struct workqueue_struct *ethsw_owq;
-
 /* Minimal supported DPSW version */
 #define DPSW_MIN_VER_MAJOR             8
 #define DPSW_MIN_VER_MINOR             1
                                unsigned long event, void *ptr)
 {
        struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
+       struct ethsw_port_priv *port_priv = netdev_priv(dev);
        struct ethsw_switchdev_event_work *switchdev_work;
        struct switchdev_notifier_fdb_info *fdb_info = ptr;
+       struct ethsw_core *ethsw = port_priv->ethsw_data;
 
        if (!ethsw_port_dev_check(dev))
                return NOTIFY_DONE;
                return NOTIFY_DONE;
        }
 
-       queue_work(ethsw_owq, &switchdev_work->work);
+       queue_work(ethsw->workqueue, &switchdev_work->work);
 
        return NOTIFY_DONE;
 
                }
        }
 
-       ethsw_owq = alloc_ordered_workqueue("%s_ordered", WQ_MEM_RECLAIM,
-                                           "ethsw");
-       if (!ethsw_owq) {
+       ethsw->workqueue = alloc_ordered_workqueue("%s_%d_ordered",
+                                                  WQ_MEM_RECLAIM, "ethsw",
+                                                  ethsw->sw_attr.id);
+       if (!ethsw->workqueue) {
                err = -ENOMEM;
                goto err_close;
        }
        return 0;
 
 err_destroy_ordered_workqueue:
-       destroy_workqueue(ethsw_owq);
+       destroy_workqueue(ethsw->workqueue);
 
 err_close:
        dpsw_close(ethsw->mc_io, 0, ethsw->dpsw_handle);
 
        ethsw_teardown_irqs(sw_dev);
 
-       destroy_workqueue(ethsw_owq);
+       destroy_workqueue(ethsw->workqueue);
 
        dpsw_disable(ethsw->mc_io, 0, ethsw->dpsw_handle);