From c60d61c48c7a1e7b693d4c3f6427e3b616d1f471 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期一, 21 十月 2019 12:29:33 +0800
Subject: [PATCH] update ffmpeg

---
 libcffmpeg.c |  176 ++++++++++++++++++++++++++++++++++------------------------
 1 files changed, 102 insertions(+), 74 deletions(-)

diff --git a/libcffmpeg.c b/libcffmpeg.c
index 0486921..edc7b5c 100644
--- a/libcffmpeg.c
+++ b/libcffmpeg.c
@@ -17,58 +17,9 @@
 libcffmpeg init_libcffmpeg(const char *so_file){
     libcffmpeg lib = dlopen(so_file, RTLD_LAZY);
     if(lib){
-        fn_create = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create");
-        release_if_err(fn_create, lib);
-        fn_create2 = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create2");
-        release_if_err(fn_create2, lib);
 
         fn_destroy = (lib_cffmpeg_destroy)dlsym(lib, "c_ffmpeg_destroy");
         release_if_err(fn_destroy, lib);
-
-        fn_run = (lib_cffmpeg_run)dlsym(lib, "c_ffmpeg_run");
-        release_if_err(fn_run, lib);
-        fn_gb28181 = (lib_cffmpeg_gb28181)dlsym(lib, "c_ffmpeg_run_gb28181");
-        release_if_err(fn_gb28181, lib);
-
-        fn_cpu = (lib_cffmpeg_cpu)dlsym(lib, "c_ffmepg_use_cpu");
-        release_if_err(fn_cpu, lib);
-
-        fn_rec_duration = (lib_cffmpeg_rec_duration)dlsym(lib, "c_ffmpeg_set_record_duration");
-        release_if_err(fn_rec_duration, lib);
-        fn_recorder = (lib_cffmpeg_recorder)dlsym(lib, "c_ffmpeg_build_recorder");
-        release_if_err(fn_recorder, lib);
-        fn_fire_recorder = (lib_cffmpeg_fire_recorder)dlsym(lib, "c_ffmpeg_fire_recorder");
-        release_if_err(fn_fire_recorder, lib);
-        fn_info_recorder = (lib_cffmpeg_info_recorder)dlsym(lib, "c_ffmpeg_get_info_recorder");
-        release_if_err(fn_info_recorder, lib);
-
-        fn_decoder = (lib_cffmpeg_decoder)dlsym(lib, "c_ffmpeg_build_decoder");
-        release_if_err(fn_decoder, lib);
-        fn_decoder_pic = (lib_cffmpeg_pic)dlsym(lib, "c_ffmpeg_get_pic_decoder");
-        release_if_err(fn_decoder_pic, lib);
-
-        fn_get_avpacket = (lib_cffmpeg_avpacket)dlsym(lib, "c_ffmpeg_get_avpacket");
-        release_if_err(fn_get_avpacket, lib);
-
-        fn_decode = (lib_cffmpeg_decode)dlsym(lib, "c_ffmpeg_decode");
-        release_if_err(fn_decode, lib);
-
-        fn_create_encoder = (lib_cffmpeg_create_encoder)dlsym(lib, "c_ffmpeg_create_encoder");
-        release_if_err(fn_create_encoder, lib);
-        fn_destroy_encoder = (lib_cffmpeg_destroy_encoder)dlsym(lib, "c_ffmpeg_destroy_encoder");
-        release_if_err(fn_destroy_encoder, lib);
-        fn_encode = (lib_cffmpeg_encode)dlsym(lib, "c_ffmpeg_encode");
-        release_if_err(fn_encode, lib);
-
-        fn_create_conv = (lib_cffmpeg_create_conv)dlsym(lib, "c_ffmpeg_create_conv");
-        release_if_err(fn_create_conv, lib);
-        fn_destroy_conv = (lib_cffmpeg_destroy_conv)dlsym(lib, "c_ffmpeg_destroy_conv");
-        release_if_err(fn_destroy_conv, lib);
-        fn_conv = (lib_cffmpeg_conv)dlsym(lib, "c_ffmpeg_conv");
-        release_if_err(fn_conv, lib);
-
-        fn_gpu_conv = (lib_gpu_conv)dlsym(lib, "c_gpu_conv");
-        release_if_err(fn_gpu_conv, lib);
 
     }else{
         printf("dlopen - %s\n", dlerror());  
@@ -82,77 +33,140 @@
     }
 }
 
-cffmpeg wrap_fn_create(){
+cffmpeg wrap_fn_create(void *lib){
+    if (!fn_create){
+        fn_create = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create");
+        release_if_err(fn_create, lib);
+    }
+
     return fn_create();
 }
 
-cffmpeg wrap_fn_create2(const char *logfile){
+cffmpeg wrap_fn_create2(void *lib, const char *logfile){
+    if (!fn_create2){
+        fn_create2 = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create2");
+        release_if_err(fn_create2, lib);
+    }
     return fn_create2(logfile);
 }
 
-void wrap_fn_destroy(const cffmpeg h){
+void wrap_fn_destroy(void *lib, const cffmpeg h){
     fn_destroy(h);
 }
 
-void wrap_fn_run(const cffmpeg h, const char* input){
+void wrap_fn_run(void *lib, const cffmpeg h, const char* input){
+    if (!fn_run){
+        fn_run = (lib_cffmpeg_run)dlsym(lib, "c_ffmpeg_run");
+        if (!fn_run) return;
+    }
+
     fn_run(h, input);
 }
 
-void wrap_fn_run_gb28181(const cffmpeg h){
+void wrap_fn_run_gb28181(void *lib, const cffmpeg h){
+    if (!fn_gb28181){
+        fn_gb28181 = (lib_cffmpeg_gb28181)dlsym(lib, "c_ffmpeg_run_gb28181");
+        if (!fn_gb28181) return;
+    }
     fn_gb28181(h);
 }
 
-void wrap_fn_use_cpu(const cffmpeg h){
+void wrap_fn_use_cpu(void *lib, const cffmpeg h){
+    if (!fn_cpu){
+        fn_cpu = (lib_cffmpeg_cpu)dlsym(lib, "c_ffmepg_use_cpu");
+        if (!fn_cpu) return;
+    }
     fn_cpu(h);
 }
 
-void wrap_fn_recorder(const cffmpeg h, const char* id, const char* dir, int mind, int maxd, int audio){
-    fn_recorder(h, id, dir, mind, maxd, audio);
+void wrap_fn_recorder(void *lib, const cffmpeg h, const char* id, const char* dir, const int64_t fid, int mind, int maxd, int audio){
+    if (!fn_recorder){
+        fn_recorder = (lib_cffmpeg_recorder)dlsym(lib, "c_ffmpeg_build_recorder");
+        if (!fn_recorder) return;
+    }
+    fn_recorder(h, id, dir, fid, mind, maxd, audio);
 }
 
-void wrap_fn_rec_duration(const cffmpeg h, const int min, const int max){
+void wrap_fn_rec_duration(void *lib, const cffmpeg h, const int min, const int max){
+    if (!fn_rec_duration){
+        fn_rec_duration = (lib_cffmpeg_rec_duration)dlsym(lib, "c_ffmpeg_set_record_duration");
+        if (!fn_rec_duration) return;
+    }
     fn_rec_duration(h, min, max);
 }
 
-void wrap_fn_fire_recorder(const cffmpeg h, const char* sid, const int64_t id){
+void wrap_fn_fire_recorder(void *lib, const cffmpeg h, const char* sid, const int64_t id){
+    if (!fn_fire_recorder){
+        fn_fire_recorder = (lib_cffmpeg_fire_recorder)dlsym(lib, "c_ffmpeg_fire_recorder");
+        if (!fn_fire_recorder) return;
+    }
     fn_fire_recorder(h, sid, id);
 }
 
-void wrap_fn_info_recorder(const cffmpeg h, int* index, char** recid, int* recidLen, char** fpath, int* pathLen){
+void wrap_fn_info_recorder(void *lib, const cffmpeg h, int* index, char** recid, int* recidLen, char** fpath, int* pathLen){
+    if (!fn_info_recorder){
+        fn_info_recorder = (lib_cffmpeg_info_recorder)dlsym(lib, "c_ffmpeg_get_info_recorder");
+        if (!fn_info_recorder) return;
+    }
     return fn_info_recorder(h, index, recid, recidLen, fpath, pathLen);
 }
 
-void wrap_fn_decoder(const cffmpeg h){
+void wrap_fn_decoder(void *lib, const cffmpeg h){
+    if (!fn_decoder){
+        fn_decoder = (lib_cffmpeg_decoder)dlsym(lib, "c_ffmpeg_build_decoder");
+        if (!fn_decoder) return;
+    }
     fn_decoder(h);
 }
 
-void* wrap_fn_decoder_pic(const cffmpeg h, int *wid, int *hei, int *format, int *length, int64_t *id){
+void* wrap_fn_decoder_pic(void *lib, const cffmpeg h, int *wid, int *hei, int *format, int *length, int64_t *id){
+    if (!fn_decoder_pic){
+        fn_decoder_pic = (lib_cffmpeg_pic)dlsym(lib, "c_ffmpeg_get_pic_decoder");
+        release_if_err(fn_decoder_pic, lib);
+    }
     return fn_decoder_pic(h, wid, hei, format, length, id);
 }
 
-void* wrap_fn_get_avpacket(const cffmpeg h, int* size, int* key){
+void* wrap_fn_get_avpacket(void *lib, const cffmpeg h, int* size, int* key){
+    if(!fn_get_avpacket){
+        fn_get_avpacket = (lib_cffmpeg_avpacket)dlsym(lib, "c_ffmpeg_get_avpacket");
+        release_if_err(fn_get_avpacket, lib);
+    }
     return fn_get_avpacket(h, size, key);
 }
 
 // return val: -1 open error; -2, find stream error; -3, converter create error
-void* wrap_fn_decode(const char* file, const int gb, int* wid, int* hei){
+void* wrap_fn_decode(void *lib, const char* file, const int gb, int* wid, int* hei){
+    if (!fn_decode){
+        fn_decode = (lib_cffmpeg_decode)dlsym(lib, "c_ffmpeg_decode");
+        release_if_err(fn_decode, lib);
+    }
     return fn_decode(file, gb, wid, hei);
 }
 
-void* wran_fn_gpu_conv(void *in, const int w, const int h, const int dst_w, const int dst_h, int *length){
-    return fn_gpu_conv(in, w, h, dst_w, dst_h, length);
-}
-
 // for encoder
-cencoder wrap_fn_create_encoder(const int w, const int h, const int fps, const int br, const int scale_flag, const int gi){
+cencoder wrap_fn_create_encoder(void *lib, const int w, const int h, const int fps, const int br, const int scale_flag, const int gi){
+    if (!fn_create_encoder){
+        fn_create_encoder = (lib_cffmpeg_create_encoder)dlsym(lib, "c_ffmpeg_create_encoder");
+        release_if_err(fn_create_encoder, lib);
+    }
     return fn_create_encoder(w, h, fps, br, scale_flag, gi);
 }
 
-void wrap_fn_destroy_encoder(const cencoder h){
+void wrap_fn_destroy_encoder(void *lib, const cencoder h){
+    if (!fn_destroy_encoder){
+        fn_destroy_encoder = (lib_cffmpeg_destroy_encoder)dlsym(lib, "c_ffmpeg_destroy_encoder");
+        if(!fn_destroy_encoder) return;
+    }
     fn_destroy_encoder(h);
 }
 
-void* wrap_fn_encode(cencoder hdl, void *in, const int w, const int h, int *out_size, int *key){
+void* wrap_fn_encode(void *lib, cencoder hdl, void *in, const int w, const int h, int *out_size, int *key){
+    if (!fn_encode){
+        fn_encode = (lib_cffmpeg_encode)dlsym(lib, "c_ffmpeg_encode");
+        release_if_err(fn_encode, lib);
+    }
+    
     uint8_t *out = NULL;
     const int flag = fn_encode(hdl, (uint8_t*)in, w, h, &out, out_size, key);
     if (flag > 0 && out != NULL) {
@@ -164,14 +178,28 @@
 }
 
 // for conv
-cconv wrap_fn_create_conv(const int srcW, const int srcH, const int srcFormat,
+cconv wrap_fn_create_conv(void *lib, const int srcW, const int srcH, const int srcFormat,
                           const int dstW, const int dstH, const int dstFormat, const int flag){
+    if (!fn_create_conv){
+        fn_create_conv = (lib_cffmpeg_create_conv)dlsym(lib, "c_ffmpeg_create_conv");
+        release_if_err(fn_create_conv, lib);
+    }
     return fn_create_conv(srcW, srcH, srcFormat, dstW, dstH, dstFormat, flag);
 }
 
-void wrap_fn_destroy_conv(const cconv h){
+void wrap_fn_destroy_conv(void *lib, const cconv h){
+    if (!fn_destroy_conv){
+        fn_destroy_conv = (lib_cffmpeg_destroy_conv)dlsym(lib, "c_ffmpeg_destroy_conv");
+        if(!fn_destroy_conv) return;
+    }
     fn_destroy_conv(h);
 }
-void* wrap_fn_conv(const cconv h, uint8_t *in){
+
+void* wrap_fn_conv(void *lib, const cconv h, uint8_t *in){
+    if (!fn_conv){
+        fn_conv = (lib_cffmpeg_conv)dlsym(lib, "c_ffmpeg_conv");
+        release_if_err(fn_conv, lib);
+    }
+
     return fn_conv(h, in);
 }

--
Gitblit v1.8.0