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?
528 Views Asked by Mark At
1
There are 1 best solutions below
Related Questions in C
- Passing arguments to main in C using Eclipse
- kernel module does not print packet info
- error C2016 (C requires that a struct or union has at least one member) and structs typedefs
- Drawing with ncurses, sockets and fork
- How to catch delay-import dll errors (missing dll or symbol) in MinGW(-w64)?
- Configured TTL for A record(s) backing CNAME records
- Allocating memory for pointers inside structures in functions
- Finding articulation point of undirected graph by DFS
- C first fgets() is being skipped while the second runs
- C std library don't appear to be linked in object file
- gcc static library compilation
- How to do a case-insensitive string comparison?
- C programming: Create and write 2D array of files as function
- How to read a file then store to array and then print?
- Function timeouts in C and thread
Related Questions in LINUX
- How do I recursively find and replace only in files named index.php on Linux webserver?
- passing text with \n as one argument in shell
- kernel module does not print packet info
- How to send ESC/POS commands to thermal printer in Linux
- (x64 Nasm) Writeline function on Linux
- How do I set the Hive user to something different than the Spark user from within a Spark program?
- Default priority of thread with SCHED_FIFO
- Calling a python function with options from shell script
- How to split a directory into parts without compressing or archiving?
- Cross compile simple standard C program on Linux for Mac
- How to offload NAPI poll function to workqueue
- python netifaces - How to get currently used network interface
- Unexpected output from function
- mingw-64 conflicting declarations when cross-compiling
- Different behavior of async with Visual Studio 2013(Windows8.1) and GCC 4.9(Ubuntu14.10)
Related Questions in LINUX-KERNEL
- kernel module does not print packet info
- android linux kernel communicate with user space about NETLINK_USER
- How to offload NAPI poll function to workqueue
- Why Device Tree Structure (DTS) file is needed both in bootloader and kernel source code?
- Bootloader in Assembly with Linux kernel
- pktgen not sending packets more than 1kb big
- Use static analysis tools to check null pointers and memory leaks in Linux device drivers
- How to build Linux kernel to support SO_ATTACH_BPF socket option?
- How do I know the last sched time of a process
- linux kernel compile error....udevd[63]: error getting socket
- Process in background mode trying to read from stdin
- board firmware update through uefi capsule feature from Linux
- spin_lock before writing status register
- Kernel module configuration locked built in?
- Install Subversion 1.7 on Debian jessie
Related Questions in INTERRUPT-HANDLING
- Fatal exception in interrupt zcu102 GPIO PL Interrupt Petalinux
- What request_irq() does internally?
- STM32F4 TIM6 interruption doesn't happen while DMA working
- how to generate the Performance monitoring interrupt after every overflow
- Setting up IDT in long mode
- Using WaitForSingleObject on Windows but supporting boost thread interrupts
- Arduino Interuppt and sleeping is freezing
- STM32F411: is clearing an external interrupt flag really necessary?
- IRQ 8 isn't working... HW or SW?
- When can one disable Interrupts in a driver
- getvect function is undefined
- Addressing Error in iretq
- Why are threads interrupted even when atexit or ConsoleHandler for SetConsoleCtrlhandler is executed?
- Is it possible the to lock the ISR instructions to L1 cache?
- Inter processor Interrrupts in ARM cortex A9 ( How To write an handler for Software generated Interrupt ( ARM) in Linux? )
Related Questions in SOFTIRQ
- softirq -- how far in network stack does it last?
- Why softirq is used for highly threaded and high frequency uses?
- amd radeon r9 series smp_affinity
- Linux FTRACE function_graph process context
- Is there a way to debug softirq?
- 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 it safe to call send_sig_info() inside URB completion routine?
- The reasons why rps procedure use spinlock with local_irq_disable
- ksoftirq is NOT using CPU and should be, why?
- The linux softirq cpu usage looks strange
- ksoftirqd behaviour on high network traffic
- How to define and trigger my own new softirq in linux kernel?
- How to stop/disable IPI(inter process interrupts) 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 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.