diff options
author | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-07-12 14:50:06 +0200 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-07-14 13:06:04 +0200 |
commit | e9aeb46c93a8b1b703d00586c05d9a71aa7e0f0c (patch) | |
tree | 8e20402235bdcdf0e250e90ba02ac9f5eae2b87c /drivers/block/sx8.c | |
parent | 792a61021c6043f6c2b24b1cdd42be5753b3e54c (diff) | |
download | op-kernel-dev-e9aeb46c93a8b1b703d00586c05d9a71aa7e0f0c.zip op-kernel-dev-e9aeb46c93a8b1b703d00586c05d9a71aa7e0f0c.tar.gz |
firewire: fully initialize fw_transaction before marking it pending
In theory, card->flush_timer could already access a transaction between
fw_send_request()'s spin_unlock_irqrestore and the rest of what happens
in fw_send_request(). This would happen if the process which sends the
request is preempted and put to sleep right after spin_unlock_irqrestore
for longer than 100ms.
Therefore we fill in everything in struct fw_transaction at which the
flush_timer might look at before we lift the lock.
To do: Ensure that the timer does not pick up the transaction before
the time of the AT request event plus split transaction timeout.
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers/block/sx8.c')
0 files changed, 0 insertions, 0 deletions