|
@@ -0,0 +1,89 @@
|
|
|
+/*
|
|
|
+ * This file is subject to the terms and conditions of the GNU General Public
|
|
|
+ * License. See the file "COPYING" in the main directory of this archive
|
|
|
+ * for more details.
|
|
|
+ *
|
|
|
+ * Copyright (c) 2016 Cavium Inc. (support@cavium.com).
|
|
|
+ *
|
|
|
+ */
|
|
|
+
|
|
|
+/*
|
|
|
+ * Module to support operations on bitmap of cores. Coremask can be used to
|
|
|
+ * select a specific core, a group of cores, or all available cores, for
|
|
|
+ * initialization and differentiation of roles within a single shared binary
|
|
|
+ * executable image.
|
|
|
+ *
|
|
|
+ * The core numbers used in this file are the same value as what is found in
|
|
|
+ * the COP0_EBASE register and the rdhwr 0 instruction.
|
|
|
+ *
|
|
|
+ * For the CN78XX and other multi-node environments the core numbers are not
|
|
|
+ * contiguous. The core numbers for the CN78XX are as follows:
|
|
|
+ *
|
|
|
+ * Node 0: Cores 0 - 47
|
|
|
+ * Node 1: Cores 128 - 175
|
|
|
+ * Node 2: Cores 256 - 303
|
|
|
+ * Node 3: Cores 384 - 431
|
|
|
+ *
|
|
|
+ */
|
|
|
+
|
|
|
+#ifndef __CVMX_COREMASK_H__
|
|
|
+#define __CVMX_COREMASK_H__
|
|
|
+
|
|
|
+#define CVMX_MIPS_MAX_CORES 1024
|
|
|
+/* bits per holder */
|
|
|
+#define CVMX_COREMASK_ELTSZ 64
|
|
|
+
|
|
|
+/* cvmx_coremask_t's size in u64 */
|
|
|
+#define CVMX_COREMASK_BMPSZ (CVMX_MIPS_MAX_CORES / CVMX_COREMASK_ELTSZ)
|
|
|
+
|
|
|
+
|
|
|
+/* cvmx_coremask_t */
|
|
|
+struct cvmx_coremask {
|
|
|
+ u64 coremask_bitmap[CVMX_COREMASK_BMPSZ];
|
|
|
+};
|
|
|
+
|
|
|
+/*
|
|
|
+ * Is ``core'' set in the coremask?
|
|
|
+ */
|
|
|
+static inline bool cvmx_coremask_is_core_set(const struct cvmx_coremask *pcm,
|
|
|
+ int core)
|
|
|
+{
|
|
|
+ int n, i;
|
|
|
+
|
|
|
+ n = core % CVMX_COREMASK_ELTSZ;
|
|
|
+ i = core / CVMX_COREMASK_ELTSZ;
|
|
|
+
|
|
|
+ return (pcm->coremask_bitmap[i] & ((u64)1 << n)) != 0;
|
|
|
+}
|
|
|
+
|
|
|
+/*
|
|
|
+ * Make a copy of a coremask
|
|
|
+ */
|
|
|
+static inline void cvmx_coremask_copy(struct cvmx_coremask *dest,
|
|
|
+ const struct cvmx_coremask *src)
|
|
|
+{
|
|
|
+ memcpy(dest, src, sizeof(*dest));
|
|
|
+}
|
|
|
+
|
|
|
+/*
|
|
|
+ * Set the lower 64-bit of the coremask.
|
|
|
+ */
|
|
|
+static inline void cvmx_coremask_set64(struct cvmx_coremask *pcm,
|
|
|
+ uint64_t coremask_64)
|
|
|
+{
|
|
|
+ pcm->coremask_bitmap[0] = coremask_64;
|
|
|
+}
|
|
|
+
|
|
|
+/*
|
|
|
+ * Clear ``core'' from the coremask.
|
|
|
+ */
|
|
|
+static inline void cvmx_coremask_clear_core(struct cvmx_coremask *pcm, int core)
|
|
|
+{
|
|
|
+ int n, i;
|
|
|
+
|
|
|
+ n = core % CVMX_COREMASK_ELTSZ;
|
|
|
+ i = core / CVMX_COREMASK_ELTSZ;
|
|
|
+ pcm->coremask_bitmap[i] &= ~(1ull << n);
|
|
|
+}
|
|
|
+
|
|
|
+#endif /* __CVMX_COREMASK_H__ */
|