[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <48EC70BB.9010709@cosmosbay.com>
Date: Wed, 08 Oct 2008 10:35:07 +0200
From: Eric Dumazet <dada1@...mosbay.com>
To: David Miller <davem@...emloft.net>
Cc: minyard@....org, linux-kernel@...r.kernel.org,
netdev@...r.kernel.org, shemminger@...tta.com,
paulmck@...ux.vnet.ibm.com
Subject: Re: [PATCH 3/3] Convert the UDP hash lock to RCU
David Miller a écrit :
> From: Eric Dumazet <dada1@...mosbay.com>
> Date: Tue, 07 Oct 2008 07:24:45 +0200
>
>> Most UDP sockets are setup for long periods (RTP trafic), or if an application really
>> wants to {open/send or receive one UDP frame/close} many sockets, it already hits
>> RCU handling of its file structures and should not be slowed down that much.
>
> As stated, I added RCU destruction generically for socket objects, and it
> showed up clearly.
>
> So "not be slowed down that much" has been disproven, at least to me,
> already :-)
>
>
RCU in hash table is ok for managing read mostly data, since
only during the read access you avoid to dirty a rwlock...
If we have a workload that insert/delete sockets as hell but
receive few frames (that hit the hash table in a read only way),
then you defeat the purpose of RCU, and pay the price of
throwing away (in rcu queue) hot data that will become cold
before reuse...
BTW is there any chance your results were obtained before October 2005 ?
At that time, RCU was able to queue an unlimited number of events.
a single loop doing close(open("/dev/null",0)) could exhaust RAM...
Refs: commit 5ee832dbc6770135ec8d63296af0a4374557bb79
and many others...
Anyway we can probably code something without call_rcu() cache blower
for UDP, if time permits :)
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists