staging: vchiq_shim: avoid code duplication
authorStefan Wahren <stefan.wahren@i2se.com>
Wed, 26 Oct 2016 18:34:19 +0000 (18:34 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 27 Oct 2016 13:23:53 +0000 (15:23 +0200)
Rearrange the polling loops in order to avoid code duplication. Btw we fix
the style of the comments.

Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com>
Reviewed-by: Eric Anholt <eric@anholt.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/vc04_services/interface/vchiq_arm/vchiq_shim.c

index 49f9d6a8f78d592c6a1bb9ed4f64df9c53308722..7694627b925c743552b093ce51d15c2f2fe71a69 100644 (file)
@@ -172,15 +172,18 @@ int32_t vchi_msg_queue(VCHI_SERVICE_HANDLE_T handle,
 
        WARN_ON(flags != VCHI_FLAGS_BLOCK_UNTIL_QUEUED);
 
-       status = vchiq_queue_message(service->handle, &element, 1);
+       while (1) {
+               status = vchiq_queue_message(service->handle, &element, 1);
+
+               /*
+                * vchiq_queue_message() may return VCHIQ_RETRY, so we need to
+                * implement a retry mechanism since this function is supposed
+                * to block until queued
+                */
+               if (status != VCHIQ_RETRY)
+                       break;
 
-       /* vchiq_queue_message() may return VCHIQ_RETRY, so we need to
-       ** implement a retry mechanism since this function is supposed
-       ** to block until queued
-       */
-       while (status == VCHIQ_RETRY) {
                msleep(1);
-               status = vchiq_queue_message(service->handle, &element, 1);
        }
 
        return vchiq_status_to_vchi(status);
@@ -229,17 +232,18 @@ int32_t vchi_bulk_queue_receive(VCHI_SERVICE_HANDLE_T handle,
                return vchiq_status_to_vchi(VCHIQ_ERROR);
        }
 
-       status = vchiq_bulk_receive(service->handle, data_dst, data_size,
-               bulk_handle, mode);
-
-       /* vchiq_bulk_receive() may return VCHIQ_RETRY, so we need to
-       ** implement a retry mechanism since this function is supposed
-       ** to block until queued
-       */
-       while (status == VCHIQ_RETRY) {
-               msleep(1);
+       while (1) {
                status = vchiq_bulk_receive(service->handle, data_dst,
                        data_size, bulk_handle, mode);
+               /*
+                * vchiq_bulk_receive() may return VCHIQ_RETRY, so we need to
+                * implement a retry mechanism since this function is supposed
+                * to block until queued
+                */
+               if (status != VCHIQ_RETRY)
+                       break;
+
+               msleep(1);
        }
 
        return vchiq_status_to_vchi(status);
@@ -289,17 +293,19 @@ int32_t vchi_bulk_queue_transmit(VCHI_SERVICE_HANDLE_T handle,
                return vchiq_status_to_vchi(VCHIQ_ERROR);
        }
 
-       status = vchiq_bulk_transmit(service->handle, data_src, data_size,
-               bulk_handle, mode);
-
-       /* vchiq_bulk_transmit() may return VCHIQ_RETRY, so we need to
-       ** implement a retry mechanism since this function is supposed
-       ** to block until queued
-       */
-       while (status == VCHIQ_RETRY) {
-               msleep(1);
+       while (1) {
                status = vchiq_bulk_transmit(service->handle, data_src,
                        data_size, bulk_handle, mode);
+
+               /*
+                * vchiq_bulk_transmit() may return VCHIQ_RETRY, so we need to
+                * implement a retry mechanism since this function is supposed
+                * to block until queued
+                */
+               if (status != VCHIQ_RETRY)
+                       break;
+
+               msleep(1);
        }
 
        return vchiq_status_to_vchi(status);