As per the RCU documentation (I believe kernel and userspace RCU frameworks are similar), synchronize_rcu() waits for all the readers (who started before synchronize_rcu was called ) to finish.
What happens to the readers which are started after synchronize_rcu() is waiting in its grace period?
What is the difference between the readers started after synchronize_rcu() returns, and readers started while synchronize_rcu() waits? How RCU framework handles this?
How RCU handles the condition of a reader started reading critical section while synchronize_rcu() is waiting
637 Views Asked by Franc At
1
There are 1 best solutions below
Related Questions in C
- How to call a C language function from x86 assembly code?
- What does: "char *argv[]" mean?
- User input sanitization program, which takes a specific amount of arguments and passes the execution to a bash script
- How to crop a BMP image in half using C
- How can I get the difference in minutes between two dates and hours?
- Why will this code compile although it defines two variables with the same name?
- Compiling eBPF program in Docker fails due to missing '__u64' type
- Why can't I use the file pointer after the first read attempt fails?
- #include Header files in C with definition too
- OpenCV2 on CLion
- What is causing the store latency in this program?
- How to refer to the filepath of test data in test sourcecode?
- 9 Digit Addresses in Hexadecimal System in MacOS
- My server TCP doesn't receive messages from the client in C
- Printing the characters obtained from the array s using printf?
Related Questions in LINUX
- Is there some way to use printf to print a horizontal list of decrementing hex digits in NASM assembly on Linux
- Why does Hugo generate different taxonomy-related HTML on different OS's?
- Writes in io_uring do not advance the file offset
- Why `set -o pipefail` gives different output even though the pipe is not failing
- what really controls the permissions: UID or eUID?
- Compiling eBPF program in Docker fails due to missing '__u64' type
- Docker container unable to make HTTPS requests to external API
- Whow to use callback_query_handler in Python 3.10
- Create kea runtime directory at startup in Yocto image
- Problem on CPU scheduling algorithms in OS
- How to copy files into the singularity sandbox?
- Android kernel error: undefined reference to `get_hw_version_platform'
- Is there a need for BPF Linux namespace?
- Error when trying to execute a binary compiled in a Kali Linux machine on an Ubuntu system
- Issue with launching application after updating ElectronJs to version 28.0.0 on Windows and Linux
Related Questions in LINUX-KERNEL
- Android kernel error: undefined reference to `get_hw_version_platform'
- Is there a need for BPF Linux namespace?
- Facing fatal errors while running "yum update" command on CentOS 7/Cloudlinux 7
- crash utility itself crashes while decoding kdump generated from null pointer dereference in kernel module
- How to compile the Linux kernel with -O0 for more detailed debug?
- Linux support for parallel Pixel data Image sensor
- Can't upgrade to newest version of linux-image-6.5.0-26-generic
- How to protect a page so that it cannot be write in mips arch?
- How to extract the .img file into normal kernel source file in the linux?
- Storage size of struct hash_desc desc; isn't known
- How can I intercept failed file openning calls?
- struct nameidata-Linux Kernel Module
- How to modify a 'struct msghdr' in Linux Kernel Module?
- How to allocate 500MB+ physically contiguous memory in a Linux kernel module and copy data to that memory from a userspace process?
- Hyper Threading: nosmt in grub configuration
Related Questions in LOCKING
- The problem of "fine-grained locks and two-phase locking algorithm"
- Two Update statements on a row are running simultaneously with no locking in MYSQL
- When does shared and exclusive locks are acquired and released in a MySql transactions?
- SQL Server opportunistic locking
- Choosing the right hints during select for update in SQL Server
- Locking PDF after filling out text field
- Using dask.distributed with rioxarray rio.to_raster results in `ValueError: Lock is not yet acquired`
- Oracle 19c. REF Partitioning. Start redefinition Holds TM lock on parent table in 4 mode (when insert data into interim table)
- How to avoid LFS lock conflicts after merging master into feature branch?
- Maatwebsite excel global transaction problems
- How to implement read and write locking for a MongoDB collection?
- How to synchronize a python dictionary across a flask app and a background thread
- SQL Server SELECT WITH (NOLOCK) causing exclusive lock in tempdb
- Lock Acquisition Order in MYSQL
- Why is this giving me an IllegalMonitorStateException when all I'm doing is locking and then awaiting a condition?
Related Questions in RCU
- How is rebalance_domains() synchronized below NUMA level?
- In the implemention of urcu-qsbr, is there any mechanism to ensure the thread offline/online is visible to writer-thread?
- How can we be sure that all call_rcu() callbacks are invoked/completed in Linux kernel?
- Does using list_for_each_entry() in rcu reader side critical section cause problems?
- How to disable CONFIG_PREEMPT_RCU in 5.14 kernel
- Return a pointer from RCU-protected list in LKM
- The Linux(CentOS 7.9) kernel has prompted a bug. Is it harmful?
- rcu_sched kthread timer wakeup didn't happen for x jiffies Allwinner sun8i
- Is it possible to create new RCU schemas for an existing Domain?
- Why RCU is designed to protect pointer assignment?
- Race conditions due to speculative reordering / Linux RCU facility
- Why Linux kernel never implemented a per data object RCU mechanism?
- 'c:\Program' is not recognized as an internal or external command, operable command or batch file
- Get a list of all rcus available in Oracle 12c?
- Can we link a new RCU with an old weblogic Domain
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
All the readers entering the critical section after
rcu_assign_pointer()read the new data structure.All you are talking about depends on if/when the new pointer is assigned. Assigning and reading are related things.
synchronize_rcu()on Linux generally waits until all CPUs will have their context switched - it guarantees that no one who saw the old pointer doesn't use it anymore (context switch happens after reader exits their critical section) - so we can free this memory. From this post:New readers know nothing about old data structure. "Swapping" of pointers is atomic.
One more time:
synchronize_rcu()has no effect on readers - it just guarantees that after it returns, we can free the memory the pointer points to (kfree()).It seems you have not explored the basics of Linux RCU.
Must read: