aboutsummaryrefslogtreecommitdiffstats
path: root/src/libunixonacid
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2026-03-16 01:53:36 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2026-03-16 01:53:36 +0000
commit6cf0cb6f31d8a4ee8d265ae6e51632ac9e826bf4 (patch)
treefc9178cd67a0fabfc838f732b41dd3f33311be02 /src/libunixonacid
parenta500a5e534b3c03c685f3397050afe6667b740f8 (diff)
downloadskalibs-6cf0cb6f31d8a4ee8d265ae6e51632ac9e826bf4.tar.gz
And use it in sassclient
Diffstat (limited to 'src/libunixonacid')
-rw-r--r--src/libunixonacid/sassclient_cancel.c16
-rw-r--r--src/libunixonacid/sassclient_sendv.c13
2 files changed, 6 insertions, 23 deletions
diff --git a/src/libunixonacid/sassclient_cancel.c b/src/libunixonacid/sassclient_cancel.c
index bc4273e..f56efd0 100644
--- a/src/libunixonacid/sassclient_cancel.c
+++ b/src/libunixonacid/sassclient_cancel.c
@@ -6,7 +6,7 @@
#include <pthread.h>
#include <skalibs/uint32.h>
-#include <skalibs/tai.h>
+#include <skalibs/pthread.h>
#include <skalibs/textclient.h>
#include <skalibs/gensetdyn.h>
#include <skalibs/sassclient.h>
@@ -14,18 +14,8 @@
int sassclient_cancel (sassclient *a, uint32_t id, tain const *deadline, tain *stamp)
{
- int e ;
-
- {
- struct timespec ts ;
- tain diff ;
- tain_sub(&diff, deadline, stamp) ;
- if (!timespec_from_tain_relative(&ts, &diff)) return 0 ;
- e = pthread_mutex_timedlock(&a->connection_mutex, &ts) ;
-// e = pthread_mutex_clocklock(&a->connection_mutex, CLOCK_MONOTONIC, &ts) ;
- if (e) return (errno = e, 0) ;
- }
-
+ int e = pthread_mutex_tailock(&a->connection_mutex, deadline, stamp) ;
+ if (e) return (errno = e, 0) ;
e = sassclient_cancel_internal(a, id, deadline, stamp) ;
if (e) goto err ;
gensetdyn_delete(&a->store, id) ;
diff --git a/src/libunixonacid/sassclient_sendv.c b/src/libunixonacid/sassclient_sendv.c
index 209462b..54d6a6e 100644
--- a/src/libunixonacid/sassclient_sendv.c
+++ b/src/libunixonacid/sassclient_sendv.c
@@ -10,6 +10,7 @@
#include <skalibs/uint32.h>
#include <skalibs/tai.h>
#include <skalibs/siovec.h>
+#include <skalibs/pthread.h>
#include <skalibs/gensetdyn.h>
#include <skalibs/textclient.h>
#include <skalibs/sassclient.h>
@@ -26,16 +27,8 @@ int sassclient_sendv (sassclient *a, uint32_t *cid, uint32_t flags, uint32_t tim
struct iovec v[1 + n] ;
if (len + 11 > UINT32_MAX) return (errno = ENAMETOOLONG, 0) ;
- {
- struct timespec ts ;
- tain diff ;
- tain_sub(&diff, deadline, stamp) ;
- if (!timespec_from_tain_relative(&ts, &diff)) return 0 ;
- e = pthread_mutex_timedlock(&a->connection_mutex, &ts) ;
-// e = pthread_mutex_clocklock(&a->connection_mutex, CLOCK_MONOTONIC, &ts) ;
- if (e) return (errno = e, 0) ;
- }
-
+ e = pthread_mutex_tailock(&a->connection_mutex, deadline, stamp) ;
+ if (e) return (errno = e, 0) ;
if (!gensetdyn_new(&a->store, &id)) goto err ;
v[0].iov_base = pack ;
v[0].iov_len = 17 ;