I've been studying about interrupts in Linux and softirq in particular (I'm interested in networking subsystem of the kernel). I understand the concept of top-half and bottom-half, but what's not clear to me is -- how far does the softirq context last? Until what point in the kernel stack we deal with softirq? For example, when the ingress path hits ip_rcv(), are we still in soft interrupt mode?
softirq -- how far in network stack does it last?
529 Views Asked by Mark 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 INTERRUPT-HANDLING
- How to write strictly conforming interrupt service routines (on AVR)
- Is it legal to use `volatile uint8_t` instead of `volatile sig_atomic_t`?
- Why does memory-barrier prohibit optimization on static global variable?
- Timer interrupt using ESP32 IDF
- ATTiny 1626 pullup input does not trigger falling edge ISR, is there something wrong with my setup?
- Optimization, global variables and memory-barriers
- what is the 1 of N model implementation for GIC600
- Sleeping or blocking in interrupt handler
- XINU OS - How can I count number of interrupts handlers that occured?
- How to exit waitPress() fuction of the Keypad library?
- Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in…”
- Clearing interrupt necessary inside an ISR? (for Atmega644p uC)
- Implementing ISR in C++ for AVR Mega
- General memory-barrier versus special volatile access (on AVR)
- What is the machinery behind stack unwinding?
Related Questions in SOFTIRQ
- Linux FTRACE function_graph process context
- Sending netlink_multicast message from softirq context like netfilter hooks
- Linux softirq and SMP
- Reducing Timer Softirq and local interrupts
- Stack overflow if softirq preempt by hardware interrupt many times
- Containers: high cpu usage in %soft (soft IRQ) for network-intensive workloads
- Failed to trace the trace point of softirq_raise in Linux-5.11.4
- Is there a way to debug softirq?
- RISC-V - Software Interrupts
- hardirq and softirq run on the same core/processor?
- softirq -- how far in network stack does it last?
- The reasons why rps procedure use spinlock with local_irq_disable
- Is it safe to call send_sig_info() inside URB completion routine?
- Pausing a kthread in Linux
- Why is time servicing softirqs increased on kernel 4.1 in compare with kernel 3.4?
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?
Rudely speaking, softirq context lasts until the softirq-handler returns.
Yep, we are in softirq context. We're inside call-stack of function, that was raised as
NET_RX_SOFTIRQ.Let's talk about receive path considering NAPI.
____napi_schedule()raisesNET_RX_SOFTIRQ(it in turn modifies per-CPU data structure by accessingirq_stat.__softirq_pending). Then the softirq handler moves packet up to the stack. All these actions are in softirq context. So here are two different directions: 1) this is forward packet - so the softirq context lasts until this packet will be added to some output queue and the handler will return. 2) this is local input packet - so the softirq lasts until this packet will be added (enqueued) to local socket receive queue, after which the handler returns. Such things are in case of dropping anywhere in the network stack. It all terminates when the basic softirq-function/handler terminates.