]> sourceware.org Git - newlib-cygwin.git/commitdiff
3013-11-19 Jennifer Averett <jennifer.averett@oarcorp.com>
authorJoel Sherrill <joel.sherrill@oarcorp.com>
Tue, 19 Nov 2013 19:11:24 +0000 (19:11 +0000)
committerJoel Sherrill <joel.sherrill@oarcorp.com>
Tue, 19 Nov 2013 19:11:24 +0000 (19:11 +0000)
        * libc/sys/rtems/sys/cpuset.h: New file.

newlib/ChangeLog
newlib/libc/sys/rtems/sys/cpuset.h [new file with mode: 0644]

index d170e9909c6d79c8b74668c4f05913c02976954e..0a8d836bce025303ddaf7c224d31b0659c0a498b 100644 (file)
@@ -1,3 +1,7 @@
+3013-11-19  Jennifer Averett <jennifer.averett@oarcorp.com>
+
+       * libc/sys/rtems/sys/cpuset.h: New file.
+
 2013-11-19  Joel Sherrill <joel.sherrill@oarcorp.com>
 
        * libc/include/stdlib.h: Add prototype of realpath().
diff --git a/newlib/libc/sys/rtems/sys/cpuset.h b/newlib/libc/sys/rtems/sys/cpuset.h
new file mode 100644 (file)
index 0000000..02fa112
--- /dev/null
@@ -0,0 +1,207 @@
+/*
+ * Copyright (c) 2013 On-Line Applications Research Corporation.
+ * All rights reserved.
+ *
+ *  On-Line Applications Research Corporation
+ *  7047 Old Madison Pike Suite 320
+ *  Huntsville Alabama 35806
+ *  <info@oarcorp.com>
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+/*
+ *  This file implements an API compatible with static portion of
+ *  the GNU/Linux cpu_set_t macros but is independently implemented.
+ *  The GNU/Linux manual page and the FreeBSD cpuset_t implementation
+ *  were used as reference material.
+ *
+ *  Not implemented:
+ *    + Linux CPU_XXX_S
+ *    + FreeBSD CPU_SUBSET
+ *    + FreeBSD CPU_OVERLAP
+ */
+
+
+#ifndef _SYS_CPUSET_H_
+#define _SYS_CPUSET_H_
+
+#if 0
+#include <sys/types.h>
+#endif
+#include <stdint.h>
+
+/* RTEMS supports a maximum of 32 CPU cores */
+#ifndef CPU_SETSIZE
+#define CPU_SETSIZE 32
+#endif
+
+/* word in the cpu set */
+typedef uint32_t cpu_set_word_t;
+
+/* Number of bits per cpu_set_t element */
+#define _NCPUBITS  (sizeof(cpu_set_word_t) * NBBY) /* bits per mask */
+
+/* Number of words in the cpu_set_t array */
+/* NOTE: Can't use howmany() because of circular dependency */
+#define _NCPUWORDS   (((CPU_SETSIZE)+((_NCPUBITS)-1))/(_NCPUBITS))
+
+/* Define the cpu set structure */
+typedef struct _cpuset {
+  cpu_set_word_t __bits[_NCPUWORDS];
+} cpu_set_t;
+
+/* determine the mask for a particular cpu within the element */
+static inline cpu_set_word_t  __cpuset_mask( size_t cpu )
+{
+  return ((cpu_set_word_t)1 << ((cpu) % _NCPUBITS));
+}
+
+/* determine the index for this cpu within the cpu set array */
+static inline size_t __cpuset_index( size_t cpu )
+{
+  return ((cpu)/_NCPUBITS);
+}
+
+/* zero out set */
+static inline void CPU_ZERO( cpu_set_t *set )
+{
+  size_t i;
+  for (i = 0; i < _NCPUWORDS; i++)
+    set->__bits[i] = 0;
+}
+
+/* fill set */
+static inline void CPU_FILL( cpu_set_t *set )
+{
+  size_t i;
+  for (i = 0; i < _NCPUWORDS; i++)
+    set->__bits[i] = -1;
+}
+
+/* set cpu within set */
+static inline void CPU_SET( size_t cpu, cpu_set_t *set )
+{
+  set->__bits[__cpuset_index(cpu)] |= __cpuset_mask(cpu);
+}
+
+/* clear cpu within set */
+static inline void CPU_CLR( size_t cpu, cpu_set_t *set )
+{
+  set->__bits[__cpuset_index(cpu)] &= ~__cpuset_mask(cpu);
+}
+
+/* Return 1 is cpu is set in set, 0 otherwise */
+static inline int const CPU_ISSET( size_t cpu, const cpu_set_t *set )
+{
+  return ((set->__bits[__cpuset_index(cpu)] & __cpuset_mask(cpu)) != 0);
+}
+
+/* copy src set to dest set */
+static inline void CPU_COPY( cpu_set_t *dest, const cpu_set_t *src )
+{
+  *dest = *src;
+}
+
+/* logical and: dest set = src1 set and src2 set */
+static inline void CPU_AND(
+  cpu_set_t *dest, const cpu_set_t *src1, const cpu_set_t *src2
+)
+{
+  size_t i;
+  for (i = 0; i < _NCPUWORDS; i++)
+    dest->__bits[i] = src1->__bits[i] & src2->__bits[i];
+}
+
+/* logical or: dest set = src1 set or src2 set */
+static inline void CPU_OR(
+  cpu_set_t *dest, const cpu_set_t *src1, const cpu_set_t *src2
+)
+{
+  size_t i;
+  for (i = 0; i < _NCPUWORDS; i++)
+     dest->__bits[i] = src1->__bits[i] | src2->__bits[i];
+}
+
+/* logical xor: dest set = src1 set xor src2 set */
+static inline void CPU_XOR(
+  cpu_set_t *dest, const cpu_set_t *src1, const cpu_set_t *src2
+)
+{
+  size_t i;
+  for (i = 0; i < _NCPUWORDS; i++)
+   dest->__bits[i] = src1->__bits[i] ^ src2->__bits[i];
+}
+
+/* logical nand: dest set = src1 set nand src2 set */
+static inline void CPU_NAND(
+  cpu_set_t *dest, const cpu_set_t *src1, const cpu_set_t *src2
+)
+{
+  size_t i; 
+  for (i = 0; i < _NCPUWORDS; i++)
+    dest->__bits[i] = ~(src1->__bits[i] & src2->__bits[i]);
+}
+
+/* return the number of set cpus in set */
+static inline int const CPU_COUNT( const cpu_set_t *set )
+{
+  size_t i;
+  int    count = 0;
+
+  for (i=0; i < _NCPUWORDS; i++)
+    if (CPU_ISSET(i, set) != 0)
+      count++;
+  return count;
+}
+
+/* return 1 if the sets set1 and set2 are equal, otherwise return 0 */
+static inline int const CPU_EQUAL( 
+  const cpu_set_t *set1, const cpu_set_t *set2 
+)
+{
+  size_t i;
+
+  for (i=0; i < _NCPUWORDS; i++)
+    if (set1->__bits[i] != set2->__bits[i] )
+      return 0;
+  return 1;
+}
+
+/* return 1 if the sets set1 and set2 are equal, otherwise return 0 */
+static inline int const CPU_CMP( const cpu_set_t *set1, const cpu_set_t *set2 )
+{
+  return CPU_EQUAL(set1, set2);
+}
+
+/* return 1 if the set is empty, otherwise return 0 */
+static inline int const CPU_EMPTY( const cpu_set_t *set )
+{
+  size_t i;
+
+  for (i=0; i < _NCPUWORDS; i++)
+    if (set->__bits[i] != 0 )
+      return 0;
+  return 1;
+}
+
+#endif
This page took 0.047475 seconds and 5 git commands to generate.