Browse Source

Test

etomic
jl777 7 years ago
parent
commit
034441ba4c
  1. 9
      iguana/exchanges/LP_socket.c

9
iguana/exchanges/LP_socket.c

@ -241,7 +241,7 @@ int32_t LP_socketrecv(int32_t sock,uint8_t *recvbuf,int32_t maxlen)
struct electrum_info struct electrum_info
{ {
queue_t sendQ,pendingQ; queue_t sendQ,pendingQ;
portable_mutex_t mutex; portable_mutex_t mutex,txmutex;
struct electrum_info *prev; struct electrum_info *prev;
int32_t bufsize,sock,*heightp; int32_t bufsize,sock,*heightp;
struct iguana_info *coin; struct iguana_info *coin;
@ -378,10 +378,12 @@ cJSON *electrum_submit(char *symbol,struct electrum_info *ep,cJSON **retjsonp,ch
sitem->expiration = timeout; sitem->expiration = timeout;
sitem->DL.type = ep->stratumid++; sitem->DL.type = ep->stratumid++;
sitem->retptrp = (void **)retjsonp; sitem->retptrp = (void **)retjsonp;
portable_mutex_lock(&ep->mutex);
queue_enqueue("sendQ",&ep->sendQ,&sitem->DL); queue_enqueue("sendQ",&ep->sendQ,&sitem->DL);
expiration = (uint32_t)time(NULL) + timeout + 1; expiration = (uint32_t)time(NULL) + timeout + 1;
while ( *retjsonp == 0 && time(NULL) <= expiration ) while ( *retjsonp == 0 && time(NULL) <= expiration )
usleep(10000); usleep(10000);
portable_mutex_unlock(&ep->mutex);
if ( ep->prev == 0 ) if ( ep->prev == 0 )
{ {
if ( *retjsonp == 0 ) if ( *retjsonp == 0 )
@ -663,10 +665,10 @@ cJSON *electrum_transaction(char *symbol,struct electrum_info *ep,cJSON **retjso
{ {
cJSON *retjson; cJSON *retjson;
if ( ep != 0 ) if ( ep != 0 )
portable_mutex_lock(&ep->mutex); portable_mutex_lock(&ep->txmutex);
retjson = _electrum_transaction(symbol,ep,retjsonp,txid); retjson = _electrum_transaction(symbol,ep,retjsonp,txid);
if ( ep != 0 ) if ( ep != 0 )
portable_mutex_unlock(&ep->mutex); portable_mutex_unlock(&ep->txmutex);
return(retjson); return(retjson);
} }
@ -771,6 +773,7 @@ struct electrum_info *LP_electrum_info(int32_t *alreadyp,char *symbol,char *ipad
} }
ep = calloc(1,sizeof(*ep) + bufsize); ep = calloc(1,sizeof(*ep) + bufsize);
portable_mutex_init(&ep->mutex); portable_mutex_init(&ep->mutex);
portable_mutex_init(&ep->txmutex);
ep->sock = sock; ep->sock = sock;
safecopy(ep->symbol,symbol,sizeof(ep->symbol)); safecopy(ep->symbol,symbol,sizeof(ep->symbol));
safecopy(ep->ipaddr,ipaddr,sizeof(ep->ipaddr)); safecopy(ep->ipaddr,ipaddr,sizeof(ep->ipaddr));

Loading…
Cancel
Save