refactor llama.cpp modifications

This commit is contained in:
Jared Van Bortel 2023-12-15 13:38:54 -05:00
parent c8fd4ba846
commit f58f581ca8

View File

@ -731,7 +731,7 @@ static std::string llama_format_win_err(DWORD err) {
struct llama_buffer { struct llama_buffer {
void * data = NULL; void * data = NULL;
size_t size = 0; size_t size = 0;
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
ggml_vk_memory memory; ggml_vk_memory memory;
#endif #endif
@ -742,7 +742,7 @@ struct llama_buffer {
void resize(size_t n) { void resize(size_t n) {
llama_host_free(data); llama_host_free(data);
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
if (ggml_vk_has_device()) { if (ggml_vk_has_device()) {
this->memory = ggml_vk_allocate(n); this->memory = ggml_vk_allocate(n);
this->data = (uint8_t*)memory.data; this->data = (uint8_t*)memory.data;
@ -764,7 +764,7 @@ struct llama_buffer {
~llama_buffer() { ~llama_buffer() {
if (data) { if (data) {
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
if (ggml_vk_has_device()) { if (ggml_vk_has_device()) {
ggml_vk_free_memory(memory); ggml_vk_free_memory(memory);
data = NULL; data = NULL;
@ -1517,7 +1517,6 @@ struct llama_context {
#ifdef GGML_USE_MPI #ifdef GGML_USE_MPI
ggml_mpi_context * ctx_mpi = NULL; ggml_mpi_context * ctx_mpi = NULL;
#endif #endif
}; };
// //
@ -2113,7 +2112,7 @@ struct llama_model_loader {
use_mmap = false; use_mmap = false;
} }
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
use_mmap = false; use_mmap = false;
#endif #endif
this->use_mmap = use_mmap; this->use_mmap = use_mmap;
@ -3790,8 +3789,7 @@ static struct ggml_tensor * llm_build_inp_embd(
const llama_hparams & hparams, const llama_hparams & hparams,
const llama_batch & batch, const llama_batch & batch,
struct ggml_tensor * tok_embd, struct ggml_tensor * tok_embd,
const llm_build_cb & cb, const llm_build_cb & cb) {
struct ggml_tensor ** to_device_tensor = nullptr) {
const int64_t n_embd = hparams.n_embd; const int64_t n_embd = hparams.n_embd;
struct ggml_tensor * inpL; struct ggml_tensor * inpL;
@ -3799,9 +3797,6 @@ static struct ggml_tensor * llm_build_inp_embd(
if (batch.token) { if (batch.token) {
struct ggml_tensor * inp_tokens = ggml_new_tensor_1d(ctx, GGML_TYPE_I32, batch.n_tokens); struct ggml_tensor * inp_tokens = ggml_new_tensor_1d(ctx, GGML_TYPE_I32, batch.n_tokens);
cb(inp_tokens, "inp_tokens", -1); cb(inp_tokens, "inp_tokens", -1);
if (to_device_tensor) {
*to_device_tensor = inp_tokens;
}
inpL = ggml_get_rows(ctx, tok_embd, inp_tokens); inpL = ggml_get_rows(ctx, tok_embd, inp_tokens);
} else { } else {
@ -3810,9 +3805,6 @@ static struct ggml_tensor * llm_build_inp_embd(
#endif #endif
inpL = ggml_new_tensor_2d(ctx, GGML_TYPE_F32, n_embd, batch.n_tokens); inpL = ggml_new_tensor_2d(ctx, GGML_TYPE_F32, n_embd, batch.n_tokens);
if (to_device_tensor) {
*to_device_tensor = inpL;
}
} }
return inpL; return inpL;
@ -3820,7 +3812,7 @@ static struct ggml_tensor * llm_build_inp_embd(
// Persimmon: n_rot = n_embd_head/2 // Persimmon: n_rot = n_embd_head/2
// Other: n_rot = n_embd_head // Other: n_rot = n_embd_head
static struct ggml_tensor * llm_build_k_shift( static void llm_build_k_shift(
struct ggml_context * ctx, struct ggml_context * ctx,
const llama_hparams & hparams, const llama_hparams & hparams,
const llama_cparams & cparams, const llama_cparams & cparams,
@ -3869,8 +3861,6 @@ static struct ggml_tensor * llm_build_k_shift(
cb(tmp, "K_shifted", il); cb(tmp, "K_shifted", il);
ggml_build_forward_expand(graph, tmp); ggml_build_forward_expand(graph, tmp);
} }
return K_shift;
} }
static void llm_build_kv_store( static void llm_build_kv_store(
@ -4148,7 +4138,7 @@ struct llm_build_context {
llama_buffer & buf_compute; llama_buffer & buf_compute;
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
ggml_kompute_context * ctx_kompute; ggml_kompute_context * ctx_kompute;
#endif #endif
@ -4187,7 +4177,7 @@ struct llm_build_context {
do_rope_shift (worst_case || kv_self.has_shift), do_rope_shift (worst_case || kv_self.has_shift),
cb (cb), cb (cb),
buf_compute (lctx.buf_compute) buf_compute (lctx.buf_compute)
#if defined(GGML_USE_KOMPUTE) #ifdef GGML_USE_KOMPUTE
, ctx_kompute (lctx.ctx_kompute) , ctx_kompute (lctx.ctx_kompute)
#endif #endif
{ {
@ -4220,9 +4210,8 @@ struct llm_build_context {
struct ggml_tensor * cur; struct ggml_tensor * cur;
struct ggml_tensor * inpL; struct ggml_tensor * inpL;
struct ggml_tensor * to_device_tensor = nullptr;
inpL = llm_build_inp_embd(ctx0, hparams, batch, model.tok_embd, cb, &to_device_tensor); inpL = llm_build_inp_embd(ctx0, hparams, batch, model.tok_embd, cb);
cb(inpL, "inp_embd", -1); cb(inpL, "inp_embd", -1);
// inp_pos - contains the positions // inp_pos - contains the positions
@ -4238,9 +4227,8 @@ struct llm_build_context {
cb(KQ_mask, "KQ_mask", -1); cb(KQ_mask, "KQ_mask", -1);
// shift the entire K-cache if needed // shift the entire K-cache if needed
struct ggml_tensor * K_shift = nullptr;
if (do_rope_shift) { if (do_rope_shift) {
K_shift = llm_build_k_shift(ctx0, hparams, cparams, kv_self, gf, LLM_ROPE, n_ctx, n_embd_head, freq_base, freq_scale, cb); llm_build_k_shift(ctx0, hparams, cparams, kv_self, gf, LLM_ROPE, n_ctx, n_embd_head, freq_base, freq_scale, cb);
} }
for (int il = 0; il < n_layer; ++il) { for (int il = 0; il < n_layer; ++il) {
@ -4336,21 +4324,6 @@ struct llm_build_context {
ggml_build_forward_expand(gf, cur); ggml_build_forward_expand(gf, cur);
#if defined(GGML_USE_KOMPUTE)
if (ctx_kompute) {
if (!ggml_vk_has_h2d_all(ctx_kompute)) {
ggml_vk_h2d_all(ctx_kompute);
} else {
ggml_vk_h2d_tensor(ctx_kompute, to_device_tensor);
ggml_vk_h2d_tensor(ctx_kompute, inp_pos);
ggml_vk_h2d_tensor(ctx_kompute, KQ_mask);
if (K_shift) {
ggml_vk_h2d_tensor(ctx_kompute, K_shift);
}
}
}
#endif
return gf; return gf;
} }
@ -4479,9 +4452,8 @@ struct llm_build_context {
struct ggml_tensor * cur; struct ggml_tensor * cur;
struct ggml_tensor * inpL; struct ggml_tensor * inpL;
struct ggml_tensor * to_device_tensor = nullptr;
inpL = llm_build_inp_embd(ctx0, hparams, batch, model.tok_embd, cb, &to_device_tensor); inpL = llm_build_inp_embd(ctx0, hparams, batch, model.tok_embd, cb);
cb(inpL, "inp_embd", -1); cb(inpL, "inp_embd", -1);
// inp_pos - contains the positions // inp_pos - contains the positions
@ -4497,9 +4469,8 @@ struct llm_build_context {
cb(KQ_mask, "KQ_mask", -1); cb(KQ_mask, "KQ_mask", -1);
// shift the entire K-cache if needed // shift the entire K-cache if needed
struct ggml_tensor * K_shift = nullptr;
if (do_rope_shift) { if (do_rope_shift) {
K_shift = llm_build_k_shift(ctx0, hparams, cparams, kv_self, gf, LLM_ROPE_NEOX, n_ctx, n_embd_head, freq_base, freq_scale, cb); llm_build_k_shift(ctx0, hparams, cparams, kv_self, gf, LLM_ROPE_NEOX, n_ctx, n_embd_head, freq_base, freq_scale, cb);
} }
for (int il = 0; il < n_layer; ++il) { for (int il = 0; il < n_layer; ++il) {
@ -4595,21 +4566,6 @@ struct llm_build_context {
ggml_build_forward_expand(gf, cur); ggml_build_forward_expand(gf, cur);
#if defined(GGML_USE_KOMPUTE)
if (ctx_kompute) {
if (!ggml_vk_has_h2d_all(ctx_kompute)) {
ggml_vk_h2d_all(ctx_kompute);
} else {
ggml_vk_h2d_tensor(ctx_kompute, to_device_tensor);
ggml_vk_h2d_tensor(ctx_kompute, inp_pos);
ggml_vk_h2d_tensor(ctx_kompute, KQ_mask);
if (K_shift) {
ggml_vk_h2d_tensor(ctx_kompute, K_shift);
}
}
}
#endif
return gf; return gf;
} }
@ -5627,6 +5583,10 @@ static struct ggml_cgraph * llama_build_graph(
const bool do_offload = true; // TODO: set to false after finishing refactoring const bool do_offload = true; // TODO: set to false after finishing refactoring
#endif #endif
#ifdef GGML_USE_KOMPUTE
const bool needs_h2d_all = lctx.ctx_kompute && !ggml_vk_has_h2d_all(lctx.ctx_kompute);
#endif
int n_non_view = 0; // number of non-view tensors that have been processed by the callback int n_non_view = 0; // number of non-view tensors that have been processed by the callback
// this callback allows us to apply custom logic to each tensor (e.g. ggml-alloc, offloading, etc.) // this callback allows us to apply custom logic to each tensor (e.g. ggml-alloc, offloading, etc.)
@ -5747,6 +5707,21 @@ static struct ggml_cgraph * llama_build_graph(
n_non_view++; n_non_view++;
} }
#ifdef GGML_USE_KOMPUTE
if (lctx.ctx_kompute && !needs_h2d_all) {
const char * offload_tensors[] = {"inp_tokens", "inp_pos", "KQ_mask", "K_shift"};
for (auto off : offload_tensors) {
if (strcmp(name, off) == 0) {
ggml_vk_h2d_tensor(lctx.ctx_kompute, cur);
break;
}
}
if (strcmp(name, "inp_embd") == 0 && !batch.token) {
ggml_vk_h2d_tensor(lctx.ctx_kompute, cur);
}
}
#endif
// //
// offload layers // offload layers
// //
@ -5915,6 +5890,12 @@ static struct ggml_cgraph * llama_build_graph(
GGML_ASSERT(false); GGML_ASSERT(false);
} }
#ifdef GGML_USE_KOMPUTE
if (needs_h2d_all) {
ggml_vk_h2d_all(lctx.ctx_kompute);
}
#endif
llm.free(); llm.free();
if (worst_case) { if (worst_case) {
@ -6175,7 +6156,6 @@ static int llama_decode_internal(
} }
} }
#if 0
// extract embeddings // extract embeddings
if (!lctx.embedding.empty()) { if (!lctx.embedding.empty()) {
auto & embedding_out = lctx.embedding; auto & embedding_out = lctx.embedding;
@ -6183,7 +6163,6 @@ static int llama_decode_internal(
embedding_out.resize(n_embd); embedding_out.resize(n_embd);
memcpy(embedding_out.data(), (float *) ggml_get_data(embeddings) + (n_embd*(n_tokens - 1)), sizeof(float)*n_embd); memcpy(embedding_out.data(), (float *) ggml_get_data(embeddings) + (n_embd*(n_tokens - 1)), sizeof(float)*n_embd);
} }
#endif
// measure the performance only for the single-token evals // measure the performance only for the single-token evals
if (n_tokens == 1) { if (n_tokens == 1) {
@ -8622,7 +8601,6 @@ static int llama_apply_lora_from_file_internal(
) { ) {
LLAMA_LOG_INFO("%s: applying lora adapter from '%s' - please wait ...\n", __func__, path_lora); LLAMA_LOG_INFO("%s: applying lora adapter from '%s' - please wait ...\n", __func__, path_lora);
const int64_t t_start_lora_us = ggml_time_us(); const int64_t t_start_lora_us = ggml_time_us();
auto fin = std::ifstream(path_lora, std::ios::binary); auto fin = std::ifstream(path_lora, std::ios::binary);