From: Brian Paul Date: Fri, 19 May 2000 22:35:44 +0000 (+0000) Subject: fixed alignment bug in _mesa_image_row_stride() X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=fbbac25ad304e09a4cde52bd09b4940ac4785623;p=mesa.git fixed alignment bug in _mesa_image_row_stride() --- diff --git a/src/mesa/main/image.c b/src/mesa/main/image.c index dc6abb39d7d..627ab1510e7 100644 --- a/src/mesa/main/image.c +++ b/src/mesa/main/image.c @@ -1,4 +1,4 @@ -/* $Id: image.c,v 1.31 2000/05/10 14:39:53 brianp Exp $ */ +/* $Id: image.c,v 1.32 2000/05/19 22:35:44 brianp Exp $ */ /* * Mesa 3-D graphics library @@ -519,16 +519,19 @@ _mesa_image_row_stride( const struct gl_pixelstore_attrib *packing, else { /* Non-BITMAP data */ const GLint bytesPerPixel = _mesa_bytes_per_pixel(format, type); + GLint bytesPerRow, remainder; if (bytesPerPixel <= 0) return -1; /* error */ if (packing->RowLength == 0) { - GLint bytes = bytesPerPixel * width; - return bytes; + bytesPerRow = bytesPerPixel * width; } else { - GLint bytes = bytesPerPixel * packing->RowLength; - return bytes; + bytesPerRow = bytesPerPixel * packing->RowLength; } + remainder = bytesPerRow % packing->Alignment; + if (remainder > 0) + bytesPerRow += (packing->Alignment - remainder); + return bytesPerRow; } }