mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-03 15:24:35 +00:00
This commit is contained in:
parent
04ef648f3e
commit
db53f8ef06
@ -19494,6 +19494,7 @@ struct llama_context * llama_new_context_with_model(
|
|||||||
// buffer used to store the computation graph and the tensor meta data
|
// buffer used to store the computation graph and the tensor meta data
|
||||||
ctx->buf_compute_meta.resize(ggml_tensor_overhead()*max_nodes + ggml_graph_overhead_custom(max_nodes, false));
|
ctx->buf_compute_meta.resize(ggml_tensor_overhead()*max_nodes + ggml_graph_overhead_custom(max_nodes, false));
|
||||||
|
|
||||||
|
// TODO: move these checks to ggml_backend_sched
|
||||||
// enabling pipeline parallelism in the scheduler increases memory usage, so it is only done when necessary
|
// enabling pipeline parallelism in the scheduler increases memory usage, so it is only done when necessary
|
||||||
bool pipeline_parallel =
|
bool pipeline_parallel =
|
||||||
llama_get_device_count(*model) > 1 &&
|
llama_get_device_count(*model) > 1 &&
|
||||||
@ -19501,12 +19502,29 @@ struct llama_context * llama_new_context_with_model(
|
|||||||
model->split_mode == LLAMA_SPLIT_MODE_LAYER &&
|
model->split_mode == LLAMA_SPLIT_MODE_LAYER &&
|
||||||
params.offload_kqv;
|
params.offload_kqv;
|
||||||
|
|
||||||
// FIXME
|
// pipeline parallelism requires support for async compute and events in all devices
|
||||||
#if !defined(GGML_USE_CUDA) && false
|
if (pipeline_parallel) {
|
||||||
// pipeline parallelism requires support for async compute and events
|
for (auto * backend : ctx->backends) {
|
||||||
// currently this is only implemented in the CUDA backend
|
if (ggml_backend_is_cpu(backend)) {
|
||||||
|
// ignore CPU backend
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
auto * dev = ggml_backend_get_device(backend);
|
||||||
|
if (!dev) {
|
||||||
|
// backend is using old interface, not supported
|
||||||
pipeline_parallel = false;
|
pipeline_parallel = false;
|
||||||
#endif
|
break;
|
||||||
|
}
|
||||||
|
ggml_backend_dev_props props;
|
||||||
|
ggml_backend_dev_get_props(dev, &props);
|
||||||
|
if (!props.caps.async || !props.caps.events) {
|
||||||
|
// device does not support async compute or events
|
||||||
|
pipeline_parallel = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ctx->sched = ggml_backend_sched_new(ctx->backends.data(), backend_buft.data(), ctx->backends.size(), max_nodes, pipeline_parallel);
|
ctx->sched = ggml_backend_sched_new(ctx->backends.data(), backend_buft.data(), ctx->backends.size(), max_nodes, pipeline_parallel);
|
||||||
|
|
||||||
if (pipeline_parallel) {
|
if (pipeline_parallel) {
|
||||||
|
Loading…
Reference in New Issue
Block a user