dynamic_shim.c 4.93 KB
Newer Older
1
#include "dynamic_shim.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
10
11
#define LOAD_SYMBOL(handle, sym) dlsym(handle, sym)
#define LOAD_ERR() dlerror()
#define UNLOAD_LIBRARY(handle) dlclose(handle)
12
#elif _WIN32
13
14
15
16
17
18
19
20
21
22
#include <windows.h>
#define LOAD_LIBRARY(lib, flags) LoadLibrary(lib)
#define LOAD_SYMBOL(handle, sym) GetProcAddress(handle, sym)
#define UNLOAD_LIBRARY(handle) FreeLibrary(handle)
// TODO - refactor this with proper error message handling on windows
inline static char *LOAD_ERR() {
  static char errbuf[8];
  snprintf(errbuf, 8, "0x%lx", GetLastError());
  return errbuf;
}
23
24
25
26
27
28
#else
#include <dlfcn.h>
#define LOAD_LIBRARY(lib, flags) dlopen(lib, flags)
#define LOAD_SYMBOL(handle, sym) dlsym(handle, sym)
#define LOAD_ERR() dlerror()
#define UNLOAD_LIBRARY(handle) dlclose(handle)
29
30
#endif

31
32
void dynamic_shim_init(const char *libPath, struct dynamic_llama_server *s,
                       ext_server_resp_t *err) {
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
  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},
  };

  printf("Lazy loading %s library\n", libPath);
57
  s->handle = LOAD_LIBRARY(libPath, RTLD_NOW);
58
59
  if (!s->handle) {
    err->id = -1;
60
61
    snprintf(err->msg, err->msg_len,
             "Unable to load dynamic server library: %s", LOAD_ERR());
62
63
64
65
66
67
68
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;
      snprintf(err->msg, err->msg_len, "symbol lookup for %s failed: %s",
               l[i].s, LOAD_ERR());
      return;
    }
  }
}

77
78
79
inline void dynamic_shim_llama_server_init(struct dynamic_llama_server s,
                                           ext_server_params_t *sparams,
                                           ext_server_resp_t *err) {
80
81
82
  s.llama_server_init(sparams, err);
}

83
inline void dynamic_shim_llama_server_start(struct dynamic_llama_server s) {
84
85
86
  s.llama_server_start();
}

87
inline void dynamic_shim_llama_server_stop(struct dynamic_llama_server s) {
88
89
90
  s.llama_server_stop();
}

91
92
93
inline void dynamic_shim_llama_server_completion(struct dynamic_llama_server s,
                                                 const char *json_req,
                                                 ext_server_resp_t *resp) {
94
95
96
  s.llama_server_completion(json_req, resp);
}

97
98
inline void dynamic_shim_llama_server_completion_next_result(
    struct dynamic_llama_server s, const int task_id,
99
100
101
102
    ext_server_task_result_t *result) {
  s.llama_server_completion_next_result(task_id, result);
}

103
104
inline void dynamic_shim_llama_server_completion_cancel(
    struct dynamic_llama_server s, const int task_id, ext_server_resp_t *err) {
105
106
  s.llama_server_completion_cancel(task_id, err);
}
107
108
inline void dynamic_shim_llama_server_release_task_result(
    struct dynamic_llama_server s, ext_server_task_result_t *result) {
109
110
111
  s.llama_server_release_task_result(result);
}

112
113
114
115
inline void dynamic_shim_llama_server_tokenize(struct dynamic_llama_server s,
                                               const char *json_req,
                                               char **json_resp,
                                               ext_server_resp_t *err) {
116
117
118
  s.llama_server_tokenize(json_req, json_resp, err);
}

119
120
121
122
inline void dynamic_shim_llama_server_detokenize(struct dynamic_llama_server s,
                                                 const char *json_req,
                                                 char **json_resp,
                                                 ext_server_resp_t *err) {
123
124
125
  s.llama_server_detokenize(json_req, json_resp, err);
}

126
127
128
129
inline void dynamic_shim_llama_server_embedding(struct dynamic_llama_server s,
                                                const char *json_req,
                                                char **json_resp,
                                                ext_server_resp_t *err) {
130
131
132
  s.llama_server_embedding(json_req, json_resp, err);
}

133
134
inline void dynamic_shim_llama_server_release_json_resp(
    struct dynamic_llama_server s, char **json_resp) {
135
136
  s.llama_server_release_json_resp(json_resp);
}