fix: handle EINTR correctly in get_cpu_mask_from_sysfs
[urcu.git] / tests / unit / test_build.c
index deb0a736b1e95cdb62365efba9dab046810bd9b4..99ddbcdd2ac4b9dfa3f84a563e5fa3eb90c0cdea 100644 (file)
@@ -1,20 +1,6 @@
-/*
- * Copyright 2021 Simon Marchi <simon.marchi@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: 2021 Simon Marchi <simon.marchi@efficios.com>
+//
+// SPDX-License-Identifier: GPL-2.0-or-later
 
 /*
  * This file is meant to verify that headers are compatible with both C and
 #include <urcu/urcu-mb.h>
 #include <urcu/urcu-memb.h>
 #include <urcu/urcu-qsbr.h>
-#include <urcu/urcu-signal.h>
 #include <urcu/wfcqueue.h>
 #include <urcu/wfqueue.h>
 #include <urcu/wfstack.h>
 
 #include "tap.h"
 
+struct my_tls_struct {
+       int int1;
+       char char1;
+       void *void1;
+};
+
+static DEFINE_URCU_TLS(int, my_tls_int);
+static DEFINE_URCU_TLS(struct my_tls_struct, my_tls_struct);
+
+static void test_lfstack(void)
+{
+       struct cds_lfs_stack s;
+
+       cds_lfs_init(&s);
+       ok(cds_lfs_empty(&s), "cds_lfs_empty");
+}
+
+static void test_wfstack(void)
+{
+       struct cds_wfs_stack s;
+
+       cds_wfs_init(&s);
+       ok(cds_wfs_empty(&s), "cds_lfs_empty");
+}
+
+static void test_wfcqueue(void)
+{
+       struct cds_wfcq_head head;
+       struct cds_wfcq_tail tail;
+
+       cds_wfcq_init(&head, &tail);
+       ok(cds_wfcq_empty(&head, &tail), "cds_wfcq_empty");
+}
+
+static
+void test_build_cds_list_head_init(void)
+{
+       /* Test that the CDS_LIST_HEAD_INIT macro builds correctly.  */
+       struct struct_with_list {
+               struct cds_list_head head;
+       };
+
+       struct struct_with_list list = {
+               .head = CDS_LIST_HEAD_INIT(list.head),
+       };
+}
+
+static
+void test_urcu_tls(void)
+{
+       URCU_TLS(my_tls_int) = 1;
+       URCU_TLS(my_tls_struct).int1 = 1;
+       URCU_TLS(my_tls_struct).char1 = 'a';
+       URCU_TLS(my_tls_struct).void1 = NULL;
+}
+
+struct an_opaque_struct;
+struct a_clear_struct
+{
+       int x;
+};
+
+static
+void test_build_rcu_dereference(void)
+{
+       static struct an_opaque_struct *opaque = NULL;
+       static struct an_opaque_struct *const opaque_const = NULL;
+       static struct a_clear_struct *clear = NULL;
+       static struct a_clear_struct *const clear_const = NULL;
+
+       (void) rcu_dereference(opaque);
+       (void) rcu_dereference(opaque_const);
+       (void) rcu_dereference(clear);
+       (void) rcu_dereference(clear_const);
+}
+
 int main(void)
 {
-       /* Need at least 1 test to make a valid TAP test plan. */
-       plan_tests(1);
-       ok(1, "dummy");
+       plan_tests(3);
+
+       test_lfstack();
+       test_wfstack();
+       test_wfcqueue();
+       test_build_cds_list_head_init();
+       test_urcu_tls();
+       test_build_rcu_dereference();
 
        return exit_status();
 }
This page took 0.023998 seconds and 4 git commands to generate.