]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commitdiff
i2c: nvidia-gpu: refactor master_xfer
authorAjay Gupta <ajayg@nvidia.com>
Fri, 7 Jun 2019 16:34:19 +0000 (09:34 -0700)
committerWolfram Sang <wsa@the-dreams.de>
Fri, 7 Jun 2019 22:09:08 +0000 (00:09 +0200)
Added a local variable "send_stop" to simplify "goto" statements.

The "send_stop" handles below two case
1) When first i2c start fails and so i2c stop is not sent before
exiting

2) When i2c stop failed after all transfers and we do not need to
send another stop before exiting.

Signed-off-by: Ajay Gupta <ajayg@nvidia.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
drivers/i2c/busses/i2c-nvidia-gpu.c

index 1c8f708f212b4fee1b7061498da29293c6322cad..7678a460bf9ae52a3fbd44b880b1dc68a25b5569 100644 (file)
@@ -169,6 +169,7 @@ static int gpu_i2c_master_xfer(struct i2c_adapter *adap,
 {
        struct gpu_i2c_dev *i2cd = i2c_get_adapdata(adap);
        int status, status2;
+       bool send_stop = true;
        int i, j;
 
        /*
@@ -182,37 +183,40 @@ static int gpu_i2c_master_xfer(struct i2c_adapter *adap,
                        /* gpu_i2c_read has implicit start */
                        status = gpu_i2c_read(i2cd, msgs[i].buf, msgs[i].len);
                        if (status < 0)
-                               goto stop;
+                               goto exit;
                } else {
                        u8 addr = i2c_8bit_addr_from_msg(msgs + i);
 
                        status = gpu_i2c_start(i2cd);
                        if (status < 0) {
                                if (i == 0)
-                                       return status;
-                               goto stop;
+                                       send_stop = false;
+                               goto exit;
                        }
 
                        status = gpu_i2c_write(i2cd, addr);
                        if (status < 0)
-                               goto stop;
+                               goto exit;
 
                        for (j = 0; j < msgs[i].len; j++) {
                                status = gpu_i2c_write(i2cd, msgs[i].buf[j]);
                                if (status < 0)
-                                       goto stop;
+                                       goto exit;
                        }
                }
        }
+       send_stop = false;
        status = gpu_i2c_stop(i2cd);
        if (status < 0)
-               return status;
-
-       return i;
-stop:
-       status2 = gpu_i2c_stop(i2cd);
-       if (status2 < 0)
-               dev_err(i2cd->dev, "i2c stop failed %d\n", status2);
+               goto exit;
+
+       status = i;
+exit:
+       if (send_stop) {
+               status2 = gpu_i2c_stop(i2cd);
+               if (status2 < 0)
+                       dev_err(i2cd->dev, "i2c stop failed %d\n", status2);
+       }
        return status;
 }