<div dir="ltr"><div>Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br><br></div>Please land soon so the old API can exist for as short a time as possible. :-)<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Mar 23, 2017 at 8:14 AM, Daniel Stone <span dir="ltr"><<a href="mailto:daniels@collabora.com" target="_blank">daniels@collabora.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">The actual offset returned is uint32_t, however int64_t was used as the<br>
return type from gbm_bo_get_offset to allow negative returns to signal<br>
errors to the caller.<br>
<br>
In case of an error getting the offset, the user will also be unable to<br>
get the handle/FD, and thus have nothing to offset into. This means that<br>
returning 0 as an error value is harmless, allowing us to change the<br>
return type to uint32_t in order to avoid signed/unsigned confusion in<br>
callers.<br>
<br>
Signed-off-by: Daniel Stone <<a href="mailto:daniels@collabora.com">daniels@collabora.com</a>><br>
Cc: Ben Widawsky <<a href="mailto:ben@bwidawsk.net">ben@bwidawsk.net</a>><br>
Cc: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br>
---<br>
 src/gbm/backends/dri/gbm_dri.c | 18 +++++++++---------<br>
 src/gbm/main/gbm.c             |  2 +-<br>
 src/gbm/main/gbm.h             |  2 +-<br>
 src/gbm/main/gbmint.h          |  2 +-<br>
 4 files changed, 12 insertions(+), 12 deletions(-)<br>
<br>
diff --git a/src/gbm/backends/dri/gbm_<wbr>dri.c b/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
index 84b4dd8853..f8c005c15b 100644<br>
--- a/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
+++ b/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
@@ -710,22 +710,22 @@ gbm_dri_bo_get_stride(struct gbm_bo *_bo, int plane)<br>
    return (uint32_t)stride;<br>
 }<br>
<br>
-static int64_t<br>
+static uint32_t<br>
 gbm_dri_bo_get_offset(struct gbm_bo *_bo, int plane)<br>
 {<br>
    struct gbm_dri_device *dri = gbm_dri_device(_bo->gbm);<br>
    struct gbm_dri_bo *bo = gbm_dri_bo(_bo);<br>
    int offset = 0;<br>
<br>
-   if (!dri->image || dri->image->base.version < 13 || !dri->image->fromPlanar) {<br>
-      errno = ENOSYS;<br>
-      return -1;<br>
-   }<br>
+   /* These error cases do not actually return an error code, as the user<br>
+    * will also fail to obtain the handle/FD from the BO. In that case, the<br>
+    * offset is irrelevant, as they have no buffer to offset into, so<br>
+    * returning 0 is harmless. */<br>
+   if (!dri->image || dri->image->base.version < 13 || !dri->image->fromPlanar)<br>
+      return 0;<br>
<br>
-   if (plane >= get_number_planes(dri, bo->image)) {<br>
-      errno = EINVAL;<br>
-      return -2;<br>
-   }<br>
+   if (plane >= get_number_planes(dri, bo->image))<br>
+      return 0;<br>
<br>
     /* Dumb images have no offset */<br>
    if (bo->image == NULL) {<br>
diff --git a/src/gbm/main/gbm.c b/src/gbm/main/gbm.c<br>
index 19dc5db901..79d78b763e 100644<br>
--- a/src/gbm/main/gbm.c<br>
+++ b/src/gbm/main/gbm.c<br>
@@ -203,7 +203,7 @@ gbm_bo_get_format(struct gbm_bo *bo)<br>
  * \param bo The buffer object<br>
  * \return The offset<br>
  */<br>
-GBM_EXPORT int64_t<br>
+GBM_EXPORT uint32_t<br>
 gbm_bo_get_offset(struct gbm_bo *bo, int plane)<br>
 {<br>
    return bo->gbm->bo_get_offset(bo, plane);<br>
diff --git a/src/gbm/main/gbm.h b/src/gbm/main/gbm.h<br>
index a774b50951..b52137ed01 100644<br>
--- a/src/gbm/main/gbm.h<br>
+++ b/src/gbm/main/gbm.h<br>
@@ -315,7 +315,7 @@ gbm_bo_get_stride_for_plane(<wbr>struct gbm_bo *bo, int plane);<br>
 uint32_t<br>
 gbm_bo_get_format(struct gbm_bo *bo);<br>
<br>
-int64_t<br>
+uint32_t<br>
 gbm_bo_get_offset(struct gbm_bo *bo, int plane);<br>
<br>
 struct gbm_device *<br>
diff --git a/src/gbm/main/gbmint.h b/src/gbm/main/gbmint.h<br>
index 5ad85cc80f..c27a7a560a 100644<br>
--- a/src/gbm/main/gbmint.h<br>
+++ b/src/gbm/main/gbmint.h<br>
@@ -81,7 +81,7 @@ struct gbm_device {<br>
    int (*bo_get_planes)(struct gbm_bo *bo);<br>
    union gbm_bo_handle (*bo_get_handle)(struct gbm_bo *bo, int plane);<br>
    uint32_t (*bo_get_stride)(struct gbm_bo *bo, int plane);<br>
-   int64_t (*bo_get_offset)(struct gbm_bo *bo, int plane);<br>
+   uint32_t (*bo_get_offset)(struct gbm_bo *bo, int plane);<br>
    uint64_t (*bo_get_modifier)(struct gbm_bo *bo);<br>
    void (*bo_destroy)(struct gbm_bo *bo);<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
2.12.1<br>
<br>
</font></span></blockquote></div><br></div>