Arcane  v4.1.3.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IProcessorAffinityService.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2025 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* IProcessorAffinityService.h (C) 2000-2025 */
9/* */
10/* Interface d'un service de gestion de l'affinité des coeurs CPU. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_UTILS_IPROCESSORAFFINITYSERVICE_H
13#define ARCANE_UTILS_IPROCESSORAFFINITYSERVICE_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
18
19/*---------------------------------------------------------------------------*/
20/*---------------------------------------------------------------------------*/
21
22namespace Arcane
23{
24
25/*---------------------------------------------------------------------------*/
26/*---------------------------------------------------------------------------*/
27/*!
28 * \internal
29 * \brief Interface d'un service de gestion de l'affinité des coeurs CPU.
30 */
32{
33 public:
34
35 virtual ~IProcessorAffinityService() {} //<! Libère les ressources
36
37 public:
38
39 virtual void build() = 0;
40
41 public:
42
43 //! Affiche les informations complète de topologie via info()
44 virtual void printInfos() = 0;
45
46 /*!
47 * \brief Retourne le cpuset pour le thread courant.
48 *
49 * La chaîne retournée est dans un format compatible avec celui
50 * de taskset. Par exemple, on peut avoir des valeurs telles
51 * que \a 'ff', '1, ou 'ffff1234,ff'.
52 */
53 virtual String cpuSetString() = 0;
54
55 //! Contraint le thread courant à rester sur le coeur d'indice \a cpu
56 virtual void bindThread(Int32 cpu) = 0;
57
58 //! Nombre de coeurs CPU (-1 si inconnu)
59 virtual Int32 numberOfCore() = 0;
60
61 //! Nombre de sockets (-1 si inconnu)
62 virtual Int32 numberOfSocket() = 0;
63
64 //! Nombre de coeurs logiques (-1 si inconnu)
66};
67
68/*---------------------------------------------------------------------------*/
69/*---------------------------------------------------------------------------*/
70
71} // namespace Arcane
72
73/*---------------------------------------------------------------------------*/
74/*---------------------------------------------------------------------------*/
75
76#endif
Fichier de configuration d'Arcane.
virtual void bindThread(Int32 cpu)=0
Contraint le thread courant à rester sur le coeur d'indice cpu.
virtual Int32 numberOfSocket()=0
Nombre de sockets (-1 si inconnu)
virtual Int32 numberOfProcessingUnit()=0
Nombre de coeurs logiques (-1 si inconnu)
virtual String cpuSetString()=0
Retourne le cpuset pour le thread courant.
virtual void printInfos()=0
Affiche les informations complète de topologie via info()
virtual Int32 numberOfCore()=0
Nombre de coeurs CPU (-1 si inconnu)
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
std::int32_t Int32
Type entier signé sur 32 bits.