14.09.2015 13:40, zhanghailiang wrote:
> config_fd should be closed before return, or there will
> be a resource leak error.
> 
> Signed-off-by: zhanghailiang <zhang.zhanghaili...@huawei.com>
> ---
>  hw/pci-host/piix.c | 11 +++++++----
>  1 file changed, 7 insertions(+), 4 deletions(-)
> 
> diff --git a/hw/pci-host/piix.c b/hw/pci-host/piix.c
> index 1fb71c8..7b2fbf9 100644
> --- a/hw/pci-host/piix.c
> +++ b/hw/pci-host/piix.c
> @@ -764,6 +764,7 @@ static int host_pci_config_read(int pos, int len, 
> uint32_t val)
>      /* Access real host bridge. */
>      int rc = snprintf(path, size, 
> "/sys/bus/pci/devices/%04x:%02x:%02x.%d/%s",
>                        0, 0, 0, 0, "config");
> +    int ret = 0;
>  
>      if (rc >= size || rc < 0) {
>          return -ENODEV;
> @@ -775,16 +776,18 @@ static int host_pci_config_read(int pos, int len, 
> uint32_t val)
>      }
>  
>      if (lseek(config_fd, pos, SEEK_SET) != pos) {
> -        return -errno;
> +        ret = -errno;
> +        goto out;
>      }
>      do {
>          rc = read(config_fd, (uint8_t *)&val, len);
>      } while (rc < 0 && (errno == EINTR || errno == EAGAIN));
>      if (rc != len) {
> -        return -errno;
> +        ret = -errno;
>      }
> -
> -    return 0;
> +out:
> +    close(config_fd);
> +    return ret;
>  }
>  
>  static int igd_pt_i440fx_initfn(struct PCIDevice *pci_dev)

How about the attached (untested)?

Thanks,

/mjt

diff --git a/hw/pci-host/piix.c b/hw/pci-host/piix.c
index 7b2fbf9..42f847d 100644
--- a/hw/pci-host/piix.c
+++ b/hw/pci-host/piix.c
@@ -764,7 +764,6 @@ static int host_pci_config_read(int pos, int len, uint32_t val)
     /* Access real host bridge. */
     int rc = snprintf(path, size, "/sys/bus/pci/devices/%04x:%02x:%02x.%d/%s",
                       0, 0, 0, 0, "config");
-    int ret = 0;
 
     if (rc >= size || rc < 0) {
         return -ENODEV;
@@ -774,20 +773,15 @@ static int host_pci_config_read(int pos, int len, uint32_t val)
     if (config_fd < 0) {
         return -ENODEV;
     }
-
-    if (lseek(config_fd, pos, SEEK_SET) != pos) {
-        ret = -errno;
-        goto out;
-    }
     do {
-        rc = read(config_fd, (uint8_t *)&val, len);
+        rc = pread(config_fd, (uint8_t *)&val, len, pos);
     } while (rc < 0 && (errno == EINTR || errno == EAGAIN));
+    close(config_fd);
     if (rc != len) {
-        ret = -errno;
+        return -errno;
     }
-out:
-    close(config_fd);
-    return ret;
+
+    return 0;
 }
 
 static int igd_pt_i440fx_initfn(struct PCIDevice *pci_dev)

Reply via email to