diff options
author | Sander Vrijders <[email protected]> | 2018-10-11 14:09:37 +0200 |
---|---|---|
committer | Dimitri Staessens <[email protected]> | 2018-10-11 14:54:21 +0200 |
commit | a1b6cebe14d6e0689655a0c4d06064728cbf1f21 (patch) | |
tree | 38d8533f59a064b492e89e9b0c090eed802dd09a /src/ipcpd | |
parent | 9b8d2830250ecffb298f6c72196cffb94991f4d1 (diff) | |
download | ouroboros-a1b6cebe14d6e0689655a0c4d06064728cbf1f21.tar.gz ouroboros-a1b6cebe14d6e0689655a0c4d06064728cbf1f21.zip |
ipcpd: Take correct lock when updating stats
The lock of the wrong fd was taken when updating the stats in the DT
component.
Signed-off-by: Sander Vrijders <[email protected]>
Signed-off-by: Dimitri Staessens <[email protected]>
Diffstat (limited to 'src/ipcpd')
-rw-r--r-- | src/ipcpd/normal/dt.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/ipcpd/normal/dt.c b/src/ipcpd/normal/dt.c index dc7343f1..54346458 100644 --- a/src/ipcpd/normal/dt.c +++ b/src/ipcpd/normal/dt.c @@ -532,12 +532,14 @@ static void packet_handler(int fd, if (ipcp_flow_write(dt_pci.eid, sdb)) { ipcp_sdb_release(sdb); #ifdef IPCP_FLOW_STATS - pthread_mutex_lock(&dt.stat[dt_pci.eid].lock); + pthread_mutex_lock(&dt.stat[fd].lock); ++dt.stat[fd].rcv_pkt[qc]; dt.stat[fd].rcv_bytes[qc] += len; + pthread_mutex_unlock(&dt.stat[fd].lock); + + pthread_mutex_lock(&dt.stat[dt_pci.eid].lock); ++dt.stat[dt_pci.eid].w_drp_pkt[qc]; dt.stat[dt_pci.eid].w_drp_bytes[qc] += len; - pthread_mutex_unlock(&dt.stat[dt_pci.eid].lock); #endif |