Revert "xpmem: Support large page attachment"
This reverts commit a8696d811d.
Conflicts:
kernel/include/process.h
kernel/syscall.c
kernel/xpmem.c
Change-Id: I726e74450f6228d3fc78fc62dda15b2067732a53
This commit is contained in:
@@ -1,187 +0,0 @@
|
||||
#!/usr/bin/bash
|
||||
|
||||
USELTP=0
|
||||
USEOSTEST=0
|
||||
|
||||
XPMEM_DIR=$HOME/usr
|
||||
XPMEM_BUILD_DIR=/home/satoken/xpmem
|
||||
|
||||
arch=`uname -p`
|
||||
if [ -f "./${arch}_config" ]; then
|
||||
. ./${arch}_config
|
||||
else
|
||||
echo "$1 is unexpected arch"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
. ../../common.sh
|
||||
|
||||
sudo insmod ${XPMEM_DIR}/lib/modules/`uname -r`/xpmem.ko
|
||||
sudo chmod og+rw /dev/xpmem
|
||||
|
||||
issue=1259
|
||||
tid=01
|
||||
ng=0
|
||||
echo "*** C${issue}T${tid} start *******************************"
|
||||
echo "** xpmem_attach to Huge mapped memory range"
|
||||
echo "** end of range is aligned with Large page size"
|
||||
for pgshift in ${PGSHIFT_LIST[@]}
|
||||
do
|
||||
${IHKOSCTL} 0 clear_kmsg
|
||||
log_file="./C${issue}T${tid}_${pgshift}.log"
|
||||
echo pageshift: ${pgshift}
|
||||
${MCEXEC} ./huge_page_xpmem ${pgshift} 2 0 > ${log_file}
|
||||
${IHKOSCTL} 0 kmsg >> ${log_file}
|
||||
|
||||
EXPECT_PGSIZE=`grep EXPECT_PAGE_SIZE ${log_file} | awk '{ print $2; }'`
|
||||
|
||||
SEG_ADDR=`grep parent: ${log_file} | awk '{ print $3; }'`
|
||||
SEG_PGSIZE=`cat ${log_file} | awk '/OK/,/DONE/' | \
|
||||
grep -o "large_page_allocation.*${SEG_ADDR}.*" | awk '{ print $5; }'`
|
||||
|
||||
XPMEM_ADDR=`grep xpmem_attachment_addr ${log_file} | awk '{ print $3; }'`
|
||||
XPMEM_PGSIZE=`grep -o "xpmem_page_attach.*${XPMEM_ADDR}.*" ${log_file} | awk '{ print $5; }'`
|
||||
|
||||
if [ "${SEG_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] seg_addr ($SEG_ADDR) is allocated until xpmem_attach"
|
||||
else
|
||||
echo "** [ NG ] seg_addr ($SEG_ADDR) is NOT allocated until xpmem_attach"
|
||||
let ng++
|
||||
fi
|
||||
if [ "${XPMEM_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] xpmem_addr ($XPMEM_ADDR) is allocated using large pages"
|
||||
else
|
||||
echo "** [ NG ] xpmem_addr ($XPMEM_ADDR) is NOT allocated using large pages"
|
||||
let ng++
|
||||
fi
|
||||
done
|
||||
if [ ${ng} -eq 0 ]; then
|
||||
echo "*** C${issue}T${tid}: PASSED"
|
||||
else
|
||||
echo "*** C${issue}T${tid}: FAILED"
|
||||
fi
|
||||
echo ""
|
||||
|
||||
tid=02
|
||||
ng=0
|
||||
echo "*** C${issue}T${tid} start *******************************"
|
||||
echo "** xpmem_attach to Huge mapped memory range"
|
||||
echo "** end of range is NOT aligned with Large page size"
|
||||
for pgshift in ${PGSHIFT_LIST[@]}
|
||||
do
|
||||
${IHKOSCTL} 0 clear_kmsg
|
||||
log_file="./C${issue}T${tid}_${pgshift}.log"
|
||||
echo pageshift: ${pgshift}
|
||||
${MCEXEC} ./huge_page_xpmem ${pgshift} 2 ${SMALL_PGSIZE} > ${log_file}
|
||||
${IHKOSCTL} 0 kmsg >> ${log_file}
|
||||
|
||||
EXPECT_PGSIZE=`grep EXPECT_PAGE_SIZE ${log_file} | awk '{ print $2; }'`
|
||||
|
||||
SEG_ADDR=`grep parent: ${log_file} | awk '{ print $3; }'`
|
||||
SEG_PGSIZE=`cat ${log_file} | awk '/OK/,/DONE/' | \
|
||||
grep -o "large_page_allocation.*${SEG_ADDR}.*" | awk '{ print $5; }'`
|
||||
|
||||
XPMEM_ADDR=`grep xpmem_attachment_addr ${log_file} | awk '{ print $3; }'`
|
||||
XPMEM_PGSIZE=`grep -o "xpmem_page_attach.*${XPMEM_ADDR}.*" ${log_file} | awk '{ print $5; }'`
|
||||
|
||||
if [ "${SEG_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] seg_addr ($SEG_ADDR) is allocated until xpmem_attach"
|
||||
else
|
||||
echo "** [ NG ] seg_addr ($SEG_ADDR) is NOT allocated until xpmem_attach"
|
||||
let ng++
|
||||
fi
|
||||
if [ "${XPMEM_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] xpmem_addr ($XPMEM_ADDR) is allocated using large pages"
|
||||
else
|
||||
echo "** [ NG ] xpmem_addr ($XPMEM_ADDR) is NOT allocated using large pages"
|
||||
let ng++
|
||||
fi
|
||||
done
|
||||
if [ ${ng} -eq 0 ]; then
|
||||
echo "*** C${issue}T${tid}: PASSED"
|
||||
else
|
||||
echo "*** C${issue}T${tid}: FAILED"
|
||||
fi
|
||||
echo ""
|
||||
|
||||
tid=03
|
||||
ng=0
|
||||
echo "*** C${issue}T${tid} start *******************************"
|
||||
echo "** xpmem_attach to small mapped memory range"
|
||||
${IHKOSCTL} 0 clear_kmsg
|
||||
log_file="./C${issue}T${tid}.log"
|
||||
echo pageshift: small page
|
||||
${MCEXEC} ./huge_page_xpmem -1 2 0 > ${log_file}
|
||||
${IHKOSCTL} 0 kmsg >> ${log_file}
|
||||
|
||||
EXPECT_PGSIZE=`grep EXPECT_PAGE_SIZE ${log_file} | awk '{ print $2; }'`
|
||||
|
||||
XPMEM_ADDR=`grep xpmem_attachment_addr ${log_file} | awk '{ print $3; }'`
|
||||
XPMEM_PGSIZE=`grep -o "xpmem_page_attach.*${XPMEM_ADDR}.*" ${log_file} | awk '{ print $5; }'`
|
||||
|
||||
if [ "${XPMEM_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] xpmem_addr ($XPMEM_ADDR) is allocated using small pages"
|
||||
else
|
||||
echo "** [ NG ] xpmem_addr ($XPMEM_ADDR) is NOT allocated using small pages"
|
||||
ng=1
|
||||
fi
|
||||
if [ ${ng} -eq 0 ]; then
|
||||
echo "*** C${issue}T${tid}: PASSED"
|
||||
else
|
||||
echo "*** C${issue}T${tid}: FAILED"
|
||||
fi
|
||||
echo ""
|
||||
|
||||
tid=04
|
||||
ng=0
|
||||
echo "*** C${issue}T${tid} start *******************************"
|
||||
echo "** xpmem_attach to multi pagesize range"
|
||||
pgshift=${PGSHIFT_LIST[0]}
|
||||
${IHKOSCTL} 0 clear_kmsg
|
||||
log_file="./C${issue}T${tid}_${pgshift}.log"
|
||||
echo pageshift: ${pgshift}
|
||||
${MCEXEC} ./multi_vmr_xpmem ${pgshift} 1 > ${log_file}
|
||||
${IHKOSCTL} 0 kmsg >> ${log_file}
|
||||
|
||||
EXPECT_PGSIZE=`grep EXPECT_PAGE_SIZE ${log_file} | awk '{ print $2; }'`
|
||||
|
||||
XPMEM_ADDR=`grep xpmem_large ${log_file} | awk '{ print $3; }'`
|
||||
XPMEM_PGSIZE=`grep -o "xpmem_page_attach.*${XPMEM_ADDR}.*" ${log_file} | awk '{ print $5; }'`
|
||||
|
||||
if [ "${XPMEM_PGSIZE}" = "${EXPECT_PGSIZE}" ]; then
|
||||
echo "** [ OK ] xpmem_addr ($XPMEM_ADDR) is allocated using large pages"
|
||||
else
|
||||
echo "** [ NG ] xpmem_addr ($XPMEM_ADDR) is NOT allocated using large pages"
|
||||
let ng++
|
||||
fi
|
||||
if [ ${ng} -eq 0 ]; then
|
||||
echo "*** C${issue}T${tid}: PASSED"
|
||||
else
|
||||
echo "*** C${issue}T${tid}: FAILED"
|
||||
fi
|
||||
echo ""
|
||||
|
||||
tid=05
|
||||
ng=0
|
||||
echo "*** C${issue}T${tid} start *******************************"
|
||||
echo "** xpmem testsuite"
|
||||
cwd=`pwd`
|
||||
cd ${XPMEM_BUILD_DIR}/test
|
||||
${cwd}/mc_run.sh
|
||||
cd ${cwd}
|
||||
|
||||
# xpmem basic test
|
||||
${MCEXEC} ./XTP_001
|
||||
${MCEXEC} ./XTP_002
|
||||
${MCEXEC} ./XTP_003
|
||||
${MCEXEC} ./XTP_004
|
||||
${MCEXEC} ./XTP_005
|
||||
${MCEXEC} ./XTP_006
|
||||
sleep 3
|
||||
${MCEXEC} ./XTP_007
|
||||
${MCEXEC} ./XTP_008
|
||||
${MCEXEC} ./XTP_009
|
||||
${MCEXEC} ./XTP_010
|
||||
${MCEXEC} ./XTP_011
|
||||
|
||||
sudo rmmod xpmem.ko
|
||||
@@ -1,12 +0,0 @@
|
||||
XPMEM_DIR=$(HOME)/usr
|
||||
CPPFLAGS=-I$(XPMEM_DIR)/include
|
||||
LDFLAGS=-L$(XPMEM_DIR)/lib -Wl,-rpath -Wl,$(XPMEM_DIR)/lib -lxpmem
|
||||
|
||||
TARGET=huge_page_xpmem multi_vmr_xpmem XTP_001 XTP_002 XTP_003 XTP_004 XTP_005 XTP_006 XTP_007 XTP_008 XTP_009 XTP_010 XTP_011
|
||||
|
||||
all: $(TARGET)
|
||||
test: all
|
||||
bash ./C1259.sh
|
||||
clean:
|
||||
rm -f $(TARGET) C*.log
|
||||
|
||||
@@ -1,104 +0,0 @@
|
||||
【Issue#1259 動作確認】
|
||||
□ テスト内容
|
||||
1. Large pageでマップされたメモリ領域でのxpmemの動作確認
|
||||
C1259T01:
|
||||
Large pageでマップされたメモリ領域に対してxpmem_attachを行った場合、
|
||||
attach先の領域がxpmem_makeでページインされることを確認する
|
||||
また、xpmemでもLarge pageが利用されることを確認する
|
||||
|
||||
C1259T02:
|
||||
Large pageでかつ、最後のページがLarge pageサイズでアラインされていない
|
||||
メモリ領域に対してxpmem_attachを行った場合、
|
||||
xpmemでもLarge pageが利用されることを確認する
|
||||
|
||||
C1259T03:
|
||||
Small pageでマップされたメモリ領域に対してxpmem_attachを行った場合、
|
||||
xpmemでもSmall pageが利用されることを確認する
|
||||
|
||||
C1259T04:
|
||||
small - large - small のように、異なるページサイズの複数のvm_rangeから
|
||||
構成されるメモリ領域に対してxpmem_attach を行った場合、
|
||||
xpmemでも同じ構成でLarge pageが利用されることを確認する
|
||||
|
||||
2. xpmemのテストスイートによる動作確認
|
||||
xpmemに付属するテストスイートをMcKernelで実行し、PASSすることを確認する
|
||||
|
||||
3. xpmemの基本操作の確認
|
||||
xpmemで操作するメモリ領域は、Large pageでマップする
|
||||
|
||||
XTP_001: 単一プロセスでのXPMEM操作
|
||||
1. 実行したプロセスがxpmem_make -> xpmem_get -> xpmem_attach -> xpmem_detach -> xpmem_remove
|
||||
|
||||
XTP_002: 子プロセスでのXPMEM操作
|
||||
1. 親プロセスがfork()
|
||||
2. 子プロセスがxpmem_make -> xpmem_get -> xpmem_attach -> xpmem_detach ->xpmem_remove
|
||||
3. 子プロセス終了後、親プロセスが終了
|
||||
|
||||
XTP_003: 親プロセスがmakeした共有領域への子プロセスによるXPMEM操作
|
||||
1. 親プロセスがxpmem_make
|
||||
2. fork()で子プロセスを作成
|
||||
3. 子プロセスで、xpmem_get -> xpmem_attach -> 値(TEST_VAL)の設定 -> xpmem_detach
|
||||
4. 子プロセスが終了
|
||||
5. 親プロセスが、子プロセスによって設定された値(TEST_VAL)を確認
|
||||
6. 親プロセスがxpmem_remove
|
||||
|
||||
XTP_004: fork()後に親プロセスがmakeした共有領域への子プロセスによるXPMEM操作
|
||||
1. fork()で子プロセスを作成
|
||||
2. 親プロセスがxpmem_make
|
||||
3. 子プロセスで、xpmem_get -> xpmem_attach -> 値(TEST_VAL)の設定 -> xpmem_detach
|
||||
4. 子プロセスが終了
|
||||
5. 親プロセスが、子プロセスによって設定された値(TEST_VAL)を確認
|
||||
6. 親プロセスがxpmem_remove
|
||||
|
||||
XTP_005: 子プロセスがxpmem_attach後、xpmem_detachをせずに終了
|
||||
1. 親プロセスがxpmem_make
|
||||
2. fork()で子プロセスを作成
|
||||
3. 子プロセスで、xpmem_get -> xpmem_attach
|
||||
4. 子プロセスが終了
|
||||
5. 親プロセスがxpmem_remove
|
||||
|
||||
XTP_006: 子プロセスがXPMEM操作を行う時点で、xpmem_makeをした親プロセスが終了している
|
||||
1. 親プロセスがxpmem_make
|
||||
2. fork()で子プロセスを作成
|
||||
3. 親プロセスが終了
|
||||
4. 子プロセスで、xpmem_get (失敗)
|
||||
5. 子プロセスが終了
|
||||
|
||||
XTP_007: xpmem_make 呼び出しの異常系
|
||||
1. xpmem_make の第1引数に不正なアドレスを指定する (失敗)
|
||||
2. 1度xpmem_make を実施したメモリ領域に対して、再度xpmem_make を行う (成功)
|
||||
|
||||
XTP_008: xpmem_get 呼び出しの異常系
|
||||
1. xpmem_get の第1引数に不正なsegidを指定する (失敗)
|
||||
2. 1度xpmem_get を実施したsegidで、再度xpmem_get を行う (成功)
|
||||
|
||||
XTP_009: xpmem_attach 呼び出しの異常系
|
||||
1. xpmem_attach の第1引数に不正なapidを指定する (失敗)
|
||||
2. 1度xpmem_attach を実施したapidで、再度xpmem_attach を行う (成功)
|
||||
|
||||
XTP_010: xpmem_detach 呼び出しの異常系
|
||||
1. xpmem_detach の第1引数に不正なアドレスを指定する (成功)
|
||||
2. 1度xpmem_detach を実施したメモリ領域に対して、再度xpmem_detach を行う (成功)
|
||||
|
||||
XTP_011: xpmem_remove 呼び出しの異常系
|
||||
1. xpmem_remove の第1引数に不正なsegidを指定する (失敗)
|
||||
2. 1度xpmem_remove を実施したsegidで、再度xpmem_remove を行う (失敗)
|
||||
|
||||
□ 実行手順
|
||||
1. xpmemのインストールディレクトリをMakefileとC1259.sh中のXPMEM_DIRに記載する
|
||||
2. xpmemのビルドディレクトリをC1259.sh中のXPMEM_BUILD_DIRに記載する
|
||||
3. 下記の手順でテストを実行する
|
||||
$ cd <mckernel>
|
||||
$ patch -p0 < test/issues/1259/large_page.patch
|
||||
(build mckernel)
|
||||
$ cd test/issues/1259
|
||||
$ make test
|
||||
|
||||
McKernelのインストール先や、OSTEST, LTPの配置場所は、
|
||||
$HOME/.mck_test_config を参照している
|
||||
.mck_test_config は、McKernelをビルドした際に生成されるmck_test_config.sample ファイルを
|
||||
$HOMEにコピーし、適宜編集する
|
||||
|
||||
□ 実行結果
|
||||
x86_64_result.log, aarch64_result.log 参照。
|
||||
すべての項目をPASSしていることを確認。
|
||||
@@ -1,60 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 0;
|
||||
int status;
|
||||
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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1, "xpmem_attach");
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
OKNG(rc == -1, "xpmem_detach");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc == -1, "xpmem_remove");
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,76 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init in child");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE,
|
||||
(void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make in child");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
OKNG(rc == -1, "xpmem_detach in child");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc == -1, "xpmem_remove in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,79 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
OKNG(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
OKNG(*((unsigned long *)mem) != TEST_VAL, "validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,112 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
#define BUFF_SIZE 1024
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 0;
|
||||
int status;
|
||||
pid_t pid;
|
||||
xpmem_segid_t segid;
|
||||
xpmem_apid_t apid;
|
||||
struct xpmem_addr addr;
|
||||
key_t key = ftok(argv[0], 0);
|
||||
int shmid;
|
||||
|
||||
printf("*** %s start ***\n", basename(argv[0]));
|
||||
|
||||
shmid = shmget(key, SZ_MEM, IPC_CREAT | 0660);
|
||||
CHKANDJUMP(shmid == -1, "shmget");
|
||||
|
||||
mem = mmap(0, SZ_MEM, PROT_READ | PROT_WRITE,
|
||||
MAP_ANONYMOUS | MAP_PRIVATE |
|
||||
MAP_HUGETLB | (LARGE_PAGE_SHIFT << MAP_HUGE_SHIFT), -1, 0);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
void *shm = shmat(shmid, NULL, 0);
|
||||
|
||||
CHKANDJUMP(shm == (void *)-1, "shmat in child");
|
||||
|
||||
while ((segid = *(xpmem_segid_t *)shm) == 0) {
|
||||
};
|
||||
|
||||
rc = shmdt(shm);
|
||||
CHKANDJUMP(rc == -1, "shmdt");
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init in child");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
OKNG(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
void *shm = shmat(shmid, NULL, 0);
|
||||
struct shmid_ds buf;
|
||||
|
||||
CHKANDJUMP(shm == (void *)-1, "shmat in parent");
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE,
|
||||
(void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make");
|
||||
|
||||
*(xpmem_segid_t *)shm = segid;
|
||||
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
OKNG(*((unsigned long *)mem) != TEST_VAL, "validate TEST_VAL");
|
||||
|
||||
rc = shmctl(shmid, IPC_RMID, &buf);
|
||||
CHKANDJUMP(rc == -1, "shmctl");
|
||||
|
||||
rc = shmdt(shm);
|
||||
CHKANDJUMP(rc == -1, "shmdt");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,76 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
OKNG(*((unsigned long *)mem) != TEST_VAL, "validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,64 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
sleep(1); /* wait for parent process exit */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid != -1,
|
||||
"xpmem_get in child failed (parent process exited already");
|
||||
fflush(0);
|
||||
|
||||
} else {
|
||||
/* Parent process */
|
||||
_exit(0);
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,89 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
#define BAD_ADDRESS ((void *)-1)
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(BAD_ADDRESS, SZ_MEM, XPMEM_PERMIT_MODE,
|
||||
(void *)0666);
|
||||
OKNG(segid != -1, "xpmem_make failed (invalid address)");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, "xpmem_make");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
OKNG(segid == -1, "xpmem_make succeed(do twice to same address)");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
CHKANDJUMP(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
CHKANDJUMP(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
CHKANDJUMP(*((unsigned long *)mem) != TEST_VAL,
|
||||
"validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
CHKANDJUMP(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,89 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
#define BAD_SEGID -1
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(BAD_SEGID, XPMEM_RDWR, XPMEM_PERMIT_MODE,
|
||||
NULL);
|
||||
OKNG(apid != -1, "xpmem_get in child failed (invalid segid)");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, "xpmem_get in child");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
OKNG(apid == -1, "xpmem_get in child (do twice to same segid");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
CHKANDJUMP(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
CHKANDJUMP(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
CHKANDJUMP(*((unsigned long *)mem) != TEST_VAL,
|
||||
"validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
CHKANDJUMP(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,92 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = -1;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach != (void *)-1,
|
||||
"xpmem_attach in childi failed (invalid apid)");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
CHKANDJUMP(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
OKNG(attach == (void *)-1,
|
||||
"xpmem_attach in child succeed (do twice to same apid)");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
CHKANDJUMP(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
CHKANDJUMP(*((unsigned long *)mem) != TEST_VAL,
|
||||
"validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
CHKANDJUMP(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,90 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
#define BAD_ADDRESS ((void *) -1)
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
CHKANDJUMP(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(BAD_ADDRESS);
|
||||
OKNG(rc == -1,
|
||||
"xpmem_detach in child succeed (invalid address)");
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
CHKANDJUMP(rc == -1, "xpmem_detach in child");
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
OKNG(rc == -1,
|
||||
"xpmem_detach in child succeed (do twice to same address)");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
CHKANDJUMP(*((unsigned long *)mem) != TEST_VAL,
|
||||
"validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
CHKANDJUMP(rc == -1, "xpmem_remove");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,88 +0,0 @@
|
||||
#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 "util2.h"
|
||||
|
||||
#define BAD_SEGID -1
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *attach;
|
||||
int rc = 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);
|
||||
CHKANDJUMP(mem == NULL, "mmap");
|
||||
memset(mem, 0, SZ_MEM);
|
||||
|
||||
rc = xpmem_init();
|
||||
CHKANDJUMP(rc != 0, "xpmem_init");
|
||||
|
||||
segid = xpmem_make(mem, SZ_MEM, XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, "xpmem_make");
|
||||
|
||||
fflush(0);
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, "fork failed\n");
|
||||
|
||||
if (pid == 0) {
|
||||
/* Child process */
|
||||
apid = xpmem_get(segid, XPMEM_RDWR, XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, "xpmem_get in child");
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, SZ_MEM, NULL);
|
||||
CHKANDJUMP(attach == (void *)-1, "xpmem_attach in child");
|
||||
|
||||
*((unsigned long *)attach) = TEST_VAL;
|
||||
|
||||
rc = xpmem_detach(attach);
|
||||
CHKANDJUMP(rc == -1, "xpmem_detach in child");
|
||||
|
||||
fflush(0);
|
||||
_exit(0);
|
||||
} else {
|
||||
/* Parent process */
|
||||
rc = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(rc == -1, "waitpid failed\n");
|
||||
|
||||
CHKANDJUMP(*((unsigned long *)mem) != TEST_VAL,
|
||||
"validate TEST_VAL");
|
||||
|
||||
rc = xpmem_remove(BAD_SEGID);
|
||||
OKNG(rc != -1, "xpmem_remove failed (invalid segid)");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
CHKANDJUMP(rc == -1, "xpmem_remove");
|
||||
|
||||
rc = xpmem_remove(segid);
|
||||
OKNG(rc != -1, "xpmem_remove failed (do twice to same segid)");
|
||||
}
|
||||
|
||||
printf("*** %s PASSED\n\n", basename(argv[0]));
|
||||
return 0;
|
||||
|
||||
fn_fail:
|
||||
printf("*** %s FAILED\n\n", basename(argv[0]));
|
||||
|
||||
return -1;
|
||||
}
|
||||
@@ -1,2 +0,0 @@
|
||||
PGSHIFT_LIST=(21 29 34)
|
||||
SMALL_PGSIZE=65536
|
||||
@@ -1,185 +0,0 @@
|
||||
*** C1259T01 start *******************************
|
||||
** xpem_attach to Huge mapped memory range
|
||||
** end of range is aligned with Large page size
|
||||
pageshift: 21
|
||||
** [ OK ] seg_addr (100000400000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100000400000) is allocated using large pages
|
||||
pageshift: 29
|
||||
** [ OK ] seg_addr (100020000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100020000000) is allocated using large pages
|
||||
pageshift: 34
|
||||
** [ OK ] seg_addr (100400000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100400000000) is allocated using large pages
|
||||
*** C1259T01: PASSED
|
||||
|
||||
*** C1259T02 start *******************************
|
||||
** xpem_attach to Huge mapped memory range
|
||||
** end of range is NOT aligned with Large page size
|
||||
pageshift: 21
|
||||
** [ OK ] seg_addr (100000400000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100000400000) is allocated using large pages
|
||||
pageshift: 29
|
||||
** [ OK ] seg_addr (100020000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100020000000) is allocated using large pages
|
||||
pageshift: 34
|
||||
** [ OK ] seg_addr (100400000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (100400000000) is allocated using large pages
|
||||
*** C1259T02: PASSED
|
||||
|
||||
*** C1259T03 start *******************************
|
||||
** xpem_attach to small mapped memory range
|
||||
pageshift: small page
|
||||
** [ OK ] xpmem_addr (100000210000) is allocated using small pages
|
||||
*** C1259T03: PASSED
|
||||
|
||||
*** C1259T04 start *******************************
|
||||
** xpem_attach to multi pagesize range
|
||||
pageshift: 21
|
||||
** [ OK ] xpmem_addr (100000400000) is allocated using large pages
|
||||
*** C1259T04: PASSED
|
||||
|
||||
*** C1259T05 start *******************************
|
||||
** xpmem testsuite
|
||||
XPMEM version = 26003
|
||||
|
||||
==== test_base STARTS ====
|
||||
xpmem_proc1: mypid = 10105
|
||||
xpmem_proc1: sharing 262144 bytes
|
||||
xpmem_proc1: segid = 200002779 at 0x100000210000
|
||||
|
||||
xpmem_proc2: mypid = 10303
|
||||
xpmem_proc2: segid = 200002779
|
||||
xpmem_proc2: attached at 0x100000210000
|
||||
xpmem_proc2: adding 1 to all elems
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_base PASSED ====
|
||||
|
||||
==== test_two_attach STARTS ====
|
||||
xpmem_proc1: mypid = 10528
|
||||
xpmem_proc1: sharing 262144 bytes
|
||||
xpmem_proc1: segid = 200002920 at 0x100000210000
|
||||
|
||||
xpmem_proc2: line 228: 11049 Segmentation fault rm -f "$progdir/$file"
|
||||
xpmem_proc2: mypid = 10733
|
||||
xpmem_proc2: segid = 200002920
|
||||
xpmem_proc2: attached at 0x100000210000
|
||||
xpmem_proc2: attached at 0x100000250000
|
||||
xpmem_proc2: adding 1 to all elems using 0x100000210000
|
||||
xpmem_proc2: adding 1 to all elems using 0x100000250000
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_two_attach PASSED ====
|
||||
|
||||
==== test_two_shares STARTS ====
|
||||
xpmem_proc1: mypid = 11064
|
||||
xpmem_proc1: sharing 2 segments, 262144 bytes each
|
||||
xpmem_proc1: segid[0] = 200002b38 at 0x100000210000
|
||||
xpmem_proc1: segid[1] = 400002b38 at 0x100000250000
|
||||
|
||||
xpmem_proc2: mypid = 11261
|
||||
xpmem_proc2: segid[0] = 200002b38
|
||||
xpmem_proc2: segid[1] = 400002b38
|
||||
xpmem_proc2: data[0] attached at 0x100000210000
|
||||
xpmem_proc2: data[1] attached at 0x100000250000
|
||||
xpmem_proc2: adding 1 to all elems using 0x100000210000
|
||||
xpmem_proc2: adding 1 to all elems using 0x100000250000
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_two_shares PASSED ====
|
||||
|
||||
==== test_fork STARTS ====
|
||||
xpmem_proc1: mypid = 11598
|
||||
xpmem_proc1: sharing 262144 bytes
|
||||
xpmem_proc1: segid = 200002d4e at 0x100000210000
|
||||
|
||||
xpmem_proc2: mypid = 11803
|
||||
xpmem_proc2: segid = 200002d4e
|
||||
xpmem_proc2: attached at 0x100000220000
|
||||
xpmem_proc2: reading to pin pages
|
||||
xpmem_proc2: waiting for COW...
|
||||
|
||||
xpmem_proc1: forking a child
|
||||
xpmem_proc1: adding 1 to all elems to induce COW
|
||||
|
||||
xpmem_child: hello from pid 12004
|
||||
|
||||
xpmem_proc1: give control back to xpmem_proc2
|
||||
|
||||
xpmem_proc2: adding 1 to all elems
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_fork PASSED ====
|
||||
|
||||
*** XTP_001 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get
|
||||
[OK] xpmem_attach
|
||||
[OK] xpmem_detach
|
||||
[OK] xpmem_remove
|
||||
*** XTP_001 PASSED
|
||||
|
||||
*** XTP_002 start ***
|
||||
[OK] xpmem_make in child
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] xpmem_remove in child
|
||||
*** XTP_002 PASSED
|
||||
|
||||
*** XTP_003 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_003 PASSED
|
||||
|
||||
*** XTP_004 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_004 PASSED
|
||||
|
||||
*** XTP_005 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_005 PASSED
|
||||
|
||||
*** XTP_006 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child failed (parent process exited already
|
||||
*** XTP_006 PASSED
|
||||
|
||||
*** XTP_007 start ***
|
||||
[OK] xpmem_make failed (invalid address)
|
||||
[OK] xpmem_make succeed(do twice to same address)
|
||||
*** XTP_007 PASSED
|
||||
|
||||
*** XTP_008 start ***
|
||||
[OK] xpmem_get in child failed (invalid segid)
|
||||
[OK] xpmem_get in child (do twice to same segid
|
||||
*** XTP_008 PASSED
|
||||
|
||||
*** XTP_009 start ***
|
||||
[OK] xpmem_attach in childi failed (invalid apid)
|
||||
[OK] xpmem_attach in child succeed (do twice to same apid)
|
||||
*** XTP_009 PASSED
|
||||
|
||||
*** XTP_010 start ***
|
||||
[OK] xpmem_detach in child succeed (invalid address)
|
||||
[OK] xpmem_detach in child succeed (do twice to same address)
|
||||
*** XTP_010 PASSED
|
||||
|
||||
*** XTP_011 start ***
|
||||
[OK] xpmem_remove failed (invalid segid)
|
||||
[OK] xpmem_remove failed (do twice to same segid)
|
||||
*** XTP_011 PASSED
|
||||
|
||||
@@ -1,182 +0,0 @@
|
||||
#include <unistd.h>
|
||||
#include <stdlib.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 "util.h"
|
||||
|
||||
#define DEBUG
|
||||
|
||||
#define SHM_SIZE (1UL << 12)
|
||||
|
||||
#define MAP_HUGE_SHIFT 26
|
||||
#define KEYWORD 0x12345678UL
|
||||
|
||||
void usage(void)
|
||||
{
|
||||
printf("Usage: huge_page_map: <pgshift> <pgnum> <pgoffset>\n");
|
||||
printf("\tpgshift : pageshift of map area (Using MAP_HUGETLB)\n");
|
||||
printf("\t -1 means using small pagesize\n");
|
||||
printf("\tpgnum : number of page of map area\n");
|
||||
printf("\tpgoffset: offset of last page\n");
|
||||
}
|
||||
|
||||
|
||||
void *mmap_flag(size_t mapsize, int page_shift)
|
||||
{
|
||||
char *addr_mmap;
|
||||
int flags = MAP_ANONYMOUS | MAP_PRIVATE;
|
||||
|
||||
if (page_shift >= 0) {
|
||||
/* mean use MAP_HUGETLB */
|
||||
flags |= MAP_HUGETLB | (page_shift << MAP_HUGE_SHIFT);
|
||||
}
|
||||
|
||||
addr_mmap = mmap(0, mapsize,
|
||||
PROT_READ | PROT_WRITE,
|
||||
flags, -1, 0);
|
||||
|
||||
return addr_mmap;
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem;
|
||||
int ret = 0;
|
||||
pid_t pid;
|
||||
int status;
|
||||
key_t key = ftok(argv[0], 0);
|
||||
void *shm;
|
||||
int shmid;
|
||||
xpmem_segid_t segid;
|
||||
struct shmid_ds shmctl_buf;
|
||||
int pgshift, pgnum;
|
||||
size_t pgsize, map_size, pgoffset;
|
||||
|
||||
if (argc < 4) {
|
||||
printf("Err: Too few arguments\n");
|
||||
usage();
|
||||
return -1;
|
||||
}
|
||||
|
||||
pgshift = atoi(argv[1]);
|
||||
pgnum = atoi(argv[2]);
|
||||
pgoffset = atol(argv[3]);
|
||||
if (pgshift > 0) {
|
||||
pgsize = (1UL << pgshift);
|
||||
} else {
|
||||
pgsize = getpagesize();
|
||||
}
|
||||
|
||||
if (pgoffset > 0) {
|
||||
map_size = (pgsize * (pgnum - 1)) + pgoffset;
|
||||
} else {
|
||||
map_size = pgsize * pgnum;
|
||||
}
|
||||
|
||||
shmid = shmget(key, SHM_SIZE, IPC_CREAT | 0660);
|
||||
CHKANDJUMP(shmid == -1, EXIT_FAILURE, "shmget failed: %s\n",
|
||||
strerror(errno));
|
||||
|
||||
printf("EXPECT_PAGE_SIZE: 0x%lx\n", pgsize);
|
||||
fflush(stdout);
|
||||
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, EXIT_FAILURE, "fork failed\n");
|
||||
if (pid == 0) {
|
||||
xpmem_apid_t apid;
|
||||
struct xpmem_addr addr;
|
||||
void *attach;
|
||||
|
||||
shm = shmat(shmid, NULL, 0);
|
||||
CHKANDJUMP(shm == (void *)-1, EXIT_FAILURE,
|
||||
"shmat failed: %s\n", strerror(errno));
|
||||
|
||||
while ((segid = *(xpmem_segid_t *)shm) == 0) {
|
||||
};
|
||||
|
||||
ret = shmdt(shm);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmdt failed\n");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR,
|
||||
XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, EXIT_FAILURE, "xpmem_get failed: %s\n",
|
||||
strerror(errno));
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, pgsize * pgnum, NULL);
|
||||
|
||||
CHKANDJUMP(attach == (void *)-1, EXIT_FAILURE,
|
||||
"xpmem_attach failed: %s\n", strerror(errno));
|
||||
|
||||
printf("child: xpmem_attachment_addr: %lx\n",
|
||||
attach);
|
||||
|
||||
*((unsigned long *)attach) = KEYWORD;
|
||||
if (pgnum > 1 && pgshift > 0) {
|
||||
*((unsigned long *)(attach +
|
||||
(1UL << pgshift))) = KEYWORD;
|
||||
}
|
||||
*((unsigned long *)(attach + map_size
|
||||
- sizeof(unsigned long *))) = KEYWORD;
|
||||
|
||||
ret = xpmem_detach(attach);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "xpmem_detach failed\n");
|
||||
|
||||
exit(0);
|
||||
} else {
|
||||
mem = mmap_flag(map_size, pgshift);
|
||||
CHKANDJUMP(mem == MAP_FAILED, EXIT_FAILURE, "mmap failed\n");
|
||||
printf("parent: anonymous_map_addr: %lx - %lx\n",
|
||||
mem, mem + map_size);
|
||||
|
||||
shm = shmat(shmid, NULL, 0);
|
||||
|
||||
CHKANDJUMP(shm == (void *)-1, EXIT_FAILURE,
|
||||
"shmat failed: %s\n", strerror(errno));
|
||||
|
||||
segid = xpmem_make(mem, map_size, XPMEM_PERMIT_MODE,
|
||||
(void *)0666);
|
||||
CHKANDJUMP(segid == -1, EXIT_FAILURE,
|
||||
"xpmem_ioctl failed: %s\n", strerror(errno));
|
||||
|
||||
*(xpmem_segid_t *)shm = segid;
|
||||
|
||||
ret = waitpid(pid, &status, 0);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "waitpid failed\n");
|
||||
|
||||
NG(*(unsigned long *)mem == KEYWORD,
|
||||
"HEAD of xpmem area is INVALID. isn't shared?\n");
|
||||
if (pgnum > 1 && pgshift > 0) {
|
||||
NG(*((unsigned long *)(mem +
|
||||
(1UL << pgshift))) == KEYWORD,
|
||||
"MIDDLE of xpmem area is INVALID. isn't shared?\n");
|
||||
}
|
||||
NG(*((unsigned long *)(mem + map_size
|
||||
- sizeof(unsigned long *))) == KEYWORD,
|
||||
"TAIL of xpmem area is INVALID. isn't shared?\n");
|
||||
printf("xpmem area is shared: OK\n");
|
||||
|
||||
ret = shmctl(shmid, IPC_RMID, &shmctl_buf);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmctl failed\n");
|
||||
|
||||
ret = shmdt(shm);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmdt failed\n");
|
||||
|
||||
ret = xpmem_remove(segid);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "xpmem_remove failed\n");
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
out:
|
||||
return ret;
|
||||
}
|
||||
@@ -1,99 +0,0 @@
|
||||
diff --git arch/arm64/kernel/memory.c arch/arm64/kernel/memory.c
|
||||
index a84bc21..7368ada 100644
|
||||
--- arch/arm64/kernel/memory.c
|
||||
+++ arch/arm64/kernel/memory.c
|
||||
@@ -2701,6 +2701,13 @@ int set_range_l1(void *args0, pte_t *ptep, uintptr_t base, uintptr_t start,
|
||||
ptl1_set(ptep, pte);
|
||||
|
||||
error = 0;
|
||||
+
|
||||
+ if (args->attr[0] & PTE_CONT &&
|
||||
+ __page_offset(base, PTL1_CONT_SIZE) == 0) {
|
||||
+ kprintf("%s: large_page_allocation, addr: %016lx, size: 0x%lx , phys: %lx\n",
|
||||
+ __func__, base, PTL1_CONT_SIZE, phys);
|
||||
+ }
|
||||
+
|
||||
// call memory_stat_rss_add() here because pgshift is resolved here
|
||||
if (!(args->attr[0] & PTE_CONT)) {
|
||||
if (rusage_memory_stat_add(args->range, phys,
|
||||
@@ -2810,6 +2817,17 @@ retry:
|
||||
level);
|
||||
|
||||
error = 0;
|
||||
+
|
||||
+ if (args->attr[level-1] & PTE_CONT) {
|
||||
+ if (__page_offset(base, tbl.cont_pgsize) == 0) {
|
||||
+ kprintf("%s: large_page_allocation, addr: %016lx, size: 0x%lx , phys: %lx\n",
|
||||
+ __func__, base, tbl.cont_pgsize, phys);
|
||||
+ }
|
||||
+ } else {
|
||||
+ kprintf("%s: large_page_allocation, addr: %016lx, size: 0x%lx , phys: %lx\n",
|
||||
+ __func__, base, tbl.pgsize, phys);
|
||||
+ }
|
||||
+
|
||||
dkprintf("set_range_middle(%lx,%lx,%lx,%d):"
|
||||
"large page. %d %lx\n",
|
||||
base, start, end, level, error, *ptep);
|
||||
diff --git arch/x86_64/kernel/memory.c arch/x86_64/kernel/memory.c
|
||||
index df545e1..633e390 100644
|
||||
--- arch/x86_64/kernel/memory.c
|
||||
+++ arch/x86_64/kernel/memory.c
|
||||
@@ -1931,6 +1931,10 @@ retry:
|
||||
dkprintf("set_range_l2(%lx,%lx,%lx):"
|
||||
"2MiB page. %d %lx\n",
|
||||
base, start, end, error, *ptep);
|
||||
+
|
||||
+ kprintf("%s: large_page_allocation, addr: %016lx, size: 0x%lx\n",
|
||||
+ __func__, base, PTL2_SIZE);
|
||||
+
|
||||
// Call memory_stat_rss_add() here because pgshift is resolved here
|
||||
if (rusage_memory_stat_add(args->range, phys, PTL2_SIZE, PTL2_SIZE)) {
|
||||
dkprintf("%lx+,%s: calling memory_stat_rss_add(),base=%lx,phys=%lx,size=%ld,pgsize=%ld\n", phys, __FUNCTION__, base, phys, PTL2_SIZE, PTL2_SIZE);
|
||||
@@ -2020,6 +2024,9 @@ retry:
|
||||
"1GiB page. %d %lx\n",
|
||||
base, start, end, error, *ptep);
|
||||
|
||||
+ kprintf("%s: large_page_allocation, addr: %016lx, size: 0x%lx\n",
|
||||
+ __func__, base, PTL3_SIZE);
|
||||
+
|
||||
// Call memory_stat_rss_add() here because pgshift is resolved here
|
||||
if (rusage_memory_stat_add(args->range, phys, PTL3_SIZE, PTL3_SIZE)) {
|
||||
dkprintf("%lx+,%s: calling memory_stat_rss_add(),base=%lx,phys=%lx,size=%ld,pgsize=%ld\n", phys, __FUNCTION__, base, phys, PTL3_SIZE, PTL3_SIZE);
|
||||
diff --git kernel/process.c kernel/process.c
|
||||
index 809f5e0..cba9e5a 100644
|
||||
--- kernel/process.c
|
||||
+++ kernel/process.c
|
||||
@@ -2059,6 +2059,12 @@ retry:
|
||||
}
|
||||
|
||||
dkprintf("%s: attr=%x\n", __FUNCTION__, attr);
|
||||
+
|
||||
+ if (pgsize > PAGE_SIZE) {
|
||||
+ kprintf("large_page_allocation, addr: %016lx, size: %d, phys: %lx\n",
|
||||
+ pgaddr, pgsize, phys);
|
||||
+ }
|
||||
+
|
||||
error = ihk_mc_pt_set_pte(vm->address_space->page_table, ptep,
|
||||
pgsize, phys, attr);
|
||||
if (error) {
|
||||
diff --git kernel/xpmem.c kernel/xpmem.c
|
||||
index e1d0231..c9da711 100644
|
||||
--- kernel/xpmem.c
|
||||
+++ kernel/xpmem.c
|
||||
@@ -514,6 +514,7 @@ static int xpmem_make(
|
||||
*segid_p = segid;
|
||||
|
||||
XPMEM_DEBUG("return: ret=%d, segid=0x%lx", 0, *segid_p);
|
||||
+ kprintf("%s: DONE\n", __func__);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -1994,6 +1995,8 @@ int xpmem_update_process_page_table(
|
||||
flush_tlb_single(vaddr);
|
||||
att->flags |= XPMEM_FLAG_VALIDPTEs;
|
||||
|
||||
+ kprintf("%s: xpmem_page_attach, addr: %016lx, size: 0x%lx\n",
|
||||
+ __func__, vaddr, seg_pgsize);
|
||||
seg_vaddr += seg_pgsize;
|
||||
vaddr += seg_pgsize;
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
test -e /tmp/xpmem.share && rm -f /tmp/xpmem.share
|
||||
test -e /tmp/xpmem.lock && rm -f /tmp/xpmem.lock
|
||||
|
||||
# create TMP_SHARE_SIZE bytes defined in xpmem_test.h
|
||||
for i in `seq 0 31` ; do
|
||||
echo -n 0 >> /tmp/xpmem.share
|
||||
done
|
||||
echo 0 > /tmp/xpmem.lock
|
||||
|
||||
# Run the main test app
|
||||
mcexec $PWD/xpmem_master
|
||||
exit 0
|
||||
|
||||
@@ -1,187 +0,0 @@
|
||||
#include <unistd.h>
|
||||
#include <stdlib.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 "util.h"
|
||||
|
||||
#define DEBUG
|
||||
|
||||
#define SHM_SIZE (1UL << 12)
|
||||
|
||||
#define MAP_HUGE_SHIFT 26
|
||||
#define KEYWORD 0x12345678UL
|
||||
|
||||
void usage(void)
|
||||
{
|
||||
printf("Usage: multi_vmr_xpmem: <pgshift> <pgnum>\n");
|
||||
printf("\tpgshift : pageshift of map area (Using MAP_HUGETLB)\n");
|
||||
printf("\t -1 means using small pagesize\n");
|
||||
printf("\tpgnum : number of page of map area\n");
|
||||
}
|
||||
|
||||
|
||||
void *mmap_flag(size_t mapsize, int page_shift)
|
||||
{
|
||||
char *addr_mmap;
|
||||
int flags = MAP_ANONYMOUS | MAP_PRIVATE;
|
||||
|
||||
if (page_shift >= 0) {
|
||||
/* mean use MAP_HUGETLB */
|
||||
flags |= MAP_HUGETLB | (page_shift << MAP_HUGE_SHIFT);
|
||||
}
|
||||
|
||||
addr_mmap = mmap(0, mapsize * 2,
|
||||
PROT_READ | PROT_WRITE,
|
||||
flags, -1, 0);
|
||||
|
||||
/* Make sure that area before addr_map is available to
|
||||
* MAP_FIXED map
|
||||
*/
|
||||
return addr_mmap + mapsize;
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
void *mem, *mem_1, *mem_2;
|
||||
int ret = 0;
|
||||
pid_t pid;
|
||||
int status;
|
||||
key_t key = ftok(argv[0], 10);
|
||||
void *shm;
|
||||
int shmid;
|
||||
xpmem_segid_t segid;
|
||||
struct shmid_ds shmctl_buf;
|
||||
int pgshift, pgnum;
|
||||
size_t extr_size, pgsize, map_size;
|
||||
|
||||
if (argc < 3) {
|
||||
printf("Err: Too few arguments\n");
|
||||
usage();
|
||||
return -1;
|
||||
}
|
||||
|
||||
pgshift = atoi(argv[1]);
|
||||
pgnum = atoi(argv[2]);
|
||||
extr_size = getpagesize() * 3;
|
||||
if (pgshift > 0) {
|
||||
pgsize = (1UL << pgshift);
|
||||
} else {
|
||||
pgsize = getpagesize();
|
||||
}
|
||||
|
||||
map_size = pgsize * pgnum;
|
||||
|
||||
shmid = shmget(key, SHM_SIZE, IPC_CREAT | 0660);
|
||||
CHKANDJUMP(shmid == -1, EXIT_FAILURE, "shmget failed: %s\n",
|
||||
strerror(errno));
|
||||
|
||||
printf("EXPECT_PAGE_SIZE: 0x%lx\n", pgsize);
|
||||
fflush(stdout);
|
||||
|
||||
pid = fork();
|
||||
CHKANDJUMP(pid == -1, EXIT_FAILURE, "fork failed\n");
|
||||
if (pid == 0) {
|
||||
xpmem_apid_t apid;
|
||||
struct xpmem_addr addr;
|
||||
void *attach;
|
||||
|
||||
shm = shmat(shmid, NULL, 0);
|
||||
CHKANDJUMP(shm == (void *)-1, EXIT_FAILURE,
|
||||
"shmat failed: %s\n", strerror(errno));
|
||||
|
||||
while ((segid = *(xpmem_segid_t *)shm) == 0) {
|
||||
};
|
||||
ret = shmdt(shm);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmdt failed\n");
|
||||
|
||||
apid = xpmem_get(segid, XPMEM_RDWR,
|
||||
XPMEM_PERMIT_MODE, NULL);
|
||||
CHKANDJUMP(apid == -1, EXIT_FAILURE, "xpmem_get failed: %s\n",
|
||||
strerror(errno));
|
||||
|
||||
addr.apid = apid;
|
||||
addr.offset = 0;
|
||||
attach = xpmem_attach(addr, map_size + (extr_size * 2), NULL);
|
||||
|
||||
CHKANDJUMP(attach == (void *)-1, EXIT_FAILURE,
|
||||
"xpmem_attach failed: %s\n", strerror(errno));
|
||||
|
||||
printf("child: xpmem_attachment_addr: %lx - %lx\n",
|
||||
attach, attach + map_size + (extr_size * 2));
|
||||
printf("child: xpmem_large: %lx\n", attach + extr_size);
|
||||
|
||||
*((unsigned long *)attach) = KEYWORD;
|
||||
*((unsigned long *)(attach + extr_size)) = KEYWORD;
|
||||
*((unsigned long *)(attach + extr_size * 2 + map_size
|
||||
- sizeof(unsigned long *))) = KEYWORD;
|
||||
|
||||
ret = xpmem_detach(attach);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "xpmem_detach failed\n");
|
||||
|
||||
exit(0);
|
||||
} else {
|
||||
mem = mmap_flag(map_size, pgshift);
|
||||
CHKANDJUMP(mem == MAP_FAILED, EXIT_FAILURE, "mmap failed\n");
|
||||
mem_1 = mmap(mem - extr_size, extr_size,
|
||||
PROT_READ | PROT_WRITE,
|
||||
MAP_ANONYMOUS | MAP_PRIVATE | MAP_FIXED,
|
||||
-1, 0);
|
||||
mem_2 = mmap(mem + map_size, extr_size,
|
||||
PROT_READ | PROT_WRITE,
|
||||
MAP_ANONYMOUS | MAP_PRIVATE | MAP_FIXED,
|
||||
-1, 0);
|
||||
if ((mem_1 + extr_size != mem) || (mem_2 != mem + map_size)) {
|
||||
printf("vm_range is NOT contignuous!!\n");
|
||||
exit(1);
|
||||
}
|
||||
printf("parent: anonymous_map_addr: %lx - %lx\n",
|
||||
mem_1, mem_2 + extr_size);
|
||||
|
||||
shm = shmat(shmid, NULL, 0);
|
||||
|
||||
CHKANDJUMP(shm == (void *)-1, EXIT_FAILURE,
|
||||
"shmat failed: %s\n", strerror(errno));
|
||||
|
||||
segid = xpmem_make(mem_1, map_size + (extr_size * 2),
|
||||
XPMEM_PERMIT_MODE, (void *)0666);
|
||||
CHKANDJUMP(segid == -1, EXIT_FAILURE,
|
||||
"xpmem_ioctl failed: %s\n", strerror(errno));
|
||||
|
||||
*(xpmem_segid_t *)shm = segid;
|
||||
|
||||
ret = waitpid(pid, &status, 0);
|
||||
printf("child exited\n");
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "waitpid failed\n");
|
||||
|
||||
NG(*(unsigned long *)mem_1 == KEYWORD,
|
||||
"HEAD of xpmem area is INVALID. isn't shared?\n");
|
||||
NG(*(unsigned long *)mem == KEYWORD,
|
||||
"MIDDLE of xpmem area is INVALID. isn't shared?\n");
|
||||
NG(*((unsigned long *)(mem_2 + extr_size
|
||||
- sizeof(unsigned long *))) == KEYWORD,
|
||||
"TAIL of xpmem area is INVALID. isn't shared?\n");
|
||||
printf("xpmem area is shared: OK\n");
|
||||
|
||||
ret = shmctl(shmid, IPC_RMID, &shmctl_buf);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmctl failed\n");
|
||||
|
||||
ret = shmdt(shm);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "shmdt failed\n");
|
||||
|
||||
ret = xpmem_remove(segid);
|
||||
CHKANDJUMP(ret == -1, EXIT_FAILURE, "xpmem_remove failed\n");
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
out:
|
||||
return ret;
|
||||
}
|
||||
@@ -1,28 +0,0 @@
|
||||
#ifndef __UTIL_H_INCLUDED__
|
||||
#define __UTIL_H_INCLUDED__
|
||||
|
||||
#define CHKANDJUMP(cond, err, ...) do { \
|
||||
if (cond) { \
|
||||
printf(__VA_ARGS__); \
|
||||
ret = err; \
|
||||
goto out; \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define _OKNG(verb, jump, cond, fmt, args...) do { \
|
||||
if (cond) { \
|
||||
if (verb) \
|
||||
printf("[ OK ] " fmt, ##args); \
|
||||
} else { \
|
||||
printf("[ NG ] " fmt, ##args); \
|
||||
if (jump) \
|
||||
goto out; \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define OKNG(args...) _OKNG(1, 1, ##args)
|
||||
#define NG(args...) _OKNG(0, 1, ##args)
|
||||
#define OKNGNOJUMP(args...) _OKNG(1, 0, ##args)
|
||||
|
||||
#endif
|
||||
|
||||
@@ -1,31 +0,0 @@
|
||||
#define CHKANDJUMP(cond, ...) do { \
|
||||
if (cond) { \
|
||||
fprintf(stderr, " [NG] "); \
|
||||
fprintf(stderr, __VA_ARGS__); \
|
||||
fprintf(stderr, " failed\n"); \
|
||||
goto fn_fail; \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define OKNG(cond, ...) do { \
|
||||
if (cond) { \
|
||||
CHKANDJUMP(cond, __VA_ARGS__); \
|
||||
} else { \
|
||||
fprintf(stdout, " [OK] "); \
|
||||
fprintf(stdout, __VA_ARGS__); \
|
||||
fprintf(stdout, "\n"); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
|
||||
#ifdef __aarch64__
|
||||
#define LARGE_PAGE_SHIFT 21
|
||||
#elif defined(__x86_64__)
|
||||
#define LARGE_PAGE_SHIFT 21
|
||||
#else
|
||||
#error "Non-compliant architecture."
|
||||
#endif
|
||||
|
||||
#define MAP_HUGE_SHIFT 26
|
||||
#define SZ_MEM (2 * (1ULL << LARGE_PAGE_SHIFT))
|
||||
#define TEST_VAL 0x1129
|
||||
@@ -1,2 +0,0 @@
|
||||
PGSHIFT_LIST=(21 30)
|
||||
SMALL_PGSIZE=4096
|
||||
@@ -1,178 +0,0 @@
|
||||
*** C1259T01 start *******************************
|
||||
** xpem_attach to Huge mapped memory range
|
||||
** end of range is aligned with Large page size
|
||||
pageshift: 21
|
||||
** [ OK ] seg_addr (2aaaab000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (2aaaab000000) is allocated using large pages
|
||||
pageshift: 30
|
||||
** [ OK ] seg_addr (2aaac0000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (2aaac0000000) is allocated using large pages
|
||||
*** C1259T01: PASSED
|
||||
|
||||
*** C1259T02 start *******************************
|
||||
** xpem_attach to Huge mapped memory range
|
||||
** end of range is NOT aligned with Large page size
|
||||
pageshift: 21
|
||||
** [ OK ] seg_addr (2aaaab000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (2aaaab000000) is allocated using large pages
|
||||
pageshift: 30
|
||||
** [ OK ] seg_addr (2aaac0000000) is allocated until xpmem_attach
|
||||
** [ OK ] xpmem_addr (2aaac0000000) is allocated using large pages
|
||||
*** C1259T02: PASSED
|
||||
|
||||
*** C1259T03 start *******************************
|
||||
** xpem_attach to small mapped memory range
|
||||
pageshift: small page
|
||||
** [ OK ] xpmem_addr (2aaaaafee000) is allocated using small pages
|
||||
*** C1259T03: PASSED
|
||||
|
||||
*** C1259T04 start *******************************
|
||||
** xpem_attach to multi pagesize range
|
||||
pageshift: 21
|
||||
** [ OK ] xpmem_addr (2aaaab000000) is allocated using large pages
|
||||
*** C1259T04: PASSED
|
||||
|
||||
*** C1259T05 start *******************************
|
||||
** xpmem testsuite
|
||||
XPMEM version = 26003
|
||||
|
||||
==== test_base STARTS ====
|
||||
xpmem_proc1: mypid = 13702
|
||||
xpmem_proc1: sharing 16384 bytes
|
||||
xpmem_proc1: segid = 200003586 at 0x2aaaaafee000
|
||||
|
||||
xpmem_proc2: mypid = 14123
|
||||
xpmem_proc2: segid = 200003586
|
||||
xpmem_proc2: attached at 0x2aaaaafee000
|
||||
xpmem_proc2: adding 1 to all elems
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_base PASSED ====
|
||||
|
||||
==== test_two_attach STARTS ====
|
||||
xpmem_proc1: mypid = 14543
|
||||
xpmem_proc1: sharing 16384 bytes
|
||||
xpmem_proc1: segid = 2000038cf at 0x2aaaaafee000
|
||||
|
||||
xpmem_proc2: mypid = 14963
|
||||
xpmem_proc2: segid = 2000038cf
|
||||
xpmem_proc2: attached at 0x2aaaaafee000
|
||||
xpmem_proc2: attached at 0x2aaaaaff2000
|
||||
xpmem_proc2: adding 1 to all elems using 0x2aaaaafee000
|
||||
xpmem_proc2: adding 1 to all elems using 0x2aaaaaff2000
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_two_attach PASSED ====
|
||||
|
||||
==== test_two_shares STARTS ====
|
||||
xpmem_proc1: mypid = 15383
|
||||
xpmem_proc1: sharing 2 segments, 16384 bytes each
|
||||
xpmem_proc1: segid[0] = 200003c17 at 0x2aaaaafee000
|
||||
xpmem_proc1: segid[1] = 400003c17 at 0x2aaaaaff2000
|
||||
|
||||
xpmem_proc2: mypid = 15807
|
||||
xpmem_proc2: segid[0] = 200003c17
|
||||
xpmem_proc2: segid[1] = 400003c17
|
||||
xpmem_proc2: data[0] attached at 0x2aaaaafee000
|
||||
xpmem_proc2: data[1] attached at 0x2aaaaaff2000
|
||||
xpmem_proc2: adding 1 to all elems using 0x2aaaaafee000
|
||||
xpmem_proc2: adding 1 to all elems using 0x2aaaaaff2000
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_two_shares PASSED ====
|
||||
|
||||
==== test_fork STARTS ====
|
||||
xpmem_proc1: mypid = 16227
|
||||
xpmem_proc1: sharing 16384 bytes
|
||||
xpmem_proc1: segid = 200003f63 at 0x2aaaaafee000
|
||||
|
||||
xpmem_proc2: mypid = 16647
|
||||
xpmem_proc2: segid = 200003f63
|
||||
xpmem_proc2: attached at 0x2aaaaafef000
|
||||
xpmem_proc2: reading to pin pages
|
||||
xpmem_proc2: waiting for COW...
|
||||
|
||||
xpmem_proc1: forking a child
|
||||
xpmem_proc1: adding 1 to all elems to induce COW
|
||||
xpmem_proc1: give control back to xpmem_proc2
|
||||
|
||||
|
||||
xpmem_child: hello from pid 17067
|
||||
|
||||
xpmem_proc2: adding 1 to all elems
|
||||
|
||||
xpmem_proc1: verifying data...done
|
||||
==== test_fork PASSED ====
|
||||
|
||||
*** XTP_001 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get
|
||||
[OK] xpmem_attach
|
||||
[OK] xpmem_detach
|
||||
[OK] xpmem_remove
|
||||
*** XTP_001 PASSED
|
||||
|
||||
*** XTP_002 start ***
|
||||
[OK] xpmem_make in child
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] xpmem_remove in child
|
||||
*** XTP_002 PASSED
|
||||
|
||||
*** XTP_003 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_003 PASSED
|
||||
|
||||
*** XTP_004 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] xpmem_detach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_004 PASSED
|
||||
|
||||
*** XTP_005 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child
|
||||
[OK] xpmem_attach in child
|
||||
[OK] validate TEST_VAL
|
||||
[OK] xpmem_remove
|
||||
*** XTP_005 PASSED
|
||||
|
||||
*** XTP_006 start ***
|
||||
[OK] xpmem_make
|
||||
[OK] xpmem_get in child failed (parent process exited already
|
||||
*** XTP_006 PASSED
|
||||
|
||||
*** XTP_007 start ***
|
||||
[OK] xpmem_make failed (invalid address)
|
||||
[OK] xpmem_make succeed(do twice to same address)
|
||||
*** XTP_007 PASSED
|
||||
|
||||
*** XTP_008 start ***
|
||||
[OK] xpmem_get in child failed (invalid segid)
|
||||
[OK] xpmem_get in child (do twice to same segid
|
||||
*** XTP_008 PASSED
|
||||
|
||||
*** XTP_009 start ***
|
||||
[OK] xpmem_attach in childi failed (invalid apid)
|
||||
[OK] xpmem_attach in child succeed (do twice to same apid)
|
||||
*** XTP_009 PASSED
|
||||
|
||||
*** XTP_010 start ***
|
||||
[OK] xpmem_detach in child succeed (invalid address)
|
||||
[OK] xpmem_detach in child succeed (do twice to same address)
|
||||
*** XTP_010 PASSED
|
||||
|
||||
*** XTP_011 start ***
|
||||
[OK] xpmem_remove failed (invalid segid)
|
||||
[OK] xpmem_remove failed (do twice to same segid)
|
||||
*** XTP_011 PASSED
|
||||
|
||||
Reference in New Issue
Block a user