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
|