%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
/* * 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__ */