]> git.baikalelectronics.ru Git - kernel.git/commitdiff
igc: Simplify TSN flags handling
authorVinicius Costa Gomes <vinicius.gomes@intel.com>
Mon, 9 Aug 2021 14:53:39 +0000 (20:23 +0530)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Fri, 27 Aug 2021 16:31:08 +0000 (09:31 -0700)
Separates the procedure done during reset from applying a
configuration, knowing when the code is executing allow us to
separate the better what changes the hardware state from what
changes only the driver state.

Introduces a flag for bookkeeping the driver state of TSN
features. When Qav and frame-preemption is also implemented
this flag makes it easier to keep track on whether a TSN feature
driver state is enabled or not though controller state changes,
say, during a reset.

Signed-off-by: Vinicius Costa Gomes <vinicius.gomes@intel.com>
Signed-off-by: Aravindhan Gunasekaran <aravindhan.gunasekaran@intel.com>
Signed-off-by: Mallikarjuna Chilakala <mallikarjuna.chilakala@intel.com>
Tested-by: Dvora Fuxbrumer <dvorax.fuxbrumer@linux.intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/igc/igc.h
drivers/net/ethernet/intel/igc/igc_main.c
drivers/net/ethernet/intel/igc/igc_tsn.c
drivers/net/ethernet/intel/igc/igc_tsn.h

index 2d17a6da63cf04a89711437027fa797d16b7be3d..b561beb1e623c936967b4c4bb03678eebfc40c83 100644 (file)
@@ -291,6 +291,8 @@ extern char igc_driver_name[];
 #define IGC_FLAG_RX_LEGACY             BIT(16)
 #define IGC_FLAG_TSN_QBV_ENABLED       BIT(17)
 
+#define IGC_FLAG_TSN_ANY_ENABLED       IGC_FLAG_TSN_QBV_ENABLED
+
 #define IGC_FLAG_RSS_FIELD_IPV4_UDP    BIT(6)
 #define IGC_FLAG_RSS_FIELD_IPV6_UDP    BIT(7)
 
index 411d6caa27b5e96f26a7e7a8a74af1be2ea9c8ac..2e5c9b5a57d1eb2f2c79d3892ff9d875fcd88f1b 100644 (file)
@@ -120,7 +120,7 @@ void igc_reset(struct igc_adapter *adapter)
        igc_ptp_reset(adapter);
 
        /* Re-enable TSN offloading, where applicable. */
-       igc_tsn_offload_apply(adapter);
+       igc_tsn_reset(adapter);
 
        igc_get_phy_info(hw);
 }
index 5bcdf758350519f2c1de2a43a1acb8f78257b418..2935d57c593dcc8757fbba3e4b0b67780c760c11 100644 (file)
@@ -18,8 +18,21 @@ static bool is_any_launchtime(struct igc_adapter *adapter)
        return false;
 }
 
+static unsigned int igc_tsn_new_flags(struct igc_adapter *adapter)
+{
+       unsigned int new_flags = adapter->flags & ~IGC_FLAG_TSN_ANY_ENABLED;
+
+       if (adapter->base_time)
+               new_flags |= IGC_FLAG_TSN_QBV_ENABLED;
+
+       if (is_any_launchtime(adapter))
+               new_flags |= IGC_FLAG_TSN_QBV_ENABLED;
+
+       return new_flags;
+}
+
 /* Returns the TSN specific registers to their default values after
- * TSN offloading is disabled.
+ * the adapter is reset.
  */
 static int igc_tsn_disable_offload(struct igc_adapter *adapter)
 {
@@ -27,11 +40,6 @@ static int igc_tsn_disable_offload(struct igc_adapter *adapter)
        u32 tqavctrl;
        int i;
 
-       if (!(adapter->flags & IGC_FLAG_TSN_QBV_ENABLED))
-               return 0;
-
-       adapter->cycle_time = 0;
-
        wr32(IGC_TXPBS, I225_TXPBSIZE_DEFAULT);
        wr32(IGC_DTXMXPKTSZ, IGC_DTXMXPKTSZ_DEFAULT);
 
@@ -62,9 +70,6 @@ static int igc_tsn_enable_offload(struct igc_adapter *adapter)
        ktime_t base_time, systim;
        int i;
 
-       if (adapter->flags & IGC_FLAG_TSN_QBV_ENABLED)
-               return 0;
-
        cycle = adapter->cycle_time;
        base_time = adapter->base_time;
 
@@ -119,33 +124,41 @@ static int igc_tsn_enable_offload(struct igc_adapter *adapter)
        wr32(IGC_BASET_H, baset_h);
        wr32(IGC_BASET_L, baset_l);
 
-       adapter->flags |= IGC_FLAG_TSN_QBV_ENABLED;
-
        return 0;
 }
 
-int igc_tsn_offload_apply(struct igc_adapter *adapter)
+int igc_tsn_reset(struct igc_adapter *adapter)
 {
-       bool is_any_enabled = adapter->base_time || is_any_launchtime(adapter);
+       unsigned int new_flags;
+       int err = 0;
 
-       if (!(adapter->flags & IGC_FLAG_TSN_QBV_ENABLED) && !is_any_enabled)
-               return 0;
+       new_flags = igc_tsn_new_flags(adapter);
+
+       if (!(new_flags & IGC_FLAG_TSN_ANY_ENABLED))
+               return igc_tsn_disable_offload(adapter);
+
+       err = igc_tsn_enable_offload(adapter);
+       if (err < 0)
+               return err;
 
-       if (!is_any_enabled) {
-               int err = igc_tsn_disable_offload(adapter);
+       adapter->flags = new_flags;
 
-               if (err < 0)
-                       return err;
+       return err;
+}
 
-               /* The BASET registers aren't cleared when writing
-                * into them, force a reset if the interface is
-                * running.
-                */
-               if (netif_running(adapter->netdev))
-                       schedule_work(&adapter->reset_task);
+int igc_tsn_offload_apply(struct igc_adapter *adapter)
+{
+       int err;
 
+       if (netif_running(adapter->netdev)) {
+               schedule_work(&adapter->reset_task);
                return 0;
        }
 
-       return igc_tsn_enable_offload(adapter);
+       err = igc_tsn_enable_offload(adapter);
+       if (err < 0)
+               return err;
+
+       adapter->flags = igc_tsn_new_flags(adapter);
+       return 0;
 }
index f76bc86ddccd9c1c1d50ee836ab1a1139409c436..1512307f5a528fe92d8f979ad7e40a31dc2ccc67 100644 (file)
@@ -5,5 +5,6 @@
 #define _IGC_TSN_H_
 
 int igc_tsn_offload_apply(struct igc_adapter *adapter);
+int igc_tsn_reset(struct igc_adapter *adapter);
 
 #endif /* _IGC_BASE_H */