Arcane  v4.1.3.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
arcane/src/arcane/utils/PlatformUtils.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2026 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/* PlatformUtils.h (C) 2000-2026 */
9/* */
10/* Fonctions utilitaires dépendant de la plateforme. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_UTILS_PLATFORMUTILS_H
13#define ARCANE_UTILS_PLATFORMUTILS_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arccore/base/PlatformUtils.h"
19
20#include <iosfwd>
21
22/*---------------------------------------------------------------------------*/
23/*---------------------------------------------------------------------------*/
24
25namespace Arcane
26{
27
28/*---------------------------------------------------------------------------*/
29/*---------------------------------------------------------------------------*/
30
34class IDynamicLibraryLoader;
36
37/*---------------------------------------------------------------------------*/
38/*---------------------------------------------------------------------------*/
39/*!
40 \brief Espace de nom pour les fonctions dépendant de la plateforme.
41
42 Cet espace de nom contient toutes les fonctions dépendant de la plateforme.
43*/
44namespace platform
45{
46
47/*!
48 * \brief Initialisations spécifiques à une platforme.
49 *
50 Cette routine est appelé lors de l'initialisation de l'architecture.
51 Elle permet d'effectuer certains traitements qui dépendent de la
52 plateforme
53 */
54extern "C++" ARCANE_UTILS_EXPORT void platformInitialize();
55
56/*!
57 * \brief Routines de fin de programme spécifiques à une platforme.
58 *
59 Cette routine est appelé juste avant de quitter le programme.
60 */
61extern "C++" ARCANE_UTILS_EXPORT void platformTerminate();
62
63/*---------------------------------------------------------------------------*/
64/*---------------------------------------------------------------------------*/
65
66/*!
67 * \brief Service utilisé pour la gestion de l'affinité des processeurs.
68 *
69 * Peut retourner nul si aucun service n'est disponible.
70 */
71extern "C++" ARCANE_UTILS_EXPORT IProcessorAffinityService*
73
74/*!
75 * \brief Positionne le service utilisé pour la gestion de l'affinité des processeurs.
76 *
77 * Retourne l'ancien service utilisé.
78 */
79extern "C++" ARCCORE_DEPRECATED_REASON("Y2025: This method is internal to Arcane")
80ARCANE_UTILS_EXPORT IProcessorAffinityService*
81setProcessorAffinityService(IProcessorAffinityService* service);
82
83/*!
84 * \brief Service utilisé pour obtenir pour obtenir des informations de profiling.
85 *
86 * Peut retourner nul si aucun service n'est disponible.
87 */
88extern "C++" ARCANE_UTILS_EXPORT IProfilingService*
90
91/*!
92 * \brief Positionne le service utilisé pour obtenir des informations de profiling.
93 *
94 * Retourne l'ancien service utilisé.
95 */
96extern "C++" ARCCORE_DEPRECATED_REASON("Y2025: This method is internal to Arcane")
97ARCANE_UTILS_EXPORT IProfilingService*
98setProfilingService(IProfilingService* service);
99
100/*!
101 * \brief Service utilisé pour obtenir la mise en place d'une architecture en ligne de debug.
102 *
103 * Peut retourner nul si aucun service n'est disponible.
104 */
105extern "C++" ARCANE_UTILS_EXPORT IOnlineDebuggerService*
107
108/*!
109 * \brief Positionne le service a utiliser pour l'architecture en ligne de debug.
110 *
111 * Retourne l'ancien service utilisé.
112 */
113extern "C++" ARCCORE_DEPRECATED_REASON("Y2025: This method is internal to Arcane")
114ARCANE_UTILS_EXPORT IOnlineDebuggerService*
115setOnlineDebuggerService(IOnlineDebuggerService* service);
116
117/*!
118 * \brief Service utilisé pour gérer les threads.
119 *
120 * Peut retourner nul si aucun service n'est disponible.
121 */
122extern "C++" ARCANE_UTILS_EXPORT IThreadImplementation*
124
125/*!
126 * \brief Positionne le service utilisé pour gérer les threads.
127 *
128 * Retourne l'ancien service utilisé.
129 */
130extern "C++" ARCCORE_DEPRECATED_REASON("Y2025: This method is internal to Arcane")
131ARCANE_UTILS_EXPORT IThreadImplementation*
132setThreadImplementationService(IThreadImplementation* service);
133
134/*!
135 * \brief Positionne le service utilisé pour gérer les compteurs interne du processeur.
136 *
137 * Retourne l'ancien service utilisé.
138 */
139extern "C++" ARCCORE_DEPRECATED_REASON("Y2025: This method is internal to Arcane")
140ARCANE_UTILS_EXPORT IPerformanceCounterService*
141setPerformanceCounterService(IPerformanceCounterService* service);
142
143/*!
144 * \brief Service utilisé pour obtenir pour obtenir les compteurs interne du processeur.
145 *
146 * Peut retourner nul si aucun service n'est disponible.
147 */
148extern "C++" ARCANE_UTILS_EXPORT IPerformanceCounterService*
150
151/*---------------------------------------------------------------------------*/
152/*---------------------------------------------------------------------------*/
153/*!
154 * \brief Remet à timer d'alarme à \a nb_second.
155 *
156 * Le timer déclenchera un signal (SIGALRM) au bout de \a nb_second.
157 */
158extern "C++" ARCANE_UTILS_EXPORT void
159resetAlarmTimer(Integer nb_second);
160
161/*!
162 * \brief Vrai si le code s'exécute avec le runtime .NET.
163 */
164extern "C++" ARCANE_UTILS_EXPORT bool
166
167/*!
168 * \brief Positionne si le code s'exécute avec le runtime .NET.
169 *
170 * Cette fonction ne peut être positionnée qu'au démarrage
171 * du calcul avant arcaneInitialize().
172 */
173extern "C++" ARCANE_UTILS_EXPORT void
174setHasDotNETRuntime(bool v);
175
176/*---------------------------------------------------------------------------*/
177/*---------------------------------------------------------------------------*/
178
179//! Appelle le Garbage Collector de '.Net' s'il est disponible
180extern "C++" ARCANE_UTILS_EXPORT void
182
183/*---------------------------------------------------------------------------*/
184/*---------------------------------------------------------------------------*/
185/*!
186 * \brief Allocateur spécifique pour les accélérateurs.
187 *
188 * \deprecated Use MemoryUtils::getDefaultDataAllocator() instead.
189 */
190extern "C++" ARCANE_DEPRECATED_REASON("Y2024: Use MemoryUtils::getDefaultDataAllocator() instead.")
191ARCANE_UTILS_EXPORT IMemoryAllocator*
193
194/*---------------------------------------------------------------------------*/
195/*---------------------------------------------------------------------------*/
196/*!
197 * \brief Positionne l'allocateur spécifique pour les accélérateurs.
198 *
199 * Retourne l'ancien allocateur utilisé. L'allocateur spécifié doit rester
200 * valide durant toute la durée de vie de l'application.
201 *
202 * \deprecated Cette méthode est interne à Arcane.
203 */
204extern "C++" ARCANE_DEPRECATED_REASON("Y2024: This method is internal to Arcane")
205ARCANE_UTILS_EXPORT IMemoryAllocator*
206setAcceleratorHostMemoryAllocator(IMemoryAllocator* a);
207
208/*---------------------------------------------------------------------------*/
209/*---------------------------------------------------------------------------*/
210/*!
211 * \brief Allocateur par défaut pour les données.
212 *
213 * Cette allocateur utilise celui getAcceleratorHostMemoryAllocator()
214 * s'il est disponible, sinon il utilise un allocateur aligné.
215 *
216 * Il est garanti que l'allocateur retourné permettra d'utiliser la donnée
217 * sur accélerateur si cela est disponible.
218 *
219 * Il est garanti que l'alignement est au moins celui retourné par
220 * AlignedMemoryAllocator::Simd().
221 */
222extern "C++" ARCANE_UTILS_EXPORT IMemoryAllocator*
224
225/*---------------------------------------------------------------------------*/
226/*---------------------------------------------------------------------------*/
227/*!
228 * \brief Positionne le gestionnaire de ressource mémoire pour les données.
229 *
230 * Le gestionnaire doit rester valide durant toute l'exécution du programme.
231 *
232 * Retourne l'ancien gestionnaire.
233 *
234 * * \deprecated Cette méthode est interne à Arcane.
235 */
236extern "C++" ARCANE_DEPRECATED_REASON("Y2024: This method is internal to Arcane")
237ARCANE_UTILS_EXPORT IMemoryRessourceMng*
238setDataMemoryRessourceMng(IMemoryRessourceMng* mng);
239
240/*---------------------------------------------------------------------------*/
241/*---------------------------------------------------------------------------*/
242/*!
243 * \brief Gestionnaire de ressource mémoire pour les données.
244 *
245 * Il est garanti que l'alignement est au moins celui retourné par
246 * AlignedMemoryAllocator::Simd().
247 *
248 * \deprecated Cette méthode est interne à Arcane.
249 */
250extern "C++" ARCANE_DEPRECATED_REASON("Y2024: This method is internal to Arcane. Use methods from MemoryUtils instead.")
251ARCANE_UTILS_EXPORT IMemoryRessourceMng*
253
254/*---------------------------------------------------------------------------*/
255/*---------------------------------------------------------------------------*/
256/*!
257 * \brief Lit le contenu d'un fichier et le conserve dans \a out_bytes.
258 *
259 * Lit le fichier de nom \a filename et remplit \a out_bytes avec le contenu
260 * de ce fichier. Si \a is_binary est vrai, le fichier est ouvert en mode
261 * binaire. Sinon il est ouvert en mode texte.
262 *
263 * \retval true en cas d'erreur
264 * \retval false sinon.
265 */
266extern "C++" ARCANE_UTILS_EXPORT bool
267readAllFile(StringView filename, bool is_binary, ByteArray& out_bytes);
268
269/*---------------------------------------------------------------------------*/
270/*---------------------------------------------------------------------------*/
271/*!
272 * \brief Lit le contenu d'un fichier et le conserve dans \a out_bytes.
273 *
274 * Lit le fichier de nom \a filename et remplit \a out_bytes avec le contenu
275 * de ce fichier. Si \a is_binary est vrai, le fichier est ouvert en mode
276 * binaire. Sinon il est ouvert en mode texte.
277 *
278 * \retval true en cas d'erreur
279 * \retval false sinon.
280 */
281extern "C++" ARCANE_UTILS_EXPORT bool
282readAllFile(StringView filename, bool is_binary, Array<std::byte>& out_bytes);
283
284/*---------------------------------------------------------------------------*/
285/*---------------------------------------------------------------------------*/
286/*!
287 * \brief Retourne le nom complet avec le chemin de l'exécutable.
288 */
289extern "C++" ARCANE_UTILS_EXPORT String
291
292/*---------------------------------------------------------------------------*/
293/*---------------------------------------------------------------------------*/
294/*!
295 * \brief Remplit \a arg_list avec les arguments de la ligne de commande.
296 *
297 * Cette fonction remplit \a arg_list avec les arguments utilisés dans
298 * l'appel à main().
299 *
300 * Actuellement cette méthode ne fonctionne que sous Linux. Pour les autres
301 * plateforme elle retourne une liste vide.
302 */
303extern "C++" ARCANE_UTILS_EXPORT void
305
306/*---------------------------------------------------------------------------*/
307/*---------------------------------------------------------------------------*/
308/*!
309 * \brief Récupère la pile d'appel via gdb.
310 *
311 * Cette méthode ne fonctionne que sous Linux et si GDB est installé. Dans
312 * les autres cas c'est la chaîne nulle qui est retournée.
313 *
314 * Cette méthode appelle la commande std::system() pour lancer gbd qui doit
315 * se trouver dans le PATH. Comme gdb charge ensuite les symboles de debug
316 * la commande peut être assez longue à s'exécuter.
317 */
318extern "C++" ARCANE_UTILS_EXPORT String
320
321/*---------------------------------------------------------------------------*/
322/*---------------------------------------------------------------------------*/
323/*!
324 * \brief Récupère la pile d'appel via lldb.
325 *
326 * Cette méthode est similaire à getGDBStack() mais utilise 'lldb' pour
327 * récupérer la pile d'appel. Si `dotnet-sos` est installé, cela permet
328 * aussi de récupérer les informations sur les méthodes du runtime 'dotnet'.
329 */
330extern "C++" ARCANE_UTILS_EXPORT String
332
333/*---------------------------------------------------------------------------*/
334/*---------------------------------------------------------------------------*/
335
336// Définition du pragma pour indiquer l'indépendance des itérations
337
338/*!
339 * \def ARCANE_PRAGMA_IVDEP
340 * Pragma pour indiquer au compilateur que les itérations d'une boucle sont
341 * indépendanntes. Ce pragma se positionne avant une boucle 'for'.
342 */
343
344/*!
345 * \def ARCANE_PRAGMA_IVDEP_VALUE
346 * Valeur du pragma ARCANE_PRAGMA_IVDEP
347 */
348
349// Pour les définitions, il faut finir par GCC car Clang et ICC définissent
350// la macro __GNU__
351// Pour CLANG, il n'y a pas encore d'équivalent au pragma ivdep de ICC.
352// Celui qui s'en approche le plus est:
353// #pragma clang loop vectorize(enable)
354// mais il ne force pas la vectorisation.
355#ifdef __clang__
356# define ARCANE_PRAGMA_IVDEP_VALUE "clang loop vectorize(enable)"
357#else
358# ifdef __INTEL_COMPILER
359# define ARCANE_PRAGMA_IVDEP_VALUE "ivdep"
360# else
361# ifdef __GNUC__
362# if (__GNUC__>=5)
363# define ARCANE_PRAGMA_IVDEP_VALUE "GCC ivdep"
364# endif
365# endif
366# endif
367#endif
368
369#ifdef ARCANE_PRAGMA_IVDEP_VALUE
370#define ARCANE_PRAGMA_IVDEP _Pragma(ARCANE_PRAGMA_IVDEP_VALUE)
371#else
372#define ARCANE_PRAGMA_IVDEP
373#define ARCANE_PRAGMA_IVDEP_VALUE ""
374#endif
375
376/*---------------------------------------------------------------------------*/
377/*---------------------------------------------------------------------------*/
378
379} // End namespace platform
380
381/*---------------------------------------------------------------------------*/
382/*---------------------------------------------------------------------------*/
383
384} // End namespace Arcane
385
386/*---------------------------------------------------------------------------*/
387/*---------------------------------------------------------------------------*/
388
389#endif
Déclarations des types utilisés dans Arcane.
Interface d'un service de récupération des symboles du code source.
Espace de nom pour les fonctions dépendant de la plateforme.
IPerformanceCounterService * setPerformanceCounterService(IPerformanceCounterService *service)
Positionne le service utilisé pour gérer les compteurs interne du processeur.
void callDotNETGarbageCollector()
Appelle le Garbage Collector de '.Net' s'il est disponible.
String getLLDBStack()
Récupère la pile d'appel via lldb.
void fillCommandLineArguments(StringList &arg_list)
Remplit arg_list avec les arguments de la ligne de commande.
IMemoryRessourceMng * setDataMemoryRessourceMng(IMemoryRessourceMng *mng)
Positionne le gestionnaire de ressource mémoire pour les données.
void platformInitialize()
Initialisations spécifiques à une platforme.
IOnlineDebuggerService * setOnlineDebuggerService(IOnlineDebuggerService *service)
Positionne le service a utiliser pour l'architecture en ligne de debug.
IProfilingService * getProfilingService()
Service utilisé pour obtenir pour obtenir des informations de profiling.
IMemoryRessourceMng * getDataMemoryRessourceMng()
Gestionnaire de ressource mémoire pour les données.
void resetAlarmTimer(Integer nb_second)
Remet à timer d'alarme à nb_second.
void platformTerminate()
Routines de fin de programme spécifiques à une platforme.
IProfilingService * setProfilingService(IProfilingService *service)
Positionne le service utilisé pour obtenir des informations de profiling.
IMemoryAllocator * getAcceleratorHostMemoryAllocator()
Allocateur spécifique pour les accélérateurs.
IMemoryAllocator * getDefaultDataAllocator()
Allocateur par défaut pour les données.
String getExeFullPath()
Retourne le nom complet avec le chemin de l'exécutable.
bool readAllFile(StringView filename, bool is_binary, ByteArray &out_bytes)
Lit le contenu d'un fichier et le conserve dans out_bytes.
IProcessorAffinityService * setProcessorAffinityService(IProcessorAffinityService *service)
Positionne le service utilisé pour la gestion de l'affinité des processeurs.
void setHasDotNETRuntime(bool v)
Positionne si le code s'exécute avec le runtime .NET.
IProcessorAffinityService * getProcessorAffinityService()
Service utilisé pour la gestion de l'affinité des processeurs.
IMemoryAllocator * setAcceleratorHostMemoryAllocator(IMemoryAllocator *a)
Positionne l'allocateur spécifique pour les accélérateurs.
IThreadImplementation * getThreadImplementationService()
Service utilisé pour gérer les threads.
IPerformanceCounterService * getPerformanceCounterService()
Service utilisé pour obtenir pour obtenir les compteurs interne du processeur.
bool hasDotNETRuntime()
Vrai si le code s'exécute avec le runtime .NET.
String getGDBStack()
Récupère la pile d'appel via gdb.
IThreadImplementation * setThreadImplementationService(IThreadImplementation *service)
Positionne le service utilisé pour gérer les threads.
IOnlineDebuggerService * getOnlineDebuggerService()
Service utilisé pour obtenir la mise en place d'une architecture en ligne de debug.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Int32 Integer
Type représentant un entier.
Array< Byte > ByteArray
Tableau dynamique à une dimension de caractères.
Definition UtilsTypes.h:121
List< String > StringList
Tableau de chaînes de caractères unicode.
Definition UtilsTypes.h:509