Arcane  v3.14.10.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
MemoryRessourceMng.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2024 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/* MemoryRessourceMng.h (C) 2000-2024 */
9/* */
10/* Gestion des ressources mémoire pour les CPU et accélérateurs. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_UTILS_INTERNAL_MEMORYRESSOURCEMNG_H
13#define ARCANE_UTILS_INTERNAL_MEMORYRESSOURCEMNG_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/utils/IMemoryRessourceMng.h"
18#include "arcane/utils/FixedArray.h"
19#include "arcane/utils/internal/IMemoryRessourceMngInternal.h"
20
21#include <memory>
22#include <array>
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27namespace Arcane
28{
29
30/*---------------------------------------------------------------------------*/
31/*---------------------------------------------------------------------------*/
35class ARCANE_UTILS_EXPORT MemoryRessourceMng
38{
39 public:
40
42
43 public:
44
45 IMemoryAllocator* getAllocator(eMemoryRessource r) override;
46 IMemoryAllocator* getAllocator(eMemoryRessource r, bool throw_if_not_found) override;
47
48 public:
49
50 void copy(ConstMemoryView from, eMemoryRessource from_mem,
51 MutableMemoryView to, eMemoryRessource to_mem, const RunQueue* queue) override;
52
53 public:
54
55 void setAllocator(eMemoryRessource r, IMemoryAllocator* allocator) override;
56 void setCopier(IMemoryCopier* copier) override { m_copier = copier; }
57 void setIsAccelerator(bool v) override { m_is_accelerator = v; }
58
59 public:
60
62 IMemoryRessourceMngInternal* _internal() override { return this; }
63
64 public:
65
67 static void genericCopy(ConstMemoryView from, MutableMemoryView to);
68
69 private:
70
72 std::unique_ptr<IMemoryCopier> m_default_memory_copier;
73 IMemoryCopier* m_copier = nullptr;
74 bool m_is_accelerator = false;
75
76 private:
77
78 inline int _checkValidRessource(eMemoryRessource r);
79};
80
81/*---------------------------------------------------------------------------*/
82/*---------------------------------------------------------------------------*/
83
84} // End namespace Arcane
85
86/*---------------------------------------------------------------------------*/
87/*---------------------------------------------------------------------------*/
88
89#endif
File d'exécution pour un accélérateur.
Interface pour les copies mémoire avec support des accélérateurs.
Partie interne à Arcane de 'IMemoryRessourceMng'.
Gestion des ressources mémoire pour les CPU et accélérateurs.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:120
Gestion des ressources mémoire pour les CPU et accélérateurs.
IMemoryRessourceMngInternal * _internal() override
Interface interne.
void setIsAccelerator(bool v) override
Indique si un accélérateur est disponible.
void setCopier(IMemoryCopier *copier) override
Positionne l'instance gérant les copies.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
eMemoryRessource
Liste des ressources mémoire disponibles.