X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=memory.c;h=7f4cef529a52e55ecbf099c0e23738943ab2b492;hp=00339e42663f25522ca1269c35883610a0d1e552;hb=ae2ddba4e74f06b5ec986d1c3387cd14e69f8146;hpb=d529ee1932bc85598900a3ef62f01293af87fbd8 diff --git a/memory.c b/memory.c index 00339e42..7f4cef52 100644 --- a/memory.c +++ b/memory.c @@ -39,7 +39,7 @@ int fio_pin_memory(void) if (phys_mem) { if ((mlock_size + 128 * 1024 * 1024) > phys_mem) { mlock_size = phys_mem - 128 * 1024 * 1024; - log_info("fio: limiting mlocked memory to %lluMiB\n", + log_info("fio: limiting mlocked memory to %lluMB\n", mlock_size >> 20); } } @@ -65,14 +65,18 @@ static int alloc_mem_shm(struct thread_data *td, unsigned int total_mem) { int flags = IPC_CREAT | SHM_R | SHM_W; - if (td->o.mem_type == MEM_SHMHUGE) + if (td->o.mem_type == MEM_SHMHUGE) { + unsigned long mask = td->o.hugepage_size - 1; + flags |= SHM_HUGETLB; + total_mem = (total_mem + mask) & ~mask; + } td->shm_id = shmget(IPC_PRIVATE, total_mem, flags); dprint(FD_MEM, "shmget %u, %d\n", total_mem, td->shm_id); if (td->shm_id < 0) { td_verror(td, errno, "shmget"); - if (geteuid() != 0 && errno == ENOMEM) + if (geteuid() != 0 && (errno == ENOMEM || errno == EPERM)) log_err("fio: you may need to run this job as root\n"); if (td->o.mem_type == MEM_SHMHUGE) { if (errno == EINVAL) {