glsl: fix bounds check in blob_overwrite_bytes
authorRob Herring <robh@kernel.org>
Thu, 1 Jun 2017 00:07:40 +0000 (19:07 -0500)
committerRob Herring <robh@kernel.org>
Thu, 8 Jun 2017 01:44:26 +0000 (20:44 -0500)
clang gives a warning in blob_overwrite_bytes because offset type is
size_t which is unsigned:

src/compiler/glsl/blob.c:110:15: warning: comparison of unsigned expression < 0 is always false [-Wtautological-compare]
   if (offset < 0 || blob->size - offset < to_write)
       ~~~~~~ ^ ~

Remove the less than 0 check to fix this.

Additionally, if offset is greater than blob->size, the 2nd check would
be false due to unsigned math. Rewrite the check to avoid subtraction.

Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
Signed-off-by: Rob Herring <robh@kernel.org>
src/compiler/glsl/blob.c

index 769ebf1a0232fd81cb79c10ce855d3f650a15b13..db3625206508bc477e9c5d98d473008c69815418 100644 (file)
@@ -107,7 +107,7 @@ blob_overwrite_bytes(struct blob *blob,
                      size_t to_write)
 {
    /* Detect an attempt to overwrite data out of bounds. */
-   if (offset < 0 || blob->size - offset < to_write)
+   if (blob->size < offset + to_write)
       return false;
 
    memcpy(blob->data + offset, bytes, to_write);