xwayland-shm: fortify fallocate against EINTR
If posix_fallocate or ftruncate is interrupted by signal while working, we return -1 as fd and the allocation process returns BadAlloc error. That causes xwayland clients to abort with 'BadAlloc (insufficient resources for operation)' even when there's a lot of resources available. Fix it by trying again when we get EINTR. Signed-off-by: Marek Chalupa <mchqwerty@gmail.com> Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
This commit is contained in:
		
							parent
							
								
									4cc3288073
								
							
						
					
					
						commit
						f48b0534f1
					
				|  | @ -140,14 +140,20 @@ os_create_anonymous_file(off_t size) | ||||||
|         return -1; |         return -1; | ||||||
| 
 | 
 | ||||||
| #ifdef HAVE_POSIX_FALLOCATE | #ifdef HAVE_POSIX_FALLOCATE | ||||||
|  |     do { | ||||||
|         ret = posix_fallocate(fd, 0, size); |         ret = posix_fallocate(fd, 0, size); | ||||||
|  |     } while (ret == EINTR); | ||||||
|  | 
 | ||||||
|     if (ret != 0) { |     if (ret != 0) { | ||||||
|         close(fd); |         close(fd); | ||||||
|         errno = ret; |         errno = ret; | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
| #else | #else | ||||||
|  |     do { | ||||||
|         ret = ftruncate(fd, size); |         ret = ftruncate(fd, size); | ||||||
|  |     } while (ret == -1 && errno == EINTR); | ||||||
|  | 
 | ||||||
|     if (ret < 0) { |     if (ret < 0) { | ||||||
|         close(fd); |         close(fd); | ||||||
|         return -1; |         return -1; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue