diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-03 16:55:12 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-03 16:55:12 -0400 |
| commit | df5a2a1fbca44bebeebb78530ac93c734f289707 (patch) | |
| tree | 6a2522fee4c7e736e5d00a7ec1a978baab5ec145 /include/linux | |
| parent | 9b2e077c42a97fcbdc0dd71edb1fc9d15c74ad29 (diff) | |
| parent | 4d50c44381c981c9caa74e82ab894d4938dac9ca (diff) | |
Merge tag 'firewire-updates' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394
Pull firewire updates from Stefan Richter:
- feed GUIDs of FireWire nodes to the random pool
- more complete quirk handling of a TI S400B phy
- avoid holding a core lock while calling into highlevel drivers
* tag 'firewire-updates' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394:
firewire: addendum to address handler RCU conversion
firewire: remove global lock around address handlers, convert to RCU
firewire: ohci: get IR bit from TSB41BA3D phy
firewire: core: feed /dev/random with devices' GUIDs
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/firewire.h | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/include/linux/firewire.h b/include/linux/firewire.h index db04ec5121cb..191501afd7fb 100644 --- a/include/linux/firewire.h +++ b/include/linux/firewire.h | |||
| @@ -265,8 +265,16 @@ typedef void (*fw_transaction_callback_t)(struct fw_card *card, int rcode, | |||
| 265 | void *data, size_t length, | 265 | void *data, size_t length, |
| 266 | void *callback_data); | 266 | void *callback_data); |
| 267 | /* | 267 | /* |
| 268 | * Important note: Except for the FCP registers, the callback must guarantee | 268 | * This callback handles an inbound request subaction. It is called in |
| 269 | * that either fw_send_response() or kfree() is called on the @request. | 269 | * RCU read-side context, therefore must not sleep. |
| 270 | * | ||
| 271 | * The callback should not initiate outbound request subactions directly. | ||
| 272 | * Otherwise there is a danger of recursion of inbound and outbound | ||
| 273 | * transactions from and to the local node. | ||
| 274 | * | ||
| 275 | * The callback is responsible that either fw_send_response() or kfree() | ||
| 276 | * is called on the @request, except for FCP registers for which the core | ||
| 277 | * takes care of that. | ||
| 270 | */ | 278 | */ |
| 271 | typedef void (*fw_address_callback_t)(struct fw_card *card, | 279 | typedef void (*fw_address_callback_t)(struct fw_card *card, |
| 272 | struct fw_request *request, | 280 | struct fw_request *request, |
