diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2010-04-12 10:35:30 +0200 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2010-04-19 19:58:32 +0200 |
commit | 2608203daf5f87311c6e5d36e5de5efcb14aab24 (patch) | |
tree | f0060813795c68ab988a998c4cced16d67139ded /drivers/firewire/ohci.c | |
parent | d6372b6e7c6142e6cc2108b3b850584cd7ade106 (diff) | |
download | op-kernel-dev-2608203daf5f87311c6e5d36e5de5efcb14aab24.zip op-kernel-dev-2608203daf5f87311c6e5d36e5de5efcb14aab24.tar.gz |
firewire: ohci: prevent aliasing of locally handled register addresses
We must compute the offset from the CSR register base with the
full 48 address bits to prevent matching with addresses whose
lower 32 bits happen to be equal with one of the specially
handled registers.
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers/firewire/ohci.c')
-rw-r--r-- | drivers/firewire/ohci.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/firewire/ohci.c b/drivers/firewire/ohci.c index e33917b..82fb2e7 100644 --- a/drivers/firewire/ohci.c +++ b/drivers/firewire/ohci.c @@ -1198,8 +1198,7 @@ static void handle_local_lock(struct fw_ohci *ohci, static void handle_local_request(struct context *ctx, struct fw_packet *packet) { - u64 offset; - u32 csr; + u64 offset, csr; if (ctx == &ctx->ohci->at_request_ctx) { packet->ack = ACK_PENDING; |