mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-03 23:34:35 +00:00
add version checking
This commit is contained in:
parent
bd9f7b4297
commit
53d7f4f658
@ -409,6 +409,7 @@ static const struct ggml_backend_reg_i ggml_backend_amx_reg_i = {
|
|||||||
|
|
||||||
ggml_backend_reg_t ggml_backend_amx_reg(void) {
|
ggml_backend_reg_t ggml_backend_amx_reg(void) {
|
||||||
static struct ggml_backend_reg ggml_backend_amx_reg = {
|
static struct ggml_backend_reg ggml_backend_amx_reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_amx_reg_i,
|
/* .iface = */ ggml_backend_amx_reg_i,
|
||||||
/* .context = */ NULL,
|
/* .context = */ NULL,
|
||||||
};
|
};
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define GGML_BACKEND_API_VERSION 1
|
||||||
|
|
||||||
//
|
//
|
||||||
// Backend buffer type
|
// Backend buffer type
|
||||||
//
|
//
|
||||||
@ -199,7 +201,7 @@ extern "C" {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct ggml_backend_reg {
|
struct ggml_backend_reg {
|
||||||
// int api_version; // TODO: for dynamic loading
|
int api_version; // initialize to GGML_BACKEND_API_VERSION
|
||||||
struct ggml_backend_reg_i iface;
|
struct ggml_backend_reg_i iface;
|
||||||
void * context;
|
void * context;
|
||||||
};
|
};
|
||||||
|
@ -167,9 +167,14 @@ struct ggml_backend_registry {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
ggml_backend_reg_t reg = backend_init();
|
ggml_backend_reg_t reg = backend_init();
|
||||||
if (!reg) {
|
if (!reg || reg->api_version != GGML_BACKEND_API_VERSION) {
|
||||||
if (!silent) {
|
if (!silent) {
|
||||||
GGML_LOG_ERROR("%s: failed to initialize backend from %s\n", __func__, path);
|
if (!reg) {
|
||||||
|
GGML_LOG_ERROR("%s: failed to initialize backend from %s: ggml_backend_init returned NULL\n", __func__, path);
|
||||||
|
} else {
|
||||||
|
GGML_LOG_ERROR("%s: failed to initialize backend from %s: incompatible API version (backend: %d, current: %d)\n",
|
||||||
|
__func__, path, reg->api_version, GGML_BACKEND_API_VERSION);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
FreeLibrary(handle);
|
FreeLibrary(handle);
|
||||||
|
@ -506,6 +506,7 @@ static const struct ggml_backend_reg_i ggml_backend_blas_reg_i = {
|
|||||||
|
|
||||||
ggml_backend_reg_t ggml_backend_blas_reg(void) {
|
ggml_backend_reg_t ggml_backend_blas_reg(void) {
|
||||||
static struct ggml_backend_reg ggml_backend_blas_reg = {
|
static struct ggml_backend_reg ggml_backend_blas_reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_blas_reg_i,
|
/* .iface = */ ggml_backend_blas_reg_i,
|
||||||
/* .context = */ NULL,
|
/* .context = */ NULL,
|
||||||
};
|
};
|
||||||
|
@ -2064,7 +2064,7 @@ ggml_backend_reg_t ggml_backend_cann_reg() {
|
|||||||
dev_ctx->name = GGML_CANN_NAME + std::to_string(i);
|
dev_ctx->name = GGML_CANN_NAME + std::to_string(i);
|
||||||
ggml_cann_set_device(i);
|
ggml_cann_set_device(i);
|
||||||
ggml_backend_dev_t dev = new ggml_backend_device {
|
ggml_backend_dev_t dev = new ggml_backend_device {
|
||||||
/* .interface = */ ggml_backend_cann_device_interface,
|
/* .iface = */ ggml_backend_cann_device_interface,
|
||||||
/* .reg = */ ®,
|
/* .reg = */ ®,
|
||||||
/* .context = */ dev_ctx
|
/* .context = */ dev_ctx
|
||||||
};
|
};
|
||||||
@ -2072,7 +2072,8 @@ ggml_backend_reg_t ggml_backend_cann_reg() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
reg = ggml_backend_reg {
|
reg = ggml_backend_reg {
|
||||||
/* .interface = */ ggml_backend_cann_reg_interface,
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
|
/* .iface = */ ggml_backend_cann_reg_interface,
|
||||||
/* .context = */ ctx
|
/* .context = */ ctx
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -678,6 +678,7 @@ ggml_backend_reg_t ggml_backend_cpu_reg(void) {
|
|||||||
ggml_cpu_init();
|
ggml_cpu_init();
|
||||||
|
|
||||||
static struct ggml_backend_reg ggml_backend_cpu_reg = {
|
static struct ggml_backend_reg ggml_backend_cpu_reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_cpu_reg_i,
|
/* .iface = */ ggml_backend_cpu_reg_i,
|
||||||
/* .context = */ NULL,
|
/* .context = */ NULL,
|
||||||
};
|
};
|
||||||
|
@ -3227,7 +3227,7 @@ ggml_backend_reg_t ggml_backend_cuda_reg() {
|
|||||||
dev_ctx->description = prop.name;
|
dev_ctx->description = prop.name;
|
||||||
|
|
||||||
ggml_backend_dev_t dev = new ggml_backend_device {
|
ggml_backend_dev_t dev = new ggml_backend_device {
|
||||||
/* .interface = */ ggml_backend_cuda_device_interface,
|
/* .iface = */ ggml_backend_cuda_device_interface,
|
||||||
/* .reg = */ ®,
|
/* .reg = */ ®,
|
||||||
/* .context = */ dev_ctx
|
/* .context = */ dev_ctx
|
||||||
};
|
};
|
||||||
@ -3235,7 +3235,8 @@ ggml_backend_reg_t ggml_backend_cuda_reg() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
reg = ggml_backend_reg {
|
reg = ggml_backend_reg {
|
||||||
/* .interface = */ ggml_backend_cuda_reg_interface,
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
|
/* .iface = */ ggml_backend_cuda_reg_interface,
|
||||||
/* .context = */ ctx
|
/* .context = */ ctx
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -2176,6 +2176,7 @@ static const struct ggml_backend_reg_i ggml_backend_kompute_reg_i = {
|
|||||||
|
|
||||||
ggml_backend_reg_t ggml_backend_kompute_reg() {
|
ggml_backend_reg_t ggml_backend_kompute_reg() {
|
||||||
static ggml_backend_reg reg = {
|
static ggml_backend_reg reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_kompute_reg_i,
|
/* .iface = */ ggml_backend_kompute_reg_i,
|
||||||
/* .context = */ nullptr,
|
/* .context = */ nullptr,
|
||||||
};
|
};
|
||||||
|
@ -4408,6 +4408,7 @@ ggml_backend_reg_t ggml_backend_metal_reg(void) {
|
|||||||
// TODO: make this thread-safe somehow?
|
// TODO: make this thread-safe somehow?
|
||||||
{
|
{
|
||||||
g_ggml_backend_metal_reg = (struct ggml_backend_reg) {
|
g_ggml_backend_metal_reg = (struct ggml_backend_reg) {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_metal_reg_i,
|
/* .iface = */ ggml_backend_metal_reg_i,
|
||||||
/* .context = */ NULL,
|
/* .context = */ NULL,
|
||||||
};
|
};
|
||||||
|
@ -1369,6 +1369,7 @@ static const struct ggml_backend_reg_i ggml_backend_rpc_reg_i = {
|
|||||||
|
|
||||||
ggml_backend_reg_t ggml_backend_rpc_reg(void) {
|
ggml_backend_reg_t ggml_backend_rpc_reg(void) {
|
||||||
static struct ggml_backend_reg ggml_backend_rpc_reg = {
|
static struct ggml_backend_reg ggml_backend_rpc_reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_rpc_reg_i,
|
/* .iface = */ ggml_backend_rpc_reg_i,
|
||||||
/* .context = */ NULL,
|
/* .context = */ NULL,
|
||||||
};
|
};
|
||||||
|
@ -4637,7 +4637,7 @@ ggml_backend_reg_t ggml_backend_sycl_reg() {
|
|||||||
dev_ctx->description = prop.get_name();
|
dev_ctx->description = prop.get_name();
|
||||||
|
|
||||||
ggml_backend_dev_t dev = new ggml_backend_device {
|
ggml_backend_dev_t dev = new ggml_backend_device {
|
||||||
/* .interface = */ ggml_backend_sycl_device_interface,
|
/* .iface = */ ggml_backend_sycl_device_interface,
|
||||||
/* .reg = */ ®,
|
/* .reg = */ ®,
|
||||||
/* .context = */ dev_ctx
|
/* .context = */ dev_ctx
|
||||||
};
|
};
|
||||||
@ -4645,7 +4645,8 @@ ggml_backend_reg_t ggml_backend_sycl_reg() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
reg = ggml_backend_reg {
|
reg = ggml_backend_reg {
|
||||||
/* .interface = */ ggml_backend_sycl_reg_interface,
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
|
/* .iface = */ ggml_backend_sycl_reg_interface,
|
||||||
/* .context = */ ctx
|
/* .context = */ ctx
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -6738,6 +6738,7 @@ static const struct ggml_backend_reg_i ggml_backend_vk_reg_i = {
|
|||||||
|
|
||||||
ggml_backend_reg_t ggml_backend_vk_reg() {
|
ggml_backend_reg_t ggml_backend_vk_reg() {
|
||||||
static ggml_backend_reg reg = {
|
static ggml_backend_reg reg = {
|
||||||
|
/* .api_version = */ GGML_BACKEND_API_VERSION,
|
||||||
/* .iface = */ ggml_backend_vk_reg_i,
|
/* .iface = */ ggml_backend_vk_reg_i,
|
||||||
/* .context = */ nullptr,
|
/* .context = */ nullptr,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user