 8e554429e8
			
		
	
	8e554429e8
	
	
	
		
			
			Now that Git depends on pread in index-pack its safe to say we can also depend on it within the git_mmap emulation we activate when NO_MMAP is set. On most systems pread should be slightly faster than an lseek/read/lseek sequence as its one system call vs. three system calls. We also now honor EAGAIN and EINTR error codes from pread and restart the prior read. Signed-off-by: Shawn O. Pearce <spearce@spearce.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
		
			
				
	
	
		
			44 lines
		
	
	
		
			748 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			748 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "../git-compat-util.h"
 | |
| 
 | |
| void *git_mmap(void *start, size_t length, int prot, int flags, int fd, off_t offset)
 | |
| {
 | |
| 	size_t n = 0;
 | |
| 
 | |
| 	if (start != NULL || !(flags & MAP_PRIVATE))
 | |
| 		die("Invalid usage of mmap when built with NO_MMAP");
 | |
| 
 | |
| 	start = xmalloc(length);
 | |
| 	if (start == NULL) {
 | |
| 		errno = ENOMEM;
 | |
| 		return MAP_FAILED;
 | |
| 	}
 | |
| 
 | |
| 	while (n < length) {
 | |
| 		ssize_t count = pread(fd, (char *)start + n, length - n, offset + n);
 | |
| 
 | |
| 		if (count == 0) {
 | |
| 			memset((char *)start+n, 0, length-n);
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		if (count < 0) {
 | |
| 			if (errno == EAGAIN || errno == EINTR)
 | |
| 				continue;
 | |
| 			free(start);
 | |
| 			errno = EACCES;
 | |
| 			return MAP_FAILED;
 | |
| 		}
 | |
| 
 | |
| 		n += count;
 | |
| 	}
 | |
| 
 | |
| 	return start;
 | |
| }
 | |
| 
 | |
| int git_munmap(void *start, size_t length)
 | |
| {
 | |
| 	free(start);
 | |
| 	return 0;
 | |
| }
 | |
| 
 |