Module: kamailio
Branch: master
Commit: 8a1c383f6af5bc0547e32430a4469333160b93e6
URL: 
https://github.com/kamailio/kamailio/commit/8a1c383f6af5bc0547e32430a4469333160b93e6

Author: S-P Chan <shihping.c...@gmail.com>
Committer: S-P Chan <shihping.c...@gmail.com>
Date: 2024-01-31T16:47:09+08:00

db_postgres: use core/rthreads.h

---

Modified: src/modules/db_postgres/km_dbase.c

---

Diff:  
https://github.com/kamailio/kamailio/commit/8a1c383f6af5bc0547e32430a4469333160b93e6.diff
Patch: 
https://github.com/kamailio/kamailio/commit/8a1c383f6af5bc0547e32430a4469333160b93e6.patch

---

diff --git a/src/modules/db_postgres/km_dbase.c 
b/src/modules/db_postgres/km_dbase.c
index 065b71f0709..3d58f1a53e0 100644
--- a/src/modules/db_postgres/km_dbase.c
+++ b/src/modules/db_postgres/km_dbase.c
@@ -34,7 +34,6 @@
 #include <string.h>
 #include <stdio.h>
 #include <stdlib.h>
-#include <pthread.h>
 #include "../../core/dprint.h"
 #include "../../core/mem/mem.h"
 #include "../../lib/srdb1/db.h"
@@ -44,6 +43,8 @@
 #include "../../core/locking.h"
 #include "../../core/hashes.h"
 #include "../../core/clist.h"
+#define KSR_RTHREAD_NEED_PI
+#include "../../core/rthreads.h"
 #include "km_dbase.h"
 #include "km_pg_con.h"
 #include "km_val.h"
@@ -119,14 +120,7 @@ static db1_con_t *db_postgres_init0(const str *_url)
 
 db1_con_t *db_postgres_init(const str *_url)
 {
-       pthread_t tid;
-       db1_con_t *ret;
-
-       pthread_create(
-                       &tid, NULL, (void *(*)(void *))db_postgres_init0, (void 
*)_url);
-       pthread_join(tid, (void **)&ret);
-
-       return ret;
+       return run_threadP((_thread_proto)db_postgres_init0, (void *)_url);
 }
 /*!
  * \brief Initialize database for future queries, specify pooling
@@ -137,28 +131,15 @@ db1_con_t *db_postgres_init(const str *_url)
  *
  * Init libssl in thread
  */
-struct _thread_args
-{
-       const str *_url;
-       db_pooling_t pooling;
-};
-
-static db1_con_t *_db_postgres_init2(struct _thread_args *args)
+static db1_con_t *db_postgres_init2_impl(const str *_url, db_pooling_t pooling)
 {
-       return db_do_init2(
-                       args->_url, (void *)db_postgres_new_connection, 
args->pooling);
+       return db_do_init2(_url, (void *)db_postgres_new_connection, pooling);
 }
 
 db1_con_t *db_postgres_init2(const str *_url, db_pooling_t pooling)
 {
-       pthread_t tid;
-       db1_con_t *ret;
-
-       pthread_create(&tid, NULL, (void *(*)(void *))_db_postgres_init2,
-                       (void *)&(struct _thread_args){_url, pooling});
-       pthread_join(tid, (void **)&ret);
-
-       return ret;
+       return run_threadPI(
+                       (_thread_protoPI)db_postgres_init2_impl, (void *)_url, 
pooling);
 }
 /*!
  * \brief Close database when the database is no longer needed

_______________________________________________
Kamailio (SER) - Development Mailing List
To unsubscribe send an email to sr-dev-le...@lists.kamailio.org

Reply via email to