summaryrefslogtreecommitdiffstats
path: root/crypto
diff options
context:
space:
mode:
authorHariprasad Shenai <hariprasad@chelsio.com>2016-06-22 09:39:29 +0530
committerDavid S. Miller <davem@davemloft.net>2016-06-25 12:04:33 -0400
commitb38066daaa81fd2f9ca2c9f103d4d56aad8906ee (patch)
tree3b37f96c770534a156dc57fc8027cf1cda1c2cb3 /crypto
parenteb88d58559b756065667f97ef5891b5c23c57c76 (diff)
downloadlinux-b38066daaa81fd2f9ca2c9f103d4d56aad8906ee.tar.bz2
cxgb4vf: Synchronize access to mailbox
The issue comes when there are multiple threads attempting to use the mailbox facility at the same time. The issue is the for the Virtual Function Driver, the only way to get the Virtual Interface statistics is to issue mailbox commands to ask the firmware for the VI Stats. And, because the VI Stats command can only retrieve a smallish number of stats per mailbox command, we have to issue three mailbox commands in quick succession. When ethtool or netstat command to get interface stats and interface up/down is run in a loop for every 0.1 sec, we observed mailbox collisions. And out of the two commands one would fail with the present code, since we don't queue the second command. To overcome the above issue, added a queue to access the mailbox. Whenever a mailbox command is issued add it to the queue. If its at the head issue the mailbox command, else wait for the existing command to complete. Usually command takes less than a milli-second to complete. Also timeout from the loop, if the command under execution takes long time to run. In reality, the number of mailbox access collisions is going to be very rare since no one runs such abusive script. Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'crypto')
0 files changed, 0 insertions, 0 deletions