mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-15 23:00:46 +01:00
29 lines
811 B
C++
29 lines
811 B
C++
|
// ref: https://github.com/ggerganov/llama.cpp/issues/4952#issuecomment-1892864763
|
||
|
|
||
|
#include <cstdio>
|
||
|
#include <string>
|
||
|
#include <thread>
|
||
|
|
||
|
#include "llama.h"
|
||
|
|
||
|
// This creates a new context inside a pthread and then tries to exit cleanly.
|
||
|
int main(int argc, char ** argv) {
|
||
|
if (argc < 2) {
|
||
|
printf("Usage: %s model.gguf\n", argv[0]);
|
||
|
return 0; // intentionally return success
|
||
|
}
|
||
|
|
||
|
const std::string fname = argv[1];
|
||
|
|
||
|
std::thread([&fname]() {
|
||
|
llama_backend_init(false);
|
||
|
auto * model = llama_load_model_from_file(fname.c_str(), llama_model_default_params());
|
||
|
auto * ctx = llama_new_context_with_model(model, llama_context_default_params());
|
||
|
llama_free(ctx);
|
||
|
llama_free_model(model);
|
||
|
llama_backend_free();
|
||
|
}).join();
|
||
|
|
||
|
return 0;
|
||
|
}
|