File size: 4,676 Bytes
5a29263
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/*

 * Copyright (c) 2023-2024 The ggml authors

 *

 * Permission is hereby granted, free of charge, to any person obtaining a copy

 * of this software and associated documentation files (the "Software"), to

 * deal in the Software without restriction, including without limitation the

 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or

 * sell copies of the Software, and to permit persons to whom the Software is

 * furnished to do so, subject to the following conditions:

 *

 * The above copyright notice and this permission notice shall be included in

 * all copies or substantial portions of the Software.

 *

 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR

 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,

 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE

 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER

 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING

 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS

 * IN THE SOFTWARE.

 */

#pragma once

#include "ggml-backend.h"
#include "ggml.h"

#ifdef __cplusplus
extern "C" {
#endif

/**

 * @brief Maximum number of CANN devices supported.

 */
#define GGML_CANN_MAX_DEVICES 16

GGML_BACKEND_API ggml_backend_reg_t ggml_backend_cann_reg(void);

/**

 * @brief Initializes the CANN backend for a specified device.

 *

 * This function initializes the CANN backend for the given device.

 * It verifies the device index, allocates a context, and creates a backend

 * instance.

 *

 * @param device The index of the device to initialize.

 * @return A pointer to the initialized backend instance, or nullptr on failure.

 */
GGML_BACKEND_API ggml_backend_t ggml_backend_cann_init(int32_t device);

/**

 * @brief Checks if a given backend is a CANN backend.

 *

 * This function verifies if the provided backend is a CANN backend by comparing

 * its GUID with the CANN backend's GUID.

 *

 * @param backend The backend instance to check.

 * @return True if the backend is a CANN backend, false otherwise.

 */
GGML_BACKEND_API bool ggml_backend_is_cann(ggml_backend_t backend);

/**

 * @brief Retrieves the CANN buffer type for a specified device.

 *

 * This function initializes and returns the buffer type interface associated

 * with the given device. It ensures thread-safe access using a mutex.

 *

 * @param device The device index for which to retrieve the buffer type.

 * @return A pointer to the buffer type interface for the specified device, or

 * nullptr if the device index is out of range.

 */
GGML_BACKEND_API ggml_backend_buffer_type_t
ggml_backend_cann_buffer_type(int32_t device);

/**

 * @brief Retrieves the number of CANN devices available.

 *

 * This function returns the number of CANN devices available based on

 * information obtained from `ggml_cann_info()`.

 *

 * @return The number of CANN devices available.

 */
GGML_BACKEND_API int32_t ggml_backend_cann_get_device_count(void);

/**

 * @brief pinned host buffer for use with the CPU backend for faster copies between CPU and NPU.

 *

 * @return A pointer to the host buffer type interface.

 */
GGML_BACKEND_API ggml_backend_buffer_type_t ggml_backend_cann_host_buffer_type(void);

/**

 * @brief Retrieves the description of a specific CANN device.

 *

 * This function sets the specified device, retrieves the SoC name,

 * and writes it into the provided description buffer.

 *

 * @param device The device index to retrieve the description for.

 * @param description Pointer to a buffer where the description will be written.

 * @param description_size Size of the description buffer.

 */
GGML_BACKEND_API void ggml_backend_cann_get_device_description(

    int32_t device, char* description, size_t description_size);

/**

 * @brief Retrieves the memory information of a specific CANN device.

 *

 * This function sets the specified device, retrieves the free and total

 * memory information of the specified type (ACL_HBM_MEM), and stores them

 * in the provided pointers.

 *

 * @param device The device index to retrieve memory information for.

 * @param free Pointer to a variable where the free memory size will be stored.

 * @param total Pointer to a variable where the total memory size will be

 * stored.

 */
GGML_BACKEND_API void ggml_backend_cann_get_device_memory(int32_t device,

                                                  size_t* free,

                                                  size_t* total);

#ifdef __cplusplus
}
#endif