Ver Fonte

llama : use smart pointers for ggml resources (#10117)

Diego Devesa há 1 ano atrás
pai
commit
e991e3127f
4 ficheiros alterados com 185 adições e 210 exclusões
  1. 38 0
      ggml/include/ggml-cpp.h
  2. 1 0
      ggml/src/CMakeLists.txt
  3. 1 0
      spm-headers/ggml-cpp.h
  4. 145 210
      src/llama.cpp

+ 38 - 0
ggml/include/ggml-cpp.h

@@ -0,0 +1,38 @@
+#pragma once
+
+#ifndef __cplusplus
+#error "This header is for C++ only"
+#endif
+
+#include "ggml.h"
+#include "ggml-alloc.h"
+#include "ggml-backend.h"
+#include <memory>
+
+// Smart pointers for ggml types
+
+// ggml
+
+struct ggml_context_deleter { void operator()(ggml_context * ctx) { ggml_free(ctx); } };
+struct gguf_context_deleter { void operator()(gguf_context * ctx) { gguf_free(ctx); } };
+
+typedef std::unique_ptr<ggml_context, ggml_context_deleter> ggml_context_ptr;
+typedef std::unique_ptr<gguf_context, gguf_context_deleter> gguf_context_ptr;
+
+// ggml-alloc
+
+struct ggml_gallocr_deleter { void operator()(ggml_gallocr_t galloc) { ggml_gallocr_free(galloc); } };
+
+typedef std::unique_ptr<ggml_gallocr_t, ggml_gallocr_deleter> ggml_gallocr_ptr;
+
+// ggml-backend
+
+struct ggml_backend_deleter        { void operator()(ggml_backend_t backend)       { ggml_backend_free(backend); } };
+struct ggml_backend_buffer_deleter { void operator()(ggml_backend_buffer_t buffer) { ggml_backend_buffer_free(buffer); } };
+struct ggml_backend_event_deleter  { void operator()(ggml_backend_event_t event)   { ggml_backend_event_free(event); } };
+struct ggml_backend_sched_deleter  { void operator()(ggml_backend_sched_t sched)   { ggml_backend_sched_free(sched); } };
+
+typedef std::unique_ptr<ggml_backend,        ggml_backend_deleter>        ggml_backend_ptr;
+typedef std::unique_ptr<ggml_backend_buffer, ggml_backend_buffer_deleter> ggml_backend_buffer_ptr;
+typedef std::unique_ptr<ggml_backend_event,  ggml_backend_event_deleter>  ggml_backend_event_ptr;
+typedef std::unique_ptr<ggml_backend_sched,  ggml_backend_sched_deleter>  ggml_backend_sched_ptr;

+ 1 - 0
ggml/src/CMakeLists.txt

@@ -1368,6 +1368,7 @@ add_library(ggml
             ../include/ggml.h
             ../include/ggml.h
             ../include/ggml-alloc.h
             ../include/ggml-alloc.h
             ../include/ggml-backend.h
             ../include/ggml-backend.h
+            ../include/ggml-cpp.h
             ggml.c
             ggml.c
             ggml-alloc.c
             ggml-alloc.c
             ggml-backend.cpp
             ggml-backend.cpp

+ 1 - 0
spm-headers/ggml-cpp.h

@@ -0,0 +1 @@
+../ggml/include/ggml-cpp.h

Diff do ficheiro suprimidas por serem muito extensas
+ 145 - 210
src/llama.cpp


Alguns ficheiros não foram mostrados porque muitos ficheiros mudaram neste diff