net/sfc: avoid usage of NIC pointer from adapter context
authorAndrew Rybchenko <arybchenko@solarflare.com>
Thu, 17 Sep 2020 06:34:37 +0000 (07:34 +0100)
committerFerruh Yigit <ferruh.yigit@intel.com>
Wed, 30 Sep 2020 17:19:08 +0000 (19:19 +0200)
Prepare to avoid usage of the adapter context in common MCDI helpers.

Signed-off-by: Andrew Rybchenko <arybchenko@solarflare.com>
Reviewed-by: Andy Moreton <amoreton@xilinx.com>
drivers/net/sfc/sfc_mcdi.c
drivers/net/sfc/sfc_mcdi.h

index 5f6ad0a..8f446e8 100644 (file)
@@ -75,6 +75,7 @@ sfc_efx_mcdi_proxy_event_available(struct sfc_adapter *sa)
 static void
 sfc_efx_mcdi_poll(struct sfc_adapter *sa, boolean_t proxy)
 {
+       struct sfc_efx_mcdi *mcdi = &sa->mcdi;
        efx_nic_t *enp;
        unsigned int delay_total;
        unsigned int delay_us;
@@ -82,7 +83,7 @@ sfc_efx_mcdi_poll(struct sfc_adapter *sa, boolean_t proxy)
 
        delay_total = 0;
        delay_us = SFC_EFX_MCDI_POLL_INTERVAL_MIN_US;
-       enp = sa->nic;
+       enp = mcdi->nic;
 
        do {
                boolean_t poll_completed;
@@ -127,10 +128,10 @@ sfc_efx_mcdi_execute(void *arg, efx_mcdi_req_t *emrp)
 
        SFC_ASSERT(mcdi->state == SFC_EFX_MCDI_INITIALIZED);
 
-       efx_mcdi_request_start(sa->nic, emrp, B_FALSE);
+       efx_mcdi_request_start(mcdi->nic, emrp, B_FALSE);
        sfc_efx_mcdi_poll(sa, B_FALSE);
 
-       if (efx_mcdi_get_proxy_handle(sa->nic, emrp, &proxy_handle) == 0) {
+       if (efx_mcdi_get_proxy_handle(mcdi->nic, emrp, &proxy_handle) == 0) {
                /*
                 * Authorization is required for the MCDI request;
                 * wait for an MCDI proxy response event to bring
@@ -148,7 +149,7 @@ sfc_efx_mcdi_execute(void *arg, efx_mcdi_req_t *emrp)
                         * Authorization succeeded; re-issue the original
                         * request and poll for an ordinary MCDI response
                         */
-                       efx_mcdi_request_start(sa->nic, emrp, B_FALSE);
+                       efx_mcdi_request_start(mcdi->nic, emrp, B_FALSE);
                        sfc_efx_mcdi_poll(sa, B_FALSE);
                } else {
                        emrp->emr_rc = mcdi->proxy_result;
@@ -267,7 +268,7 @@ sfc_efx_mcdi_ev_proxy_response(void *arg, uint32_t handle, efx_rc_t result)
 
 static int
 sfc_efx_mcdi_init(struct sfc_adapter *sa, struct sfc_efx_mcdi *mcdi,
-                 uint32_t logtype, const char *log_prefix)
+                 uint32_t logtype, const char *log_prefix, efx_nic_t *nic)
 {
        size_t max_msg_size;
        efx_mcdi_transport_t *emtp;
@@ -277,6 +278,8 @@ sfc_efx_mcdi_init(struct sfc_adapter *sa, struct sfc_efx_mcdi *mcdi,
 
        rte_spinlock_init(&mcdi->lock);
 
+       mcdi->nic = nic;
+
        mcdi->state = SFC_EFX_MCDI_INITIALIZED;
 
        mcdi->logtype = logtype;
@@ -298,7 +301,7 @@ sfc_efx_mcdi_init(struct sfc_adapter *sa, struct sfc_efx_mcdi *mcdi,
        emtp->emt_ev_proxy_response = sfc_efx_mcdi_ev_proxy_response;
 
        sfc_efx_mcdi_info(mcdi, "init MCDI");
-       rc = efx_mcdi_init(sa->nic, emtp);
+       rc = efx_mcdi_init(mcdi->nic, emtp);
        if (rc != 0)
                goto fail_mcdi_init;
 
@@ -326,7 +329,7 @@ sfc_efx_mcdi_fini(struct sfc_adapter *sa, struct sfc_efx_mcdi *mcdi)
        mcdi->state = SFC_EFX_MCDI_UNINITIALIZED;
 
        sfc_efx_mcdi_info(mcdi, "fini MCDI");
-       efx_mcdi_fini(sa->nic);
+       efx_mcdi_fini(mcdi->nic);
        memset(emtp, 0, sizeof(*emtp));
 
        rte_spinlock_unlock(&mcdi->lock);
@@ -346,7 +349,7 @@ sfc_mcdi_init(struct sfc_adapter *sa)
                                       RTE_LOG_NOTICE);
 
        return sfc_efx_mcdi_init(sa, &sa->mcdi, logtype,
-                                sa->priv.shared->log_prefix);
+                                sa->priv.shared->log_prefix, sa->nic);
 }
 
 void
index 0194825..e210536 100644 (file)
@@ -33,6 +33,7 @@ enum sfc_efx_mcdi_state {
 
 struct sfc_efx_mcdi {
        rte_spinlock_t                  lock;
+       efx_nic_t                       *nic;
        efsys_mem_t                     mem;
        enum sfc_efx_mcdi_state         state;
        efx_mcdi_transport_t            transport;