lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Message-Id: <200710072226.EJF51558.LFVHJOStFOOFMQ@I-love.SAKURA.ne.jp> Date: Sun, 7 Oct 2007 22:26:23 +0900 From: Tetsuo Handa <penguin-kernel@...ove.SAKURA.ne.jp> To: junwang1234@...il.com, a.p.zijlstra@...llo.nl Cc: linux-kernel@...r.kernel.org, linux-security-module@...r.kernel.org Subject: Re: Sleeping in RCU list traversal Hello. Thank you for pointing out. Jun WANG wrote: > >rcu_read_lock(); > >list_for_each_rcu(p, ...) { > > ptr = list_entry(p, struct ..., list); > > /* Grab a reference to "ptr". */ > > rcu_read_unlock(); > > my_task_that_may_sleep(ptr); > > rcu_read_lock(); > > /* Drop a reference to "ptr". */ > > } > > rcu_read_unlock(); > > In Document/RCU/whatisRCU.txt > Note that the value returned by rcu_dereference() is valid > only within the enclosing RCU read-side critical section. Excuse me, but I think "p" is used only between rcu_read_lock() and rcu_read_unlock(). Is it illegal to use "ptr" after rcu_read_unlock() if "ptr" is obtained before rcu_read_unlock() ? Regards. - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists