12#ifndef ARCCORE_MESSAGEPASSING_MESSAGEPASSINGGLOBAL_H
13#define ARCCORE_MESSAGEPASSING_MESSAGEPASSINGGLOBAL_H
22#if defined(ARCCORE_COMPONENT_arccore_message_passing)
23#define ARCCORE_MESSAGEPASSING_EXPORT ARCCORE_EXPORT
24#define ARCCORE_MESSAGEPASSING_EXTERN_TPL
26#define ARCCORE_MESSAGEPASSING_EXPORT ARCCORE_IMPORT
27#define ARCCORE_MESSAGEPASSING_EXTERN_TPL extern
40using Arcane::ISerializer;
41using Arcane::ITimeMetricCollector;
53static const Int32 A_NULL_RANK =
static_cast<Int32>(-1);
56static const Int32 A_NULL_TAG_VALUE =
static_cast<Int32>(-1);
59static const Int32 A_ANY_SOURCE_RANK =
static_cast<Int32>(-2);
62static const Int32 A_PROC_NULL_RANK =
static_cast<Int32>(-3);
65class SubRequestCompletionInfo;
144namespace Arcane::MessagePassing::internal
150namespace Arccore::MessagePassing::internal
152using Arcane::MessagePassing::internal::BasicSerializeMessage;
153using Arcane::MessagePassing::internal::SerializeMessageList;
166using Arcane::MessagePassing::IControlDispatcher;
167using Arcane::MessagePassing::IMessagePassingMng;
168using Arcane::MessagePassing::ISerializeMessage;
169using Arcane::MessagePassing::ISerializeMessageList;
170using Arcane::MessagePassing::ITypeDispatcher;
185using Arcane::MessagePassing::WaitAll;
189using Arcane::MessagePassing::Blocking;
191using Arcane::MessagePassing::NonBlocking;
194using Arcane::MessagePassing::MsgReceive;
195using Arcane::MessagePassing::MsgSend;
197using Arcane::MessagePassing::IRequestCreator;
198using Arcane::MessagePassing::IRequestList;
199using Arcane::MessagePassing::ISubRequest;
200using Arcane::MessagePassing::MessageId;
201using Arcane::MessagePassing::MessageRank;
202using Arcane::MessagePassing::MessageSourceInfo;
203using Arcane::MessagePassing::MessageTag;
204using Arcane::MessagePassing::PointToPointMessageInfo;
205using Arcane::MessagePassing::Request;
206using Arcane::MessagePassing::MessagePassingMng;
207using Arcane::MessagePassing::SubRequestCompletionInfo;
209using Arcane::MessagePassing::Communicator;
210using Arcane::MessagePassing::IProfiler;
211using Arcane::MessagePassing::IStat;
212using Arcane::MessagePassing::Stat;
213using Arcane::MessagePassing::ISerializeDispatcher;
214using Arcane::MessagePassing::IDispatchers;
215using Arcane::MessagePassing::Dispatchers;
217using Arcane::MessagePassing::A_NULL_RANK;
218using Arcane::MessagePassing::A_NULL_TAG_VALUE;
219using Arcane::MessagePassing::A_ANY_SOURCE_RANK;
220using Arcane::MessagePassing::A_PROC_NULL_RANK;
222using Arcane::MessagePassing::GatherMessageInfoBase;
223using Arcane::MessagePassing::GatherMessageInfo;
225using Arcane::MessagePassing::OneStat;
226using Arcane::MessagePassing::StatData;
227using Arcane::MessagePassing::IControlDispatcher;
228using Arcane::MessagePassing::IMessagePassingMng;
229using Arcane::MessagePassing::PointToPointSerializerMng;
230using Arcane::MessagePassing::ISerializeMessage;
231using Arcane::MessagePassing::ISerializeMessageList;
247using Arcane::MessagePassing::WaitAll;
251using Arcane::MessagePassing::Blocking;
253using Arcane::MessagePassing::NonBlocking;
256using Arcane::MessagePassing::MsgReceive;
257using Arcane::MessagePassing::MsgSend;
#define ARCCORE_DECLARE_REFERENCE_COUNTED_CLASS(class_name)
Macro pour déclarer qu'une classe utilise un compteur de référence.
Interface d'un sérialiseur.
Interface gérant les statistiques sur l'exécution.
Communicateur pour l'échange de message.
Interface du conteneur des dispatchers.
Informations pour un message 'gather'.
Informations pour un message 'gather' pour le type de données DataType.
Interface du conteneur des dispatchers.
Interface du gestionnaire des échanges de messages.
Interface d'un profiler pour les échanges de messages.
Interface d'un créateur de requête.
Liste de requête de messages.
Interface des messages de sérialisation.
Interface d'une liste de messages de sérialisation.
Statistiques sur le parallélisme.
Gestionnaire des échanges de messages.
Informations sur la source d'un message.
Statistique sur un message.
Informations pour envoyer/recevoir un message point à point.
Communications point à point par des 'ISerializer'.
Déclarations des types et méthodes utilisés par les mécanismes d'échange de messages.
@ WaitSome
Attend que tous les messages de la liste soient traités.
@ TestSome
Attend que au moins un message de la liste soit traité
eBlockingType
Type indiquant si un message est bloquant ou non.
ePointToPointMessageType
Type de message point à point.
eReduceType
Types des réductions supportées.
@ ReduceSum
Somme des valeurs.
@ ReduceMin
Minimum des valeurs.
@ ReduceMax
Maximum des valeurs.
Implémentation de la concurrence.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
std::int32_t Int32
Type entier signé sur 32 bits.
Espace de nommage contenant les types et déclarations qui gèrent le mécanisme de parallélisme par éch...
Espace de nom de Arccore.