summaryrefslogtreecommitdiffstats
path: root/src/mesa/drivers/dri/r300
diff options
context:
space:
mode:
authorEric Anholt <[email protected]>2005-08-25 03:38:07 +0000
committerEric Anholt <[email protected]>2005-08-25 03:38:07 +0000
commit61d386a93f862005d1eddb45be91c7d5421aca83 (patch)
tree3d8ab1181fd200c4212de7f3ee5323d4c4138046 /src/mesa/drivers/dri/r300
parentd545d916a838819af4ad577873aa8e590d9f5756 (diff)
Attempt to fix the issue reported by Alan Grimes with DRM_RADEON_TEXTURE
erroring out when it shouldn't. The errno could be changed by usleep() between the ioctl call and the loop check, if a signal was received. This could cause an EAGAIN return from the DRM_RADEON_TEXTURE ioctl to not loop again. Instead of checking errno, check thevalue of ret itself, since it is a saved (and sign-flipped) copy of errno from the ioctl call.
Diffstat (limited to 'src/mesa/drivers/dri/r300')
-rw-r--r--src/mesa/drivers/dri/r300/r300_texmem.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/mesa/drivers/dri/r300/r300_texmem.c b/src/mesa/drivers/dri/r300/r300_texmem.c
index 5c70e2e3c54..ca392762ad4 100644
--- a/src/mesa/drivers/dri/r300/r300_texmem.c
+++ b/src/mesa/drivers/dri/r300/r300_texmem.c
@@ -417,7 +417,7 @@ static void uploadSubImage(r300ContextPtr rmesa, r300TexObjPtr t,
"DRM_RADEON_TEXTURE: again!\n");
usleep(1);
}
- } while (ret && errno == EAGAIN);
+ } while (ret == -EAGAIN);
UNLOCK_HARDWARE(&rmesa->radeon);