fix: handle EINTR correctly in get_cpu_mask_from_sysfs
[urcu.git] / tests / unit / test_uatomic.c
index fe2a6c1b8751794190261539d9cb276958fcee48..d9c70e0ac912747d5a68fcf7ee90872b0e25a3e8 100644 (file)
@@ -1,24 +1,6 @@
-/*
- * test_uatomic.c
- *
- * Userspace RCU library - test atomic operations
- *
- * Copyright February 2009 - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- */
+// SPDX-FileCopyrightText: 2009 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
+//
+// SPDX-License-Identifier: GPL-2.0-or-later
 
 #include <stdio.h>
 #include <urcu/uatomic.h>
 
 #define NR_TESTS 17
 
+#define BYTE_PER_LONG  (sizeof(unsigned long) / sizeof(unsigned char))
+#define SHORT_PER_LONG (sizeof(unsigned long) / sizeof(unsigned short))
+#define INT_PER_LONG   (sizeof(unsigned long) / sizeof(unsigned int))
+
 struct testvals {
 #ifdef UATOMIC_HAS_ATOMIC_BYTE
-       unsigned char c;
+       unsigned char c[BYTE_PER_LONG];
 #endif
 #ifdef UATOMIC_HAS_ATOMIC_SHORT
-       unsigned short s;
+       unsigned short s[SHORT_PER_LONG];
 #endif
-       unsigned int i;
+       unsigned int i[INT_PER_LONG];
        unsigned long l;
 };
 
@@ -91,27 +77,38 @@ do {                                                \
                                                \
 } while (0)
 
-int main(int argc, char **argv)
+int main(void)
 {
-       int nr_run = 2;
+       int nr_run = INT_PER_LONG + 1;
+       unsigned long i;
+
 #ifdef UATOMIC_HAS_ATOMIC_BYTE
-       nr_run += 1;
+       nr_run += BYTE_PER_LONG;
 #endif
 #ifdef UATOMIC_HAS_ATOMIC_SHORT
-       nr_run += 1;
+       nr_run += SHORT_PER_LONG;
 #endif
 
        plan_tests(nr_run * NR_TESTS);
 #ifdef UATOMIC_HAS_ATOMIC_BYTE
-       diag("Test atomic ops on byte");
-       do_test(&vals.c);
+       for (i = 0; i < BYTE_PER_LONG; i++) {
+               diag("Test atomic ops on byte with %lu byte offset from long alignment",
+                       i);
+               do_test(&vals.c[i]);
+       }
 #endif
 #ifdef UATOMIC_HAS_ATOMIC_SHORT
-       diag("Test atomic ops on short");
-       do_test(&vals.s);
+       for (i = 0; i < SHORT_PER_LONG; i++) {
+               diag("Test atomic ops on short with %lu byte offset from long alignment",
+                       i * sizeof(unsigned short));
+               do_test(&vals.s[i]);
+       }
 #endif
-       diag("Test atomic ops on int");
-       do_test(&vals.i);
+       for (i = 0; i < INT_PER_LONG; i++) {
+               diag("Test atomic ops on int with %lu byte offset from long alignment",
+                       i * sizeof(unsigned int));
+               do_test(&vals.i[i]);
+       }
        diag("Test atomic ops on long");
        do_test(&vals.l);
 
This page took 0.028972 seconds and 4 git commands to generate.