RDMA/ocrdma: Help gcc generate better code for ocrdma_srq_toggle_bit
authorRasmus Villemoes <linux@rasmusvillemoes.dk>
Fri, 16 Jan 2015 14:39:55 +0000 (15:39 +0100)
committerRoland Dreier <roland@purestorage.com>
Wed, 18 Feb 2015 16:31:05 +0000 (08:31 -0800)
commitba64fdca63af5a1bdda8e33d9cc8496089631dde
tree1accd20f3b25c252a04949b693e321aa3cdcfd56
parent0ba5dc5cba6d033c47637927e557ad6a7907bec7
RDMA/ocrdma: Help gcc generate better code for ocrdma_srq_toggle_bit

gcc emits a surprising amount of code in order to flip a bit. One
would think that a single instruction is enough.

$ scripts/bloat-o-meter /tmp/ocrdma_verbs.o drivers/infiniband/hw/ocrdma/ocrdma_verbs.o
add/remove: 0/0 grow/shrink: 0/3 up/down: 0/-142 (-142)
function                                     old     new   delta
ocrdma_post_srq_recv                         498     460     -38
ocrdma_poll_cq                              2010    1962     -48
ocrdma_discard_cqes                          495     439     -56

All three calls of ocrdma_srq_toggle_bit happen within spinlocks, so
saving a few useless instructions might be worthwhile.

Signed-off-by: Rasmus Villemoes <linux@rasmusvillemoes.dk>
Acked-by: Selvin Xavier <selvin.xavier@emulex.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/hw/ocrdma/ocrdma_verbs.c