diff options
author | Mathias Krause <mathias.krause@secunet.com> | 2013-10-25 12:14:15 +0200 |
---|---|---|
committer | Herbert Xu <herbert@gondor.apana.org.au> | 2013-10-30 12:02:58 +0800 |
commit | 0b6b098efcddac2bf4e2a895c9b655560bbfcee4 (patch) | |
tree | 0facc6f31504a5be471d4592f99bce0b28f995e2 /drivers/firewire/core-device.c | |
parent | cfc6f11b768a9bdda17aac280474de1f0e344fea (diff) | |
download | lwn-0b6b098efcddac2bf4e2a895c9b655560bbfcee4.tar.gz lwn-0b6b098efcddac2bf4e2a895c9b655560bbfcee4.zip |
padata: make the sequence counter an atomic_t
Using a spinlock to atomically increase a counter sounds wrong -- we've
atomic_t for this!
Also move 'seq_nr' to a different cache line than 'lock' to reduce cache
line trashing. This has the nice side effect of decreasing the size of
struct parallel_data from 192 to 128 bytes for a x86-64 build, e.g.
occupying only two instead of three cache lines.
Those changes results in a 5% performance increase on an IPsec test run
using pcrypt.
Btw. the seq_lock spinlock was never explicitly initialized -- one more
reason to get rid of it.
Signed-off-by: Mathias Krause <mathias.krause@secunet.com>
Acked-by: Steffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'drivers/firewire/core-device.c')
0 files changed, 0 insertions, 0 deletions