static int prestera_port_vlans_add(struct prestera_port *port,
                                   const struct switchdev_obj_port_vlan *vlan,
-                                  struct switchdev_trans *trans,
                                   struct netlink_ext_ack *extack)
 {
        bool flag_untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
        if (netif_is_bridge_master(dev))
                return 0;
 
-       if (switchdev_trans_ph_commit(trans))
-               return 0;
-
        br_port = prestera_bridge_port_by_dev(sw->swdev, dev);
        if (WARN_ON(!br_port))
                return -EINVAL;
 
 static int prestera_port_obj_add(struct net_device *dev,
                                 const struct switchdev_obj *obj,
-                                struct switchdev_trans *trans,
                                 struct netlink_ext_ack *extack)
 {
        struct prestera_port *port = netdev_priv(dev);
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
                vlan = SWITCHDEV_OBJ_PORT_VLAN(obj);
-               return prestera_port_vlans_add(port, vlan, trans, extack);
+               return prestera_port_vlans_add(port, vlan, extack);
        default:
                return -EOPNOTSUPP;
        }
 
 }
 
 static int mlxsw_sp_port_mdb_add(struct mlxsw_sp_port *mlxsw_sp_port,
-                                const struct switchdev_obj_port_mdb *mdb,
-                                struct switchdev_trans *trans)
+                                const struct switchdev_obj_port_mdb *mdb)
 {
        struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
        struct net_device *orig_dev = mdb->obj.orig_dev;
        u16 fid_index;
        int err = 0;
 
-       if (switchdev_trans_ph_commit(trans))
-               return 0;
-
        bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
        if (!bridge_port)
                return 0;
 
 static int mlxsw_sp_port_obj_add(struct net_device *dev,
                                 const struct switchdev_obj *obj,
-                                struct switchdev_trans *trans,
                                 struct netlink_ext_ack *extack)
 {
        struct mlxsw_sp_port *mlxsw_sp_port = netdev_priv(dev);
        const struct switchdev_obj_port_vlan *vlan;
+       struct switchdev_trans trans;
        int err = 0;
 
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
                vlan = SWITCHDEV_OBJ_PORT_VLAN(obj);
-               err = mlxsw_sp_port_vlans_add(mlxsw_sp_port, vlan, trans,
+
+               trans.ph_prepare = true;
+               err = mlxsw_sp_port_vlans_add(mlxsw_sp_port, vlan, &trans,
                                              extack);
 
-               if (switchdev_trans_ph_prepare(trans)) {
-                       /* The event is emitted before the changes are actually
-                        * applied to the bridge. Therefore schedule the respin
-                        * call for later, so that the respin logic sees the
-                        * updated bridge state.
-                        */
-                       mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
-               }
+               /* The event is emitted before the changes are actually
+                * applied to the bridge. Therefore schedule the respin
+                * call for later, so that the respin logic sees the
+                * updated bridge state.
+                */
+               mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
+
+               if (err)
+                       break;
+
+               trans.ph_prepare = false;
+               err = mlxsw_sp_port_vlans_add(mlxsw_sp_port, vlan, &trans,
+                                             extack);
                break;
        case SWITCHDEV_OBJ_ID_PORT_MDB:
                err = mlxsw_sp_port_mdb_add(mlxsw_sp_port,
-                                           SWITCHDEV_OBJ_PORT_MDB(obj),
-                                           trans);
+                                           SWITCHDEV_OBJ_PORT_MDB(obj));
                break;
        default:
                err = -EOPNOTSUPP;
 static int
 mlxsw_sp_switchdev_vxlan_vlans_add(struct net_device *vxlan_dev,
                                   struct switchdev_notifier_port_obj_info *
-                                  port_obj_info)
+                                  port_obj_info,
+                                  struct switchdev_trans *trans)
 {
        struct switchdev_obj_port_vlan *vlan =
                SWITCHDEV_OBJ_PORT_VLAN(port_obj_info->obj);
        bool flag_untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
        bool flag_pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
-       struct switchdev_trans *trans = port_obj_info->trans;
        struct mlxsw_sp_bridge_device *bridge_device;
        struct netlink_ext_ack *extack;
        struct mlxsw_sp *mlxsw_sp;
                                        struct switchdev_notifier_port_obj_info *
                                        port_obj_info)
 {
+       struct switchdev_trans trans;
        int err = 0;
 
        switch (port_obj_info->obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
+               trans.ph_prepare = true;
+               err = mlxsw_sp_switchdev_vxlan_vlans_add(vxlan_dev,
+                                                        port_obj_info,
+                                                        &trans);
+               if (err)
+                       break;
+
+               trans.ph_prepare = false;
                err = mlxsw_sp_switchdev_vxlan_vlans_add(vxlan_dev,
-                                                        port_obj_info);
+                                                        port_obj_info,
+                                                        &trans);
                break;
        default:
                break;
 
 }
 
 static int ocelot_port_obj_add_vlan(struct net_device *dev,
-                                   const struct switchdev_obj_port_vlan *vlan,
-                                   struct switchdev_trans *trans)
+                                   const struct switchdev_obj_port_vlan *vlan)
 {
        bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
        bool pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
        int ret;
 
-       if (switchdev_trans_ph_prepare(trans))
-               ret = ocelot_vlan_vid_prepare(dev, vlan->vid, pvid, untagged);
-       else
-               ret = ocelot_vlan_vid_add(dev, vlan->vid, pvid, untagged);
+       ret = ocelot_vlan_vid_prepare(dev, vlan->vid, pvid, untagged);
+       if (ret)
+               return ret;
 
-       return ret;
+       return ocelot_vlan_vid_add(dev, vlan->vid, pvid, untagged);
 }
 
 static int ocelot_port_obj_add_mdb(struct net_device *dev,
-                                  const struct switchdev_obj_port_mdb *mdb,
-                                  struct switchdev_trans *trans)
+                                  const struct switchdev_obj_port_mdb *mdb)
 {
        struct ocelot_port_private *priv = netdev_priv(dev);
        struct ocelot_port *ocelot_port = &priv->port;
        struct ocelot *ocelot = ocelot_port->ocelot;
        int port = priv->chip_port;
 
-       if (switchdev_trans_ph_prepare(trans))
-               return 0;
-
        return ocelot_port_mdb_add(ocelot, port, mdb);
 }
 
 
 static int ocelot_port_obj_add(struct net_device *dev,
                               const struct switchdev_obj *obj,
-                              struct switchdev_trans *trans,
                               struct netlink_ext_ack *extack)
 {
        int ret = 0;
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
                ret = ocelot_port_obj_add_vlan(dev,
-                                              SWITCHDEV_OBJ_PORT_VLAN(obj),
-                                              trans);
+                                              SWITCHDEV_OBJ_PORT_VLAN(obj));
                break;
        case SWITCHDEV_OBJ_ID_PORT_MDB:
-               ret = ocelot_port_obj_add_mdb(dev, SWITCHDEV_OBJ_PORT_MDB(obj),
-                                             trans);
+               ret = ocelot_port_obj_add_mdb(dev, SWITCHDEV_OBJ_PORT_MDB(obj));
                break;
        default:
                return -EOPNOTSUPP;
 
 
 static int
 rocker_world_port_obj_vlan_add(struct rocker_port *rocker_port,
-                              const struct switchdev_obj_port_vlan *vlan,
-                              struct switchdev_trans *trans)
+                              const struct switchdev_obj_port_vlan *vlan)
 {
        struct rocker_world_ops *wops = rocker_port->rocker->wops;
 
        if (!wops->port_obj_vlan_add)
                return -EOPNOTSUPP;
 
-       if (switchdev_trans_ph_prepare(trans))
-               return 0;
-
        return wops->port_obj_vlan_add(rocker_port, vlan);
 }
 
 }
 
 static int rocker_port_obj_add(struct net_device *dev,
-                              const struct switchdev_obj *obj,
-                              struct switchdev_trans *trans)
+                              const struct switchdev_obj *obj)
 {
        struct rocker_port *rocker_port = netdev_priv(dev);
        int err = 0;
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
                err = rocker_world_port_obj_vlan_add(rocker_port,
-                                                    SWITCHDEV_OBJ_PORT_VLAN(obj),
-                                                    trans);
+                                                    SWITCHDEV_OBJ_PORT_VLAN(obj));
                break;
        default:
                err = -EOPNOTSUPP;
 
        switch (event) {
        case SWITCHDEV_PORT_OBJ_ADD:
-               err = rocker_port_obj_add(netdev, port_obj_info->obj,
-                                         port_obj_info->trans);
+               err = rocker_port_obj_add(netdev, port_obj_info->obj);
                break;
        case SWITCHDEV_PORT_OBJ_DEL:
                err = rocker_port_obj_del(netdev, port_obj_info->obj);
 
 }
 
 static int cpsw_port_vlans_add(struct cpsw_priv *priv,
-                              const struct switchdev_obj_port_vlan *vlan,
-                              struct switchdev_trans *trans)
+                              const struct switchdev_obj_port_vlan *vlan)
 {
        bool untag = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
        struct net_device *orig_dev = vlan->obj.orig_dev;
        if (cpu_port && !(vlan->flags & BRIDGE_VLAN_INFO_BRENTRY))
                return 0;
 
-       if (switchdev_trans_ph_prepare(trans))
-               return 0;
-
        return cpsw_port_vlan_add(priv, untag, pvid, vlan->vid, orig_dev);
 }
 
 static int cpsw_port_mdb_add(struct cpsw_priv *priv,
-                            struct switchdev_obj_port_mdb *mdb,
-                            struct switchdev_trans *trans)
+                            struct switchdev_obj_port_mdb *mdb)
 
 {
        struct net_device *orig_dev = mdb->obj.orig_dev;
        int port_mask;
        int err;
 
-       if (switchdev_trans_ph_prepare(trans))
-               return 0;
-
        if (cpu_port)
                port_mask = BIT(HOST_PORT_NUM);
        else
 
 static int cpsw_port_obj_add(struct net_device *ndev,
                             const struct switchdev_obj *obj,
-                            struct switchdev_trans *trans,
                             struct netlink_ext_ack *extack)
 {
        struct switchdev_obj_port_vlan *vlan = SWITCHDEV_OBJ_PORT_VLAN(obj);
 
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
-               err = cpsw_port_vlans_add(priv, vlan, trans);
+               err = cpsw_port_vlans_add(priv, vlan);
                break;
        case SWITCHDEV_OBJ_ID_PORT_MDB:
        case SWITCHDEV_OBJ_ID_HOST_MDB:
-               err = cpsw_port_mdb_add(priv, mdb, trans);
+               err = cpsw_port_mdb_add(priv, mdb);
                break;
        default:
                err = -EOPNOTSUPP;
 
 }
 
 static int dpaa2_switch_port_vlans_add(struct net_device *netdev,
-                                      const struct switchdev_obj_port_vlan *vlan,
-                                      struct switchdev_trans *trans)
+                                      const struct switchdev_obj_port_vlan *vlan)
 {
        struct ethsw_port_priv *port_priv = netdev_priv(netdev);
        struct ethsw_core *ethsw = port_priv->ethsw_data;
        struct dpsw_attr *attr = ðsw->sw_attr;
        int err = 0;
 
-       if (switchdev_trans_ph_prepare(trans)) {
-               /* Make sure that the VLAN is not already configured
-                * on the switch port
-                */
-               if (port_priv->vlans[vlan->vid] & ETHSW_VLAN_MEMBER)
-                       return -EEXIST;
+       /* Make sure that the VLAN is not already configured
+        * on the switch port
+        */
+       if (port_priv->vlans[vlan->vid] & ETHSW_VLAN_MEMBER)
+               return -EEXIST;
 
-               /* Check if there is space for a new VLAN */
-               err = dpsw_get_attributes(ethsw->mc_io, 0, ethsw->dpsw_handle,
-                                         ðsw->sw_attr);
-               if (err) {
-                       netdev_err(netdev, "dpsw_get_attributes err %d\n", err);
-                       return err;
-               }
-               if (attr->max_vlans - attr->num_vlans < 1)
-                       return -ENOSPC;
+       /* Check if there is space for a new VLAN */
+       err = dpsw_get_attributes(ethsw->mc_io, 0, ethsw->dpsw_handle,
+                                 ðsw->sw_attr);
+       if (err) {
+               netdev_err(netdev, "dpsw_get_attributes err %d\n", err);
+               return err;
+       }
+       if (attr->max_vlans - attr->num_vlans < 1)
+               return -ENOSPC;
 
-               return 0;
+       /* Check if there is space for a new VLAN */
+       err = dpsw_get_attributes(ethsw->mc_io, 0, ethsw->dpsw_handle,
+                                 ðsw->sw_attr);
+       if (err) {
+               netdev_err(netdev, "dpsw_get_attributes err %d\n", err);
+               return err;
        }
+       if (attr->max_vlans - attr->num_vlans < 1)
+               return -ENOSPC;
 
        if (!port_priv->ethsw_data->vlans[vlan->vid]) {
                /* this is a new VLAN */
 }
 
 static int dpaa2_switch_port_mdb_add(struct net_device *netdev,
-                                    const struct switchdev_obj_port_mdb *mdb,
-                                    struct switchdev_trans *trans)
+                                    const struct switchdev_obj_port_mdb *mdb)
 {
        struct ethsw_port_priv *port_priv = netdev_priv(netdev);
        int err;
 
-       if (switchdev_trans_ph_prepare(trans))
-               return 0;
-
        /* Check if address is already set on this port */
        if (dpaa2_switch_port_lookup_address(netdev, 0, mdb->addr))
                return -EEXIST;
 }
 
 static int dpaa2_switch_port_obj_add(struct net_device *netdev,
-                                    const struct switchdev_obj *obj,
-                                    struct switchdev_trans *trans)
+                                    const struct switchdev_obj *obj)
 {
        int err;
 
        switch (obj->id) {
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
                err = dpaa2_switch_port_vlans_add(netdev,
-                                                 SWITCHDEV_OBJ_PORT_VLAN(obj),
-                                                 trans);
+                                                 SWITCHDEV_OBJ_PORT_VLAN(obj));
                break;
        case SWITCHDEV_OBJ_ID_PORT_MDB:
                err = dpaa2_switch_port_mdb_add(netdev,
-                                               SWITCHDEV_OBJ_PORT_MDB(obj),
-                                               trans);
+                                               SWITCHDEV_OBJ_PORT_MDB(obj));
                break;
        default:
                err = -EOPNOTSUPP;
 
        switch (event) {
        case SWITCHDEV_PORT_OBJ_ADD:
-               err = dpaa2_switch_port_obj_add(netdev, port_obj_info->obj,
-                                               port_obj_info->trans);
+               err = dpaa2_switch_port_obj_add(netdev, port_obj_info->obj);
                break;
        case SWITCHDEV_PORT_OBJ_DEL:
                err = dpaa2_switch_port_obj_del(netdev, port_obj_info->obj);
 
 struct switchdev_notifier_port_obj_info {
        struct switchdev_notifier_info info; /* must be first */
        const struct switchdev_obj *obj;
-       struct switchdev_trans *trans;
        bool handled;
 };
 
                        bool (*check_cb)(const struct net_device *dev),
                        int (*add_cb)(struct net_device *dev,
                                      const struct switchdev_obj *obj,
-                                     struct switchdev_trans *trans,
                                      struct netlink_ext_ack *extack));
 int switchdev_handle_port_obj_del(struct net_device *dev,
                        struct switchdev_notifier_port_obj_info *port_obj_info,
                        bool (*check_cb)(const struct net_device *dev),
                        int (*add_cb)(struct net_device *dev,
                                      const struct switchdev_obj *obj,
-                                     struct switchdev_trans *trans,
                                      struct netlink_ext_ack *extack))
 {
        return 0;
 
 /* DSA_NOTIFIER_MDB_* */
 struct dsa_notifier_mdb_info {
        const struct switchdev_obj_port_mdb *mdb;
-       struct switchdev_trans *trans;
        int sw_index;
        int port;
 };
 /* DSA_NOTIFIER_VLAN_* */
 struct dsa_notifier_vlan_info {
        const struct switchdev_obj_port_vlan *vlan;
-       struct switchdev_trans *trans;
        int sw_index;
        int port;
 };
                     u16 vid);
 int dsa_port_fdb_dump(struct dsa_port *dp, dsa_fdb_dump_cb_t *cb, void *data);
 int dsa_port_mdb_add(const struct dsa_port *dp,
-                    const struct switchdev_obj_port_mdb *mdb,
-                    struct switchdev_trans *trans);
+                    const struct switchdev_obj_port_mdb *mdb);
 int dsa_port_mdb_del(const struct dsa_port *dp,
                     const struct switchdev_obj_port_mdb *mdb);
 int dsa_port_pre_bridge_flags(const struct dsa_port *dp, unsigned long flags,
 int dsa_port_mrouter(struct dsa_port *dp, bool mrouter,
                     struct switchdev_trans *trans);
 int dsa_port_vlan_add(struct dsa_port *dp,
-                     const struct switchdev_obj_port_vlan *vlan,
-                     struct switchdev_trans *trans);
+                     const struct switchdev_obj_port_vlan *vlan);
 int dsa_port_vlan_del(struct dsa_port *dp,
                      const struct switchdev_obj_port_vlan *vlan);
 int dsa_port_link_register_of(struct dsa_port *dp);
 
 }
 
 int dsa_port_mdb_add(const struct dsa_port *dp,
-                    const struct switchdev_obj_port_mdb *mdb,
-                    struct switchdev_trans *trans)
+                    const struct switchdev_obj_port_mdb *mdb)
 {
        struct dsa_notifier_mdb_info info = {
                .sw_index = dp->ds->index,
                .port = dp->index,
-               .trans = trans,
                .mdb = mdb,
        };
 
 }
 
 int dsa_port_vlan_add(struct dsa_port *dp,
-                     const struct switchdev_obj_port_vlan *vlan,
-                     struct switchdev_trans *trans)
+                     const struct switchdev_obj_port_vlan *vlan)
 {
        struct dsa_notifier_vlan_info info = {
                .sw_index = dp->ds->index,
                .port = dp->index,
-               .trans = trans,
                .vlan = vlan,
        };
 
 
 }
 
 static int dsa_slave_vlan_add(struct net_device *dev,
-                             const struct switchdev_obj *obj,
-                             struct switchdev_trans *trans)
+                             const struct switchdev_obj *obj)
 {
        struct net_device *master = dsa_slave_to_master(dev);
        struct dsa_port *dp = dsa_slave_to_port(dev);
        /* Deny adding a bridge VLAN when there is already an 802.1Q upper with
         * the same VID.
         */
-       if (trans->ph_prepare && br_vlan_enabled(dp->bridge_dev)) {
+       if (br_vlan_enabled(dp->bridge_dev)) {
                rcu_read_lock();
                err = dsa_slave_vlan_check_for_8021q_uppers(dev, &vlan);
                rcu_read_unlock();
                        return err;
        }
 
-       err = dsa_port_vlan_add(dp, &vlan, trans);
+       err = dsa_port_vlan_add(dp, &vlan);
        if (err)
                return err;
 
         */
        vlan.flags &= ~BRIDGE_VLAN_INFO_PVID;
 
-       err = dsa_port_vlan_add(dp->cpu_dp, &vlan, trans);
+       err = dsa_port_vlan_add(dp->cpu_dp, &vlan);
        if (err)
                return err;
 
 
 static int dsa_slave_port_obj_add(struct net_device *dev,
                                  const struct switchdev_obj *obj,
-                                 struct switchdev_trans *trans,
                                  struct netlink_ext_ack *extack)
 {
        struct dsa_port *dp = dsa_slave_to_port(dev);
        case SWITCHDEV_OBJ_ID_PORT_MDB:
                if (obj->orig_dev != dev)
                        return -EOPNOTSUPP;
-               err = dsa_port_mdb_add(dp, SWITCHDEV_OBJ_PORT_MDB(obj), trans);
+               err = dsa_port_mdb_add(dp, SWITCHDEV_OBJ_PORT_MDB(obj));
                break;
        case SWITCHDEV_OBJ_ID_HOST_MDB:
                /* DSA can directly translate this to a normal MDB add,
                 * but on the CPU port.
                 */
-               err = dsa_port_mdb_add(dp->cpu_dp, SWITCHDEV_OBJ_PORT_MDB(obj),
-                                      trans);
+               err = dsa_port_mdb_add(dp->cpu_dp, SWITCHDEV_OBJ_PORT_MDB(obj));
                break;
        case SWITCHDEV_OBJ_ID_PORT_VLAN:
-               err = dsa_slave_vlan_add(dev, obj, trans);
+               err = dsa_slave_vlan_add(dev, obj);
                break;
        default:
                err = -EOPNOTSUPP;
                /* This API only allows programming tagged, non-PVID VIDs */
                .flags = 0,
        };
-       struct switchdev_trans trans;
        int ret;
 
        /* User port... */
-       trans.ph_prepare = true;
-       ret = dsa_port_vlan_add(dp, &vlan, &trans);
-       if (ret)
-               return ret;
-
-       trans.ph_prepare = false;
-       ret = dsa_port_vlan_add(dp, &vlan, &trans);
+       ret = dsa_port_vlan_add(dp, &vlan);
        if (ret)
                return ret;
 
        /* And CPU port... */
-       trans.ph_prepare = true;
-       ret = dsa_port_vlan_add(dp->cpu_dp, &vlan, &trans);
-       if (ret)
-               return ret;
-
-       trans.ph_prepare = false;
-       ret = dsa_port_vlan_add(dp->cpu_dp, &vlan, &trans);
+       ret = dsa_port_vlan_add(dp->cpu_dp, &vlan);
        if (ret)
                return ret;
 
 
        return false;
 }
 
-static int dsa_switch_mdb_prepare(struct dsa_switch *ds,
-                                 struct dsa_notifier_mdb_info *info)
+static int dsa_switch_mdb_add(struct dsa_switch *ds,
+                             struct dsa_notifier_mdb_info *info)
 {
        int port, err;
 
                }
        }
 
-       return 0;
-}
-
-static int dsa_switch_mdb_add(struct dsa_switch *ds,
-                             struct dsa_notifier_mdb_info *info)
-{
-       int port;
-
-       if (switchdev_trans_ph_prepare(info->trans))
-               return dsa_switch_mdb_prepare(ds, info);
-
-       if (!ds->ops->port_mdb_add)
-               return 0;
-
        for (port = 0; port < ds->num_ports; port++)
                if (dsa_switch_mdb_match(ds, port, info))
                        ds->ops->port_mdb_add(ds, port, info->mdb);
        return false;
 }
 
-static int dsa_switch_vlan_prepare(struct dsa_switch *ds,
-                                  struct dsa_notifier_vlan_info *info)
+static int dsa_switch_vlan_add(struct dsa_switch *ds,
+                              struct dsa_notifier_vlan_info *info)
 {
        int port, err;
 
                }
        }
 
-       return 0;
-}
-
-static int dsa_switch_vlan_add(struct dsa_switch *ds,
-                              struct dsa_notifier_vlan_info *info)
-{
-       int port;
-
-       if (switchdev_trans_ph_prepare(info->trans))
-               return dsa_switch_vlan_prepare(ds, info);
-
-       if (!ds->ops->port_vlan_add)
-               return 0;
-
        for (port = 0; port < ds->num_ports; port++)
                if (dsa_switch_vlan_match(ds, port, info))
                        ds->ops->port_vlan_add(ds, port, info->vlan);
 
 static int switchdev_port_obj_notify(enum switchdev_notifier_type nt,
                                     struct net_device *dev,
                                     const struct switchdev_obj *obj,
-                                    struct switchdev_trans *trans,
                                     struct netlink_ext_ack *extack)
 {
        int rc;
 
        struct switchdev_notifier_port_obj_info obj_info = {
                .obj = obj,
-               .trans = trans,
                .handled = false,
        };
 
                                      const struct switchdev_obj *obj,
                                      struct netlink_ext_ack *extack)
 {
-       struct switchdev_trans trans;
-       int err;
-
        ASSERT_RTNL();
 
-       /* Phase I: prepare for obj add. Driver/device should fail
-        * here if there are going to be issues in the commit phase,
-        * such as lack of resources or support.  The driver/device
-        * should reserve resources needed for the commit phase here,
-        * but should not commit the obj.
-        */
-
-       trans.ph_prepare = true;
-       err = switchdev_port_obj_notify(SWITCHDEV_PORT_OBJ_ADD,
-                                       dev, obj, &trans, extack);
-       if (err)
-               return err;
-
-       /* Phase II: commit obj add.  This cannot fail as a fault
-        * of driver/device.  If it does, it's a bug in the driver/device
-        * because the driver said everythings was OK in phase I.
-        */
-
-       trans.ph_prepare = false;
-       err = switchdev_port_obj_notify(SWITCHDEV_PORT_OBJ_ADD,
-                                       dev, obj, &trans, extack);
-       WARN(err, "%s: Commit of object (id=%d) failed.\n", dev->name, obj->id);
-
-       return err;
+       return switchdev_port_obj_notify(SWITCHDEV_PORT_OBJ_ADD,
+                                        dev, obj, extack);
 }
 
 static void switchdev_port_obj_add_deferred(struct net_device *dev,
  *     @obj: object to add
  *     @extack: netlink extended ack
  *
- *     Use a 2-phase prepare-commit transaction model to ensure
- *     system is not left in a partially updated state due to
- *     failure from driver/device.
- *
  *     rtnl_lock must be held and must not be in atomic section,
  *     in case SWITCHDEV_F_DEFER flag is not set.
  */
                                      const struct switchdev_obj *obj)
 {
        return switchdev_port_obj_notify(SWITCHDEV_PORT_OBJ_DEL,
-                                        dev, obj, NULL, NULL);
+                                        dev, obj, NULL);
 }
 
 static void switchdev_port_obj_del_deferred(struct net_device *dev,
                        bool (*check_cb)(const struct net_device *dev),
                        int (*add_cb)(struct net_device *dev,
                                      const struct switchdev_obj *obj,
-                                     struct switchdev_trans *trans,
                                      struct netlink_ext_ack *extack))
 {
        struct netlink_ext_ack *extack;
        if (check_cb(dev)) {
                /* This flag is only checked if the return value is success. */
                port_obj_info->handled = true;
-               return add_cb(dev, port_obj_info->obj, port_obj_info->trans,
-                             extack);
+               return add_cb(dev, port_obj_info->obj, extack);
        }
 
        /* Switch ports might be stacked under e.g. a LAG. Ignore the
                        bool (*check_cb)(const struct net_device *dev),
                        int (*add_cb)(struct net_device *dev,
                                      const struct switchdev_obj *obj,
-                                     struct switchdev_trans *trans,
                                      struct netlink_ext_ack *extack))
 {
        int err;