diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-03 20:12:13 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-03 20:12:13 -0400 |
commit | 7f0ef0267e20d62d45d527911a993b1e998f4968 (patch) | |
tree | de51abc7da5903f59d83e23937f22420164c9477 /tools | |
parent | 862f0012549110d6f2586bf54b52ed4540cbff3a (diff) | |
parent | 9307c29524502c21f0e8a6d96d850b2f5bc0bd9a (diff) |
Merge branch 'akpm' (updates from Andrew Morton)
Merge first patch-bomb from Andrew Morton:
- various misc bits
- I'm been patchmonkeying ocfs2 for a while, as Joel and Mark have been
distracted. There has been quite a bit of activity.
- About half the MM queue
- Some backlight bits
- Various lib/ updates
- checkpatch updates
- zillions more little rtc patches
- ptrace
- signals
- exec
- procfs
- rapidio
- nbd
- aoe
- pps
- memstick
- tools/testing/selftests updates
* emailed patches from Andrew Morton <akpm@linux-foundation.org>: (445 commits)
tools/testing/selftests: don't assume the x bit is set on scripts
selftests: add .gitignore for kcmp
selftests: fix clean target in kcmp Makefile
selftests: add .gitignore for vm
selftests: add hugetlbfstest
self-test: fix make clean
selftests: exit 1 on failure
kernel/resource.c: remove the unneeded assignment in function __find_resource
aio: fix wrong comment in aio_complete()
drivers/w1/slaves/w1_ds2408.c: add magic sequence to disable P0 test mode
drivers/memstick/host/r592.c: convert to module_pci_driver
drivers/memstick/host/jmb38x_ms: convert to module_pci_driver
pps-gpio: add device-tree binding and support
drivers/pps/clients/pps-gpio.c: convert to module_platform_driver
drivers/pps/clients/pps-gpio.c: convert to devm_* helpers
drivers/parport/share.c: use kzalloc
Documentation/accounting/getdelays.c: avoid strncpy in accounting tool
aoe: update internal version number to v83
aoe: update copyright date
aoe: perform I/O completions in parallel
...
Diffstat (limited to 'tools')
-rw-r--r-- | tools/testing/selftests/cpu-hotplug/Makefile | 2 | ||||
-rw-r--r-- | tools/testing/selftests/kcmp/.gitignore | 2 | ||||
-rw-r--r-- | tools/testing/selftests/kcmp/Makefile | 3 | ||||
-rw-r--r-- | tools/testing/selftests/memory-hotplug/Makefile | 2 | ||||
-rw-r--r-- | tools/testing/selftests/vm/.gitignore | 4 | ||||
-rw-r--r-- | tools/testing/selftests/vm/Makefile | 7 | ||||
-rw-r--r-- | tools/testing/selftests/vm/hugetlbfstest.c | 84 | ||||
-rw-r--r-- | tools/testing/selftests/vm/run_vmtests | 16 |
8 files changed, 113 insertions, 7 deletions
diff --git a/tools/testing/selftests/cpu-hotplug/Makefile b/tools/testing/selftests/cpu-hotplug/Makefile index 12657a5e4bf9..ae5faf9aade2 100644 --- a/tools/testing/selftests/cpu-hotplug/Makefile +++ b/tools/testing/selftests/cpu-hotplug/Makefile | |||
@@ -1,6 +1,6 @@ | |||
1 | all: | 1 | all: |
2 | 2 | ||
3 | run_tests: | 3 | run_tests: |
4 | @./on-off-test.sh || echo "cpu-hotplug selftests: [FAIL]" | 4 | @/bin/sh ./on-off-test.sh || echo "cpu-hotplug selftests: [FAIL]" |
5 | 5 | ||
6 | clean: | 6 | clean: |
diff --git a/tools/testing/selftests/kcmp/.gitignore b/tools/testing/selftests/kcmp/.gitignore new file mode 100644 index 000000000000..5a9b3732b2de --- /dev/null +++ b/tools/testing/selftests/kcmp/.gitignore | |||
@@ -0,0 +1,2 @@ | |||
1 | kcmp_test | ||
2 | kcmp-test-file | ||
diff --git a/tools/testing/selftests/kcmp/Makefile b/tools/testing/selftests/kcmp/Makefile index 56eb5523dbb8..d7d6bbeeff2f 100644 --- a/tools/testing/selftests/kcmp/Makefile +++ b/tools/testing/selftests/kcmp/Makefile | |||
@@ -25,5 +25,4 @@ run_tests: all | |||
25 | @./kcmp_test || echo "kcmp_test: [FAIL]" | 25 | @./kcmp_test || echo "kcmp_test: [FAIL]" |
26 | 26 | ||
27 | clean: | 27 | clean: |
28 | rm -fr ./run_test | 28 | $(RM) kcmp_test kcmp-test-file |
29 | rm -fr ./test-file | ||
diff --git a/tools/testing/selftests/memory-hotplug/Makefile b/tools/testing/selftests/memory-hotplug/Makefile index 0f49c3f5f58d..350bfeda3aa8 100644 --- a/tools/testing/selftests/memory-hotplug/Makefile +++ b/tools/testing/selftests/memory-hotplug/Makefile | |||
@@ -1,6 +1,6 @@ | |||
1 | all: | 1 | all: |
2 | 2 | ||
3 | run_tests: | 3 | run_tests: |
4 | @./on-off-test.sh || echo "memory-hotplug selftests: [FAIL]" | 4 | @/bin/sh ./on-off-test.sh || echo "memory-hotplug selftests: [FAIL]" |
5 | 5 | ||
6 | clean: | 6 | clean: |
diff --git a/tools/testing/selftests/vm/.gitignore b/tools/testing/selftests/vm/.gitignore new file mode 100644 index 000000000000..ff1bb16cec4f --- /dev/null +++ b/tools/testing/selftests/vm/.gitignore | |||
@@ -0,0 +1,4 @@ | |||
1 | hugepage-mmap | ||
2 | hugepage-shm | ||
3 | map_hugetlb | ||
4 | thuge-gen | ||
diff --git a/tools/testing/selftests/vm/Makefile b/tools/testing/selftests/vm/Makefile index 436d2e81868b..3f94e1afd6cf 100644 --- a/tools/testing/selftests/vm/Makefile +++ b/tools/testing/selftests/vm/Makefile | |||
@@ -2,13 +2,14 @@ | |||
2 | 2 | ||
3 | CC = $(CROSS_COMPILE)gcc | 3 | CC = $(CROSS_COMPILE)gcc |
4 | CFLAGS = -Wall | 4 | CFLAGS = -Wall |
5 | BINARIES = hugepage-mmap hugepage-shm map_hugetlb thuge-gen hugetlbfstest | ||
5 | 6 | ||
6 | all: hugepage-mmap hugepage-shm map_hugetlb thuge-gen | 7 | all: $(BINARIES) |
7 | %: %.c | 8 | %: %.c |
8 | $(CC) $(CFLAGS) -o $@ $^ | 9 | $(CC) $(CFLAGS) -o $@ $^ |
9 | 10 | ||
10 | run_tests: all | 11 | run_tests: all |
11 | @/bin/sh ./run_vmtests || echo "vmtests: [FAIL]" | 12 | @/bin/sh ./run_vmtests || (echo "vmtests: [FAIL]"; exit 1) |
12 | 13 | ||
13 | clean: | 14 | clean: |
14 | $(RM) hugepage-mmap hugepage-shm map_hugetlb | 15 | $(RM) $(BINARIES) |
diff --git a/tools/testing/selftests/vm/hugetlbfstest.c b/tools/testing/selftests/vm/hugetlbfstest.c new file mode 100644 index 000000000000..ea40ff8c2391 --- /dev/null +++ b/tools/testing/selftests/vm/hugetlbfstest.c | |||
@@ -0,0 +1,84 @@ | |||
1 | #define _GNU_SOURCE | ||
2 | #include <assert.h> | ||
3 | #include <fcntl.h> | ||
4 | #include <stdio.h> | ||
5 | #include <stdlib.h> | ||
6 | #include <string.h> | ||
7 | #include <sys/mman.h> | ||
8 | #include <sys/stat.h> | ||
9 | #include <sys/types.h> | ||
10 | #include <unistd.h> | ||
11 | |||
12 | typedef unsigned long long u64; | ||
13 | |||
14 | static size_t length = 1 << 24; | ||
15 | |||
16 | static u64 read_rss(void) | ||
17 | { | ||
18 | char buf[4096], *s = buf; | ||
19 | int i, fd; | ||
20 | u64 rss; | ||
21 | |||
22 | fd = open("/proc/self/statm", O_RDONLY); | ||
23 | assert(fd > 2); | ||
24 | memset(buf, 0, sizeof(buf)); | ||
25 | read(fd, buf, sizeof(buf) - 1); | ||
26 | for (i = 0; i < 1; i++) | ||
27 | s = strchr(s, ' ') + 1; | ||
28 | rss = strtoull(s, NULL, 10); | ||
29 | return rss << 12; /* assumes 4k pagesize */ | ||
30 | } | ||
31 | |||
32 | static void do_mmap(int fd, int extra_flags, int unmap) | ||
33 | { | ||
34 | int *p; | ||
35 | int flags = MAP_PRIVATE | MAP_POPULATE | extra_flags; | ||
36 | u64 before, after; | ||
37 | |||
38 | before = read_rss(); | ||
39 | p = mmap(NULL, length, PROT_READ | PROT_WRITE, flags, fd, 0); | ||
40 | assert(p != MAP_FAILED || | ||
41 | !"mmap returned an unexpected error"); | ||
42 | after = read_rss(); | ||
43 | assert(llabs(after - before - length) < 0x40000 || | ||
44 | !"rss didn't grow as expected"); | ||
45 | if (!unmap) | ||
46 | return; | ||
47 | munmap(p, length); | ||
48 | after = read_rss(); | ||
49 | assert(llabs(after - before) < 0x40000 || | ||
50 | !"rss didn't shrink as expected"); | ||
51 | } | ||
52 | |||
53 | static int open_file(const char *path) | ||
54 | { | ||
55 | int fd, err; | ||
56 | |||
57 | unlink(path); | ||
58 | fd = open(path, O_CREAT | O_RDWR | O_TRUNC | O_EXCL | ||
59 | | O_LARGEFILE | O_CLOEXEC, 0600); | ||
60 | assert(fd > 2); | ||
61 | unlink(path); | ||
62 | err = ftruncate(fd, length); | ||
63 | assert(!err); | ||
64 | return fd; | ||
65 | } | ||
66 | |||
67 | int main(void) | ||
68 | { | ||
69 | int hugefd, fd; | ||
70 | |||
71 | fd = open_file("/dev/shm/hugetlbhog"); | ||
72 | hugefd = open_file("/hugepages/hugetlbhog"); | ||
73 | |||
74 | system("echo 100 > /proc/sys/vm/nr_hugepages"); | ||
75 | do_mmap(-1, MAP_ANONYMOUS, 1); | ||
76 | do_mmap(fd, 0, 1); | ||
77 | do_mmap(-1, MAP_ANONYMOUS | MAP_HUGETLB, 1); | ||
78 | do_mmap(hugefd, 0, 1); | ||
79 | do_mmap(hugefd, MAP_HUGETLB, 1); | ||
80 | /* Leak the last one to test do_exit() */ | ||
81 | do_mmap(-1, MAP_ANONYMOUS | MAP_HUGETLB, 0); | ||
82 | printf("oll korrekt.\n"); | ||
83 | return 0; | ||
84 | } | ||
diff --git a/tools/testing/selftests/vm/run_vmtests b/tools/testing/selftests/vm/run_vmtests index 4c53cae6c273..c87b6812300d 100644 --- a/tools/testing/selftests/vm/run_vmtests +++ b/tools/testing/selftests/vm/run_vmtests | |||
@@ -4,6 +4,7 @@ | |||
4 | #we need 256M, below is the size in kB | 4 | #we need 256M, below is the size in kB |
5 | needmem=262144 | 5 | needmem=262144 |
6 | mnt=./huge | 6 | mnt=./huge |
7 | exitcode=0 | ||
7 | 8 | ||
8 | #get pagesize and freepages from /proc/meminfo | 9 | #get pagesize and freepages from /proc/meminfo |
9 | while read name size unit; do | 10 | while read name size unit; do |
@@ -41,6 +42,7 @@ echo "--------------------" | |||
41 | ./hugepage-mmap | 42 | ./hugepage-mmap |
42 | if [ $? -ne 0 ]; then | 43 | if [ $? -ne 0 ]; then |
43 | echo "[FAIL]" | 44 | echo "[FAIL]" |
45 | exitcode=1 | ||
44 | else | 46 | else |
45 | echo "[PASS]" | 47 | echo "[PASS]" |
46 | fi | 48 | fi |
@@ -55,6 +57,7 @@ echo "--------------------" | |||
55 | ./hugepage-shm | 57 | ./hugepage-shm |
56 | if [ $? -ne 0 ]; then | 58 | if [ $? -ne 0 ]; then |
57 | echo "[FAIL]" | 59 | echo "[FAIL]" |
60 | exitcode=1 | ||
58 | else | 61 | else |
59 | echo "[PASS]" | 62 | echo "[PASS]" |
60 | fi | 63 | fi |
@@ -67,6 +70,18 @@ echo "--------------------" | |||
67 | ./map_hugetlb | 70 | ./map_hugetlb |
68 | if [ $? -ne 0 ]; then | 71 | if [ $? -ne 0 ]; then |
69 | echo "[FAIL]" | 72 | echo "[FAIL]" |
73 | exitcode=1 | ||
74 | else | ||
75 | echo "[PASS]" | ||
76 | fi | ||
77 | |||
78 | echo "--------------------" | ||
79 | echo "running hugetlbfstest" | ||
80 | echo "--------------------" | ||
81 | ./hugetlbfstest | ||
82 | if [ $? -ne 0 ]; then | ||
83 | echo "[FAIL]" | ||
84 | exitcode=1 | ||
70 | else | 85 | else |
71 | echo "[PASS]" | 86 | echo "[PASS]" |
72 | fi | 87 | fi |
@@ -75,3 +90,4 @@ fi | |||
75 | umount $mnt | 90 | umount $mnt |
76 | rm -rf $mnt | 91 | rm -rf $mnt |
77 | echo $nr_hugepgs > /proc/sys/vm/nr_hugepages | 92 | echo $nr_hugepgs > /proc/sys/vm/nr_hugepages |
93 | exit $exitcode | ||