xpmem: support large page
1. try to use as large page as possible on attach 2. pre-map resident remote pages on attach Change-Id: I5580682a4199e94085a9bad9ce3958a0f14cdcea
This commit is contained in:
committed by
Masamichi Takagi
parent
3aaa5350f0
commit
d2db639853
91
test/issues/1473/XTP_007.c
Normal file
91
test/issues/1473/XTP_007.c
Normal file
@ -0,0 +1,91 @@
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
#include <sys/mman.h>
|
||||
#include <string.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <errno.h>
|
||||
#include <sys/wait.h>
|
||||
#include <sys/ipc.h>
|
||||
#include <sys/shm.h>
|
||||
#include <xpmem.h>
|
||||
#include <libgen.h>
|
||||
#include "util.h"
|
||||
#include "okng.h"
|
||||
|
||||
#define BAD_ADDRESS ((void *)-1)
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int ret = 0;
|
||||
int status;
|
||||
pid_t pid;
|
||||
xpmem_segid_t segid;
|
||||
xpmem_apid_t apid;
|
||||
struct xpmem_addr addr;
|
||||
|
||||
printf("*** %s start ***\n", basename(argv[0]));
|
||||
|
||||
mem = mmap(0, SZ_MEM, PROT_READ | PROT_WRITE,
|
||||
MAP_ANONYMOUS | MAP_PRIVATE |
|
||||
MAP_HUGETLB | (LARGE_PAGE_SHIFT << MAP_HUGE_SHIFT), -1, 0);
|
||||
INTERR(mem == NULL, "mmap failed\n");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
INTERR(ret != 0, "xpmem_init failed\n");
|
||||
|
||||
segid = xpmem_make(BAD_ADDRESS, SZ_MEM, XPMEM_PERMIT_MODE,
|
||||
(void *)0666);
|
||||
OKNG(segid == -1,
|
||||
"xpmem_make with invalid address failed as expected\n");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
INTERR(segid == -1, "xpmem_make failed\n");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid != -1, "duplicated xpmem_make call succeeded as expected\n");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
INTERR(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
INTERR(apid == -1, "xpmem_get in child failed\n");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
INTERR(attach == (void *)-1,
|
||||
"xpmem_attach in child failed\n");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
ret = xpmem_detach(attach);
|
||||
INTERR(ret == -1, "xpmem_detach in child failed\n");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
ret = waitpid(pid, &status, 0);
|
||||
INTERR(ret == -1, "waitpid failed\n");
|
||||
|
||||
INTERR(*((unsigned long *)mem) != TEST_VAL,
|
||||
"TEST_VAL not found\n");
|
||||
|
||||
ret = xpmem_remove(segid);
|
||||
INTERR(ret == -1, "xpmem_remove failed\n");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
out:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
Reference in New Issue
Block a user