Arcane  v3.16.7.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
ParallelMngInternal.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/* ParallelMngInternal.h (C) 2000-2025 */
9/* */
10/* Implémentation de la partie interne à Arcane de IParallelMng. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_CORE_INTERNAL_PARALLELMNGINTERNAL_H
13#define ARCANE_CORE_INTERNAL_PARALLELMNGINTERNAL_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
18#include "arcane/core/internal/IParallelMngInternal.h"
19
20#include "arcane/accelerator/core/Runner.h"
21
22/*---------------------------------------------------------------------------*/
23/*---------------------------------------------------------------------------*/
24
25namespace Arcane
26{
27
28/*---------------------------------------------------------------------------*/
29/*---------------------------------------------------------------------------*/
30
32
33/*---------------------------------------------------------------------------*/
34/*---------------------------------------------------------------------------*/
35
40class ARCANE_CORE_EXPORT ParallelMngInternal
42{
43 public:
44
45 explicit ParallelMngInternal(ParallelMngDispatcher* pm);
46
47 ~ParallelMngInternal() override = default;
48
49 public:
50
51 Runner runner() const override;
52 RunQueue queue() const override;
53 bool isAcceleratorAware() const override;
55 void setDefaultRunner(const Runner& runner) override;
57
58 private:
59
60 ParallelMngDispatcher* m_parallel_mng = nullptr;
61 Runner m_runner;
62 RunQueue m_queue;
63 bool m_is_accelerator_aware_disabled = false;
64};
65
66/*---------------------------------------------------------------------------*/
67/*---------------------------------------------------------------------------*/
68
69} // namespace Arcane
70
71/*---------------------------------------------------------------------------*/
72/*---------------------------------------------------------------------------*/
73
74#endif
Déclarations des types généraux de Arcane.
File d'exécution pour un accélérateur.
Gestionnaire d'exécution pour accélérateur.
Definition core/Runner.h:68
Partie interne de IParallelMng.
Redirige la gestion des messages des sous-domaines suivant le type de l'argument.
RunQueue queue() const override
File par défaut pour les messages. Peut être nul.
Ref< IParallelMng > createSubParallelMngRef(Int32 color, Int32 key) override
Créé un sous IParallelMng de manière similaire à MPI_Comm_split.
bool isAcceleratorAware() const override
Indique si l'implémentation gère les accélérateurs.
Runner runner() const override
Runner par défaut. Peut être nul.
Ref< MessagePassing::IMachineMemoryWindowBaseInternal > createMachineMemoryWindowBase(Int64 sizeof_segment, Int32 sizeof_type) override
Méthode permettant de créer une fenêtre mémoire sur le noeud.
Référence à une instance.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
std::int64_t Int64
Type entier signé sur 64 bits.
std::int32_t Int32
Type entier signé sur 32 bits.