patch: always add token to cache_tokens (#2459)

This commit is contained in:
Jeffrey Morgan 2024-02-12 08:10:16 -08:00 committed by GitHub
parent 1c8435ffa9
commit 26b13fc33c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -1,30 +1,21 @@
diff --git a/examples/server/server.cpp b/examples/server/server.cpp diff --git a/examples/server/server.cpp b/examples/server/server.cpp
index d86d7e04..7d71c766 100644 index d86d7e04..2694e92e 100644
--- a/examples/server/server.cpp --- a/examples/server/server.cpp
+++ b/examples/server/server.cpp +++ b/examples/server/server.cpp
@@ -1598,12 +1598,6 @@ struct llama_server_context @@ -901,13 +901,15 @@ struct llama_server_context
LOG_TEE("slot %d : in cache: %i tokens | to process: %i tokens\n", slot.id, slot.n_past, slot.num_prompt_tokens_processed); slot.sent_count += result.text_to_send.size();
// add the token to slot queue and cache
} }
- slot.add_token_string(result);
- LOG_TEE("slot %d : kv cache rm - [%d, end)\n", slot.id, (int) system_tokens.size() + slot.n_past); +
- if (slot.params.stream)
- llama_kv_cache_seq_rm(ctx, slot.id, system_tokens.size() + slot.n_past, -1);
-
- slot.cache_tokens = prompt_tokens;
-
if (slot.n_past == slot.num_prompt_tokens && slot.n_past > 0)
{ {
// we have to evaluate at least 1 token to generate logits. send_partial_response(slot, result);
@@ -1615,6 +1609,12 @@ struct llama_server_context
} }
} }
+ LOG_TEE("slot %d : kv cache rm - [%d, end)\n", slot.id, (int) system_tokens.size() + slot.n_past); + slot.add_token_string(result);
+ +
+ llama_kv_cache_seq_rm(ctx, slot.id, system_tokens.size() + slot.n_past, -1); if (incomplete)
+ {
+ slot.cache_tokens = prompt_tokens; slot.has_next_token = true;
+
LOG_VERBOSE("prompt ingested", {
{"n_past", slot.n_past},
{"cached", tokens_to_str(ctx, slot.cache_tokens.cbegin(), slot.cache_tokens.cbegin() + slot.n_past)},