On Fri, 21 Dec 2007 01:55:43 -0800 (PST) David Miller <[EMAIL PROTECTED]> wrote:
> From: Eric Dumazet <[EMAIL PROTECTED]> > Date: Fri, 21 Dec 2007 07:18:40 +0100 > > > Because sk_wmem_queued, sk_sndbuf are signed, a divide per two > > forces compiler to use an integer divide. We can instead use > > a right shift. > > > > SK_STREAM_MEM_QUANTUM deserves to be declared as an unsigned > > quantity, so that sk_stream_pages() and __sk_stream_mem_reclaim() > > can use right shifts instead of integer divides. > > > > Signed-off-by: Eric Dumazet <[EMAIL PROTECTED]> > > Everything that works with SK_STREAM_MEM_QUANTUM is an int. > > We do a DIV_ROUND_UP() using SK_STREAM_MEM_QUANTUM and an int. > > We do sk->sk_forward_alloc modifications using multiplies on > SK_STREAM_MEM_QUANTUM and an int, sk_forward_alloc is an int > too. > > Changing the type of SK_STREAM_MEM_QUANTUM does nothing more than > create an exception in the typing used in these operations for no real > gain, in fact it makes this code's correctness harder to verify. > > I'm fine with the rest of your change, so please resubmit this patch > with the type change removed. I cannot remove underlying divide without telling compiler *something* is unsigned, or adding a new _SHIFT macro We currently do int_value / int_constant I was suggesting int_value / uint_constant Since you prefer to keep sk_forward_alloc as signed, the only clean (without casts) way is to do : int_value >> SK_STREAM_MEM_QUANTUM_SHIFT Please tell me if you are OK with this solution, or if you prefer I change sk_forward_alloc to be unsigned :) Thank you Here is the patch handling the change on sk_wmem_queued, sk_sndbuf. Keeping small patches may help future bisection anyway... [SOCK] Avoid integer divides where not necessary in include/net/sock.h Because sk_wmem_queued, sk_sndbuf are signed, a divide per two may force compiler to use an integer divide. We can instead use a right shift. Signed-off-by: Eric Dumazet <[EMAIL PROTECTED]> diff --git a/include/net/sock.h b/include/net/sock.h index 803d8f2..4456453 100644 --- a/include/net/sock.h +++ b/include/net/sock.h @@ -445,7 +445,7 @@ static inline int sk_acceptq_is_full(struct sock *sk) */ static inline int sk_stream_min_wspace(struct sock *sk) { - return sk->sk_wmem_queued / 2; + return sk->sk_wmem_queued >> 1; } static inline int sk_stream_wspace(struct sock *sk) @@ -1187,7 +1187,7 @@ static inline void sk_wake_async(struct sock *sk, int how, int band) static inline void sk_stream_moderate_sndbuf(struct sock *sk) { if (!(sk->sk_userlocks & SOCK_SNDBUF_LOCK)) { - sk->sk_sndbuf = min(sk->sk_sndbuf, sk->sk_wmem_queued / 2); + sk->sk_sndbuf = min(sk->sk_sndbuf, sk->sk_wmem_queued >> 1); sk->sk_sndbuf = max(sk->sk_sndbuf, SOCK_MIN_SNDBUF); } } @@ -1211,7 +1211,7 @@ static inline struct page *sk_stream_alloc_page(struct sock *sk) */ static inline int sock_writeable(const struct sock *sk) { - return atomic_read(&sk->sk_wmem_alloc) < (sk->sk_sndbuf / 2); + return atomic_read(&sk->sk_wmem_alloc) < (sk->sk_sndbuf >> 1); } static inline gfp_t gfp_any(void) -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html