Previously the incorrect 'd' format specifier was used despite the '0x' prefix implying hex to the user. Change-Id: Ib97bd86ee0e0c8fe8c3785e22a4d9f6def3cae61 Signed-off-by: Mate Kukri <kukri.mate@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/81191 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de>
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* intelmetool */
 | |
| /* SPDX-License-Identifier: GPL-2.0-or-later */
 | |
| 
 | |
| #include "mmap.h"
 | |
| #include <errno.h>
 | |
| #include <string.h>
 | |
| 
 | |
| #ifndef __DARWIN__
 | |
| int fd_mem;
 | |
| 
 | |
| void *map_physical_exact(off_t phys_addr, void *mapto, size_t len)
 | |
| {
 | |
| 	void *virt_addr;
 | |
| 	int err;
 | |
| 
 | |
| 	virt_addr = mmap(mapto, len, PROT_WRITE | PROT_READ,
 | |
| 	                 MAP_SHARED | MAP_FIXED, fd_mem, phys_addr);
 | |
| 
 | |
| 	if (virt_addr == MAP_FAILED) {
 | |
| 		err = errno;
 | |
| 		printf("Error mapping physical memory 0x%016jx [0x%zx] ERRNO=%d %s\n",
 | |
| 		       (uintmax_t)phys_addr, len, err, strerror(err));
 | |
| 		return NULL;
 | |
| 	}
 | |
| 
 | |
| 	return virt_addr;
 | |
| }
 | |
| 
 | |
| void *map_physical(off_t phys_addr, size_t len)
 | |
| {
 | |
| 	void *virt_addr;
 | |
| 	int err;
 | |
| 
 | |
| 	virt_addr = mmap(NULL, len, PROT_WRITE | PROT_READ, MAP_SHARED, fd_mem, phys_addr);
 | |
| 
 | |
| 	if (virt_addr == MAP_FAILED) {
 | |
| 		err = errno;
 | |
| 		printf("Error mapping physical memory 0x%016jx [0x%zx] ERRNO=%d %s\n",
 | |
| 		       (uintmax_t)phys_addr, len, err, strerror(err));
 | |
| 		return NULL;
 | |
| 	}
 | |
| 
 | |
| 	return virt_addr;
 | |
| }
 | |
| 
 | |
| void unmap_physical(void *virt_addr, size_t len)
 | |
| {
 | |
| 	munmap(virt_addr, len);
 | |
| }
 | |
| #endif
 |