X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=mISDN.cpp;h=035b78bd33bded6582fc7fa4b6b2a468b318878b;hp=3e7751eae14aeabde5acb89a338eb77cc6503354;hb=76c5d82d4cbdd9d75e6b6db9e51eb22d10fb44bd;hpb=fa7af7ab195346b11a0bb401050d7c06f4a3ffaa diff --git a/mISDN.cpp b/mISDN.cpp index 3e7751e..035b78b 100644 --- a/mISDN.cpp +++ b/mISDN.cpp @@ -1834,8 +1834,11 @@ static int mISDN_upqueue(struct lcr_fd *fd, unsigned int what, void *instance, i char byte; /* unset global semaphore */ - read(fd->fd, &byte, 1); upqueue_avail = 0; + // with a very small incident, upqueue_avail may be set by mISDN thread and + // another byte may be sent to the pipe, which causes a call to this function + // again with nothing in the upqueue. this is no problem. + read(fd->fd, &byte, 1); /* process all ports */ mISDNport = mISDNport_first; @@ -2060,6 +2063,9 @@ int do_layer3(struct mlayer3 *ml3, unsigned int cmd, unsigned int pid, struct l3 l3m->pid = pid; mqueue_tail(&mISDNport->upqueue, mb); if (!upqueue_avail) { + // multiple threads may cause multiple calls of this section, but this + // results only in multiple processing of the upqueue read. + // this is no problem. upqueue_avail = 1; char byte = 0; write(upqueue_pipe[1], &byte, 1);