| /* |
| * 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__ */ |