]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: ipa: have gsi_channel_update() return a value
authorAlex Elder <elder@linaro.org>
Thu, 21 Jan 2021 11:48:19 +0000 (05:48 -0600)
committerJakub Kicinski <kuba@kernel.org>
Sat, 23 Jan 2021 21:16:00 +0000 (13:16 -0800)
Have gsi_channel_update() return the first transaction in the
updated completed transaction list, or NULL if no new transactions
have been added.

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ipa/gsi.c

index 634f514e861e79151f7e35c3ee424484d8086201..6e5817e16c0f680f82822c19634f9e938a149324 100644 (file)
@@ -1452,7 +1452,7 @@ void gsi_channel_doorbell(struct gsi_channel *channel)
 }
 
 /* Consult hardware, move any newly completed transactions to completed list */
-static void gsi_channel_update(struct gsi_channel *channel)
+static struct gsi_trans *gsi_channel_update(struct gsi_channel *channel)
 {
        u32 evt_ring_id = channel->evt_ring_id;
        struct gsi *gsi = channel->gsi;
@@ -1471,7 +1471,7 @@ static void gsi_channel_update(struct gsi_channel *channel)
        offset = GSI_EV_CH_E_CNTXT_4_OFFSET(evt_ring_id);
        index = gsi_ring_index(ring, ioread32(gsi->virt + offset));
        if (index == ring->index % ring->count)
-               return;
+               return NULL;
 
        /* Get the transaction for the latest completed event.  Take a
         * reference to keep it from completing before we give the events
@@ -1496,6 +1496,8 @@ static void gsi_channel_update(struct gsi_channel *channel)
        gsi_evt_ring_doorbell(channel->gsi, channel->evt_ring_id, index);
 
        gsi_trans_free(trans);
+
+       return gsi_channel_trans_complete(channel);
 }
 
 /**
@@ -1516,11 +1518,8 @@ static struct gsi_trans *gsi_channel_poll_one(struct gsi_channel *channel)
 
        /* Get the first transaction from the completed list */
        trans = gsi_channel_trans_complete(channel);
-       if (!trans) {
-               /* List is empty; see if there's more to do */
-               gsi_channel_update(channel);
-               trans = gsi_channel_trans_complete(channel);
-       }
+       if (!trans)     /* List is empty; see if there's more to do */
+               trans = gsi_channel_update(channel);
 
        if (trans)
                gsi_trans_move_polled(trans);