dyn_ext_server.c 5.1 KB
Newer Older
1
#include "dyn_ext_server.h"
2
3
4
5

#include <stdio.h>
#include <string.h>

6
#ifdef __linux__
7
#include <dlfcn.h>
8
#define LOAD_LIBRARY(lib, flags) dlopen(lib, flags | RTLD_DEEPBIND)
9
#define LOAD_SYMBOL(handle, sym) dlsym(handle, sym)
10
#define LOAD_ERR() strdup(dlerror())
11
#define UNLOAD_LIBRARY(handle) dlclose(handle)
12
#elif _WIN32
13
14
15
16
#include <windows.h>
#define LOAD_LIBRARY(lib, flags) LoadLibrary(lib)
#define LOAD_SYMBOL(handle, sym) GetProcAddress(handle, sym)
#define UNLOAD_LIBRARY(handle) FreeLibrary(handle)
17
18
19
20
21
22
23
24
25
26
inline char *LOAD_ERR() {
  LPSTR messageBuffer = NULL;
  size_t size = FormatMessageA(
      FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM |
          FORMAT_MESSAGE_IGNORE_INSERTS,
      NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
      (LPSTR)&messageBuffer, 0, NULL);
  char *resp = strdup(messageBuffer);
  LocalFree(messageBuffer);
  return resp;
27
}
28
29
30
31
#else
#include <dlfcn.h>
#define LOAD_LIBRARY(lib, flags) dlopen(lib, flags)
#define LOAD_SYMBOL(handle, sym) dlsym(handle, sym)
32
#define LOAD_ERR() strdup(dlerror())
33
#define UNLOAD_LIBRARY(handle) dlclose(handle)
34
35
#endif

36
void dyn_init(const char *libPath, struct dynamic_llama_server *s,
37
                       ext_server_resp_t *err) {
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
  int i = 0;
  struct lookup {
    char *s;
    void **p;
  } l[] = {
      {"llama_server_init", (void *)&s->llama_server_init},
      {"llama_server_start", (void *)&s->llama_server_start},
      {"llama_server_stop", (void *)&s->llama_server_stop},
      {"llama_server_completion", (void *)&s->llama_server_completion},
      {"llama_server_completion_next_result",
       (void *)&s->llama_server_completion_next_result},
      {"llama_server_completion_cancel",
       (void *)&s->llama_server_completion_cancel},
      {"llama_server_release_task_result",
       (void *)&s->llama_server_release_task_result},
      {"llama_server_tokenize", (void *)&s->llama_server_tokenize},
      {"llama_server_detokenize", (void *)&s->llama_server_detokenize},
      {"llama_server_embedding", (void *)&s->llama_server_embedding},
      {"llama_server_release_json_resp",
       (void *)&s->llama_server_release_json_resp},
      {"", NULL},
  };

61
  printf("loading %s library\n", libPath);
62
  s->handle = LOAD_LIBRARY(libPath, RTLD_NOW);
63
64
  if (!s->handle) {
    err->id = -1;
65
    char *msg = LOAD_ERR();
66
    snprintf(err->msg, err->msg_len,
67
68
             "Unable to load dynamic server library: %s", msg);
    free(msg);
69
70
71
72
73
74
75
76
    return;
  }

  for (i = 0; l[i].p != NULL; i++) {
    *l[i].p = LOAD_SYMBOL(s->handle, l[i].s);
    if (!l[i].p) {
      UNLOAD_LIBRARY(s->handle);
      err->id = -1;
77
      char *msg = LOAD_ERR();
78
      snprintf(err->msg, err->msg_len, "symbol lookup for %s failed: %s",
79
80
               l[i].s, msg);
      free(msg);
81
82
83
84
85
      return;
    }
  }
}

86
inline void dyn_llama_server_init(struct dynamic_llama_server s,
87
88
                                           ext_server_params_t *sparams,
                                           ext_server_resp_t *err) {
89
90
91
  s.llama_server_init(sparams, err);
}

92
inline void dyn_llama_server_start(struct dynamic_llama_server s) {
93
94
95
  s.llama_server_start();
}

96
inline void dyn_llama_server_stop(struct dynamic_llama_server s) {
97
98
99
  s.llama_server_stop();
}

100
inline void dyn_llama_server_completion(struct dynamic_llama_server s,
101
102
                                                 const char *json_req,
                                                 ext_server_resp_t *resp) {
103
104
105
  s.llama_server_completion(json_req, resp);
}

106
inline void dyn_llama_server_completion_next_result(
107
    struct dynamic_llama_server s, const int task_id,
108
109
110
111
    ext_server_task_result_t *result) {
  s.llama_server_completion_next_result(task_id, result);
}

112
inline void dyn_llama_server_completion_cancel(
113
    struct dynamic_llama_server s, const int task_id, ext_server_resp_t *err) {
114
115
  s.llama_server_completion_cancel(task_id, err);
}
116
inline void dyn_llama_server_release_task_result(
117
    struct dynamic_llama_server s, ext_server_task_result_t *result) {
118
119
120
  s.llama_server_release_task_result(result);
}

121
inline void dyn_llama_server_tokenize(struct dynamic_llama_server s,
122
123
124
                                               const char *json_req,
                                               char **json_resp,
                                               ext_server_resp_t *err) {
125
126
127
  s.llama_server_tokenize(json_req, json_resp, err);
}

128
inline void dyn_llama_server_detokenize(struct dynamic_llama_server s,
129
130
131
                                                 const char *json_req,
                                                 char **json_resp,
                                                 ext_server_resp_t *err) {
132
133
134
  s.llama_server_detokenize(json_req, json_resp, err);
}

135
inline void dyn_llama_server_embedding(struct dynamic_llama_server s,
136
137
138
                                                const char *json_req,
                                                char **json_resp,
                                                ext_server_resp_t *err) {
139
140
141
  s.llama_server_embedding(json_req, json_resp, err);
}

142
inline void dyn_llama_server_release_json_resp(
143
    struct dynamic_llama_server s, char **json_resp) {
144
145
  s.llama_server_release_json_resp(json_resp);
}