The patch titled Subject: tools-selftests-add-mq_perf_tests-checkpatch-fixes has been added to the -mm tree. Its filename is tools-selftests-add-mq_perf_tests-checkpatch-fixes.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** The -mm tree is included into linux-next and is updated there every 3-4 working days ------------------------------------------------------ From: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> Subject: tools-selftests-add-mq_perf_tests-checkpatch-fixes Cc: Doug Ledford <dledford@xxxxxxxxxx> ERROR: space required after that ',' (ctx:VxV) #117: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:73: +#define min(a,b) ((a) < (b) ? (a) : (b)) ^ ERROR: that open brace { should be on the previous line #145: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:101: +const struct poptOption options[] = +{ WARNING: externs should be avoided in .c files #196: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:152: +void shutdown(int exit_val, char *err_cause, int line_no); WARNING: externs should be avoided in .c files #197: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:153: +void sig_action_SIGUSR1(int signum, siginfo_t *info, void *context); WARNING: externs should be avoided in .c files #198: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:154: +void sig_action(int signum, siginfo_t *info, void *context); WARNING: externs should be avoided in .c files #205: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:161: +void increase_limits(void); ERROR: do not initialise statics to 0 or NULL #217: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:173: + static int in_shutdown = 0; ERROR: spaces required around that '=' (ctx:VxV) #225: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:181: + for (i=0; i < num_cpus_to_pin; i++) ^ WARNING: quoted string split across lines #258: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:214: + fprintf(stderr, "Caught signal %d in SIGUSR1 handler, " + "exiting\n", signum); ERROR: do not use assignment in if condition #336: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:292: + if ((queue = mq_open(queue_path, flags, perms, attr)) == -1) ERROR: spaces required around that '=' (ctx:VxV) #352: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:308: + for (i=0; i < num_cpus_to_pin; i++) ^ ERROR: space required before the open parenthesis '(' #357: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:313: + while(1) ; ERROR: trailing statements should be on next line #357: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:313: + while(1) ; ERROR: spaces required around that '=' (ctx:VxV) #365: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:321: + for (i=0; i < num_cpus_to_pin; i++) ^ ERROR: space required before the open parenthesis '(' #370: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:326: + while(1) { ERROR: space required before the open parenthesis '(' #371: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:327: + while(mq_send(queue, buff, sizeof(buff), 0) == 0); ERROR: trailing statements should be on next line #371: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:327: + while(mq_send(queue, buff, sizeof(buff), 0) == 0); ERROR: Macros with complex values should be enclosed in parenthesis #376: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:332: +#define drain_queue() \ + while (mq_receive(queue, buff, MSG_SIZE, &prio_in) == MSG_SIZE) ERROR: space required before the open parenthesis '(' #383: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:339: + } while(0) WARNING: Statements terminations use 1 semicolon #423: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:379: + *prio = 0;; ERROR: do not use assignment in if condition #475: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:431: + if ((mq_prio_max = sysconf(_SC_MQ_PRIO_MAX)) == -1) WARNING: quoted string split across lines #490: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:446: + printf("\n\tTest #1: Time send/recv message, queue " + "empty\n"); ERROR: trailing statements should be on next line #566: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:522: + while (try_set(max_msgs, cur_max_msgs += 10)); ERROR: trailing statements should be on next line #568: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:524: + while (try_set(max_msgsize, cur_max_msgsize += 1024)); ERROR: do not use assignment in if condition #593: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:549: + if ((cpu_set = CPU_ALLOC(cpus_online)) == NULL) { WARNING: quoted string split across lines #615: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:571: + fprintf(stderr, "CPU %d exceeds " + "cpus online, ignoring.\n", WARNING: quoted string split across lines #628: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:584: + fprintf(stderr, "Any given CPU may " + "only be given once.\n"); WARNING: quoted string split across lines #660: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:616: + fprintf(stderr, "Must pass at least one CPU to continuous " + "mode.\n"); WARNING: quoted string split across lines #670: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:626: + fprintf(stderr, "Not running as root, but almost all tests " + "require root in order to modify\nsystem settings. " ERROR: spaces required around that '=' (ctx:VxV) #721: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:677: + for(cpu=1; cpu < num_cpus_to_pin; cpu++) ^ ERROR: space required before the open parenthesis '(' #721: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:677: + for(cpu=1; cpu < num_cpus_to_pin; cpu++) ERROR: spaces required around that '=' (ctx:VxV) #750: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:706: + for (i=0; i < num_cpus_to_pin; i++) { ^ ERROR: space required before the open parenthesis '(' #776: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:732: + while(1) sleep(1); ERROR: trailing statements should be on next line #776: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:732: + while(1) sleep(1); ERROR: space required after that ',' (ctx:VxV) #777: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:733: + shutdown(0,"",0); ^ ERROR: space required after that ',' (ctx:VxV) #777: FILE: tools/testing/selftests/mqueue/mq_perf_tests.c:733: + shutdown(0,"",0); ^ total: 25 errors, 11 warnings, 747 lines checked ./patches/tools-selftests-add-mq_perf_tests.patch has style problems, please review. If any of these errors are false positives, please report them to the maintainer, see CHECKPATCH in MAINTAINERS. Please run checkpatch prior to sending patches Cc: Doug Ledford <dledford@xxxxxxxxxx> Cc: Frederic Weisbecker <fweisbec@xxxxxxxxx> Cc: Manfred Spraul <manfred@xxxxxxxxxxxxxxxx> Cc: Stephen Rothwell <sfr@xxxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- tools/testing/selftests/mqueue/mq_perf_tests.c | 55 ++++++++------- 1 file changed, 31 insertions(+), 24 deletions(-) diff -puN tools/testing/selftests/mqueue/.gitignore~tools-selftests-add-mq_perf_tests-checkpatch-fixes tools/testing/selftests/mqueue/.gitignore diff -puN tools/testing/selftests/mqueue/Makefile~tools-selftests-add-mq_perf_tests-checkpatch-fixes tools/testing/selftests/mqueue/Makefile diff -puN tools/testing/selftests/mqueue/mq_perf_tests.c~tools-selftests-add-mq_perf_tests-checkpatch-fixes tools/testing/selftests/mqueue/mq_perf_tests.c --- a/tools/testing/selftests/mqueue/mq_perf_tests.c~tools-selftests-add-mq_perf_tests-checkpatch-fixes +++ a/tools/testing/selftests/mqueue/mq_perf_tests.c @@ -70,7 +70,7 @@ static char *usage = char *MAX_MSGS = "/proc/sys/fs/mqueue/msg_max"; char *MAX_MSGSIZE = "/proc/sys/fs/mqueue/msgsize_max"; -#define min(a,b) ((a) < (b) ? (a) : (b)) +#define min(a, b) ((a) < (b) ? (a) : (b)) #define MAX_CPUS 64 char *cpu_option_string; int cpus_to_pin[MAX_CPUS]; @@ -97,8 +97,7 @@ mqd_t queue = -1; struct mq_attr result; int mq_prio_max; -const struct poptOption options[] = -{ +const struct poptOption options[] = { { .longName = "continuous", .shortName = 'c', @@ -178,7 +177,7 @@ void shutdown(int exit_val, char *err_ca if (in_shutdown++) return; - for (i=0; i < num_cpus_to_pin; i++) + for (i = 0; i < num_cpus_to_pin; i++) if (cpu_threads[i]) { pthread_kill(cpu_threads[i], SIGUSR1); pthread_join(cpu_threads[i], NULL); @@ -211,7 +210,7 @@ void sig_action_SIGUSR1(int signum, sigi pthread_exit(0); else { fprintf(stderr, "Caught signal %d in SIGUSR1 handler, " - "exiting\n", signum); + "exiting\n", signum); shutdown(0, "", 0); fprintf(stderr, "\n\nReturned from shutdown?!?!\n\n"); exit(0); @@ -289,7 +288,8 @@ static inline void open_queue(struct mq_ int flags = O_RDWR | O_EXCL | O_CREAT | O_NONBLOCK; int perms = DEFFILEMODE; - if ((queue = mq_open(queue_path, flags, perms, attr)) == -1) + queue = mq_open(queue_path, flags, perms, attr); + if (queue == -1) shutdown(1, "mq_open()", __LINE__); if (mq_getattr(queue, &result)) shutdown(1, "mq_getattr()", __LINE__); @@ -305,12 +305,13 @@ void *fake_cont_thread(void *arg) { int i; - for (i=0; i < num_cpus_to_pin; i++) + for (i = 0; i < num_cpus_to_pin; i++) if (cpu_threads[i] == pthread_self()) break; printf("\tStarted fake continuous mode thread %d on CPU %d\n", i, cpus_to_pin[i]); - while(1) ; + while (1) + ; } void *cont_thread(void *arg) @@ -318,13 +319,14 @@ void *cont_thread(void *arg) char buff[MSG_SIZE]; int i, priority; - for (i=0; i < num_cpus_to_pin; i++) + for (i = 0; i < num_cpus_to_pin; i++) if (cpu_threads[i] == pthread_self()) break; printf("\tStarted continuous mode thread %d on CPU %d\n", i, cpus_to_pin[i]); - while(1) { - while(mq_send(queue, buff, sizeof(buff), 0) == 0); + while (1) { + while(mq_send(queue, buff, sizeof(buff), 0) == 0) + ; mq_receive(queue, buff, sizeof(buff), &priority); } } @@ -336,7 +338,7 @@ void *cont_thread(void *arg) do { \ if (mq_send(queue, buff, MSG_SIZE, prio_out)) \ shutdown(3, "Test send failure", __LINE__); \ - } while(0) + } while (0) #define do_send_recv() \ do { \ @@ -376,7 +378,7 @@ void const_prio(int *prio) void inc_prio(int *prio) { if (++*prio == mq_prio_max) - *prio = 0;; + *prio = 0; } void dec_prio(int *prio) @@ -428,7 +430,8 @@ void *perf_test_thread(void *arg) t = &cpu_threads[0]; printf("\n\tStarted mqueue performance test thread on CPU %d\n", cpus_to_pin[0]); - if ((mq_prio_max = sysconf(_SC_MQ_PRIO_MAX)) == -1) + mq_prio_max = sysconf(_SC_MQ_PRIO_MAX); + if (mq_prio_max == -1) shutdown(2, "sysconf(_SC_MQ_PRIO_MAX)", __LINE__); if (pthread_getcpuclockid(cpu_threads[0], &clock) != 0) shutdown(2, "pthread_getcpuclockid", __LINE__); @@ -442,8 +445,7 @@ void *perf_test_thread(void *arg) - printf("\n\tTest #1: Time send/recv message, queue " - "empty\n"); + printf("\n\tTest #1: Time send/recv message, queue empty\n"); printf("\t\t(%d iterations)\n", TEST1_LOOPS); prio_out = 0; send_total.tv_sec = 0; @@ -519,9 +521,11 @@ void increase_limits(void) cur_limits.rlim_cur = RLIM_INFINITY; cur_limits.rlim_max = RLIM_INFINITY; setr(RLIMIT_MSGQUEUE, &cur_limits); - while (try_set(max_msgs, cur_max_msgs += 10)); + while (try_set(max_msgs, cur_max_msgs += 10)) + ; cur_max_msgs = get(max_msgs); - while (try_set(max_msgsize, cur_max_msgsize += 1024)); + while (try_set(max_msgsize, cur_max_msgsize += 1024)) + ; cur_max_msgsize = get(max_msgsize); if (setpriority(PRIO_PROCESS, 0, -20) != 0) shutdown(2, "setpriority()", __LINE__); @@ -546,7 +550,8 @@ int main(int argc, char *argv[]) exit(1); } cpus_online = min(MAX_CPUS, sysconf(_SC_NPROCESSORS_ONLN)); - if ((cpu_set = CPU_ALLOC(cpus_online)) == NULL) { + cpu_set = CPU_ALLOC(cpus_online); + if (cpu_set == NULL) { perror("CPU_ALLOC()"); exit(1); } @@ -674,7 +679,7 @@ int main(int argc, char *argv[]) (continuous_mode_fake ? "fake mode" : "enabled") : "disabled"); printf("\tCPUs to pin:\t\t\t\t%d", cpus_to_pin[0]); - for(cpu=1; cpu < num_cpus_to_pin; cpu++) + for (cpu = 1; cpu < num_cpus_to_pin; cpu++) printf(",%d", cpus_to_pin[cpu]); printf("\n"); @@ -703,7 +708,7 @@ int main(int argc, char *argv[]) attr.mq_msgsize = MSG_SIZE; open_queue(&attr); } - for (i=0; i < num_cpus_to_pin; i++) { + for (i = 0; i < num_cpus_to_pin; i++) { pthread_attr_t thread_attr; void *thread_func; @@ -728,7 +733,9 @@ int main(int argc, char *argv[]) if (!continuous_mode) { pthread_join(cpu_threads[0], &retval); shutdown((long)retval, "perf_test_thread()", __LINE__); - } else - while(1) sleep(1); - shutdown(0,"",0); + } else { + while (1) + sleep(1); + } + shutdown(0, "", 0); } _ Subject: Subject: tools-selftests-add-mq_perf_tests-checkpatch-fixes Patches currently in -mm which might be from akpm@xxxxxxxxxxxxxxxxxxxx are linux-next.patch i-need-old-gcc.patch arch-alpha-kernel-systblss-remove-debug-check.patch drivers-block-nvmec-stop-breaking-my-i386-build.patch drivers-staging-zsmalloc-zsmalloc-mainc-unbork.patch arch-x86-platform-iris-irisc-register-a-platform-device-and-a-platform-driver.patch arch-x86-kernel-apic-io_apicc-move-io_apic_level_ack_pending-inside-config_generic_pending_irq.patch drivers-xen-kconfig-fix-kconfig-layout.patch x86-use-this_cpu_xxx-to-replace-percpu_xxx-funcs.patch x86-use-this_cpu_xxx-to-replace-percpu_xxx-funcs-fix.patch percpu-remove-percpu_xxx-functions-fix.patch fs-symlink-restrictions-on-sticky-directories.patch fs-hardlink-creation-restrictions.patch brlocks-lglocks-cleanups.patch mm.patch hugetlb-use-mmu_gather-instead-of-a-temporary-linked-list-for-accumulating-pages-fix.patch hugetlb-use-mmu_gather-instead-of-a-temporary-linked-list-for-accumulating-pages-fix-fix.patch memcg-add-hugetlb-extension-fix-fix.patch hugetlbfs-add-memcg-control-files-for-hugetlbfs-use-scnprintf-instead-of-sprintf-fix.patch memcg-move-hugetlb-resource-count-to-parent-cgroup-on-memcg-removal-fix.patch memcg-move-hugetlb-resource-count-to-parent-cgroup-on-memcg-removal-fix-fix.patch hugetlb-migrate-memcg-info-from-oldpage-to-new-page-during-migration-fix.patch mm-mmapc-find_vma-remove-unnecessary-ifmm-check-fix.patch mm-correctly-synchronize-rss-counters-at-exit-exec.patch mm-do_migrate_pages-calls-migrate_to_node-even-if-task-is-already-on-a-correct-node-fix.patch mm-do_migrate_pages-rename-arguments.patch mm-memcg-count-pte-references-from-every-member-of-the-reclaimed-hierarchy-fix.patch mm-rename-is_mlocked_vma-to-mlocked_vma_newpage-fix.patch mm-push-lru-index-into-shrink_active_list-fix.patch memcg-add-mlock-statistic-in-memorystat-fix.patch security-keys-keyctlc-suppress-memory-allocation-failure-warning.patch spinlockstxt-add-a-discussion-on-why-spin_is_locked-is-bad-fix.patch nmi-watchdog-fix-for-lockup-detector-breakage-on-resume-fix.patch nmi-watchdog-fix-for-lockup-detector-breakage-on-resume-fix-fix.patch kernel-irq-managec-use-the-pr_foo-infrastructure-to-prefix-printks.patch vsprintf-correctly-handle-width-when-flag-used-in-%p-format-checkpatch-fixes.patch vsprintf-further-optimize-decimal-conversion-checkpatch-fixes.patch leds-led-module-for-da9052-53-pmic-v2-fix.patch leds-add-led-driver-for-lm3556-chip-checkpatch-fixes.patch leds-heartbeat-stop-on-shutdown-checkpatch-fixes.patch lib-string_helpersc-make-arrays-static.patch lib-bitmapc-fix-documentation-for-scnprintf-functions.patch rtc-rename-config_rtc_mxc-to-config_rtc_drv_mxc-fix.patch kmod-avoid-deadlock-by-recursive-kmod-call.patch proc-clean-up-proc-pid-environ-handling-checkpatch-fixes.patch ipc-mqueue-improve-performance-of-send-recv-fix.patch ipc-mqueue-correct-mq_attr_ok-test-fix.patch tools-selftests-add-mq_perf_tests-checkpatch-fixes.patch eventfd-change-int-to-__u64-in-eventfd_signal-fix.patch syscalls-x86-add-__nr_kcmp-syscall-v8.patch syscalls-x86-add-__nr_kcmp-syscall-v8-comment-update-fix.patch c-r-prctl-simplify-pr_set_mm-on-mm-code-data-assignment-fix.patch c-r-prctl-add-ability-to-get-clear_tid_address.patch notify_change-check-that-i_mutex-is-held.patch journal_add_journal_head-debug.patch mutex-subsystem-synchro-test-module-fix.patch slab-leaks3-default-y.patch put_bh-debug.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html