c65cda1836
Establish Netlink socket connection in a nonblocking mode and callback notification. Tolerate a few times on failures from receiving events. In practice, such delivery failure is rare. But it may indicate more fundamental issues if it repeats. So disconnect it unless the failure is transient. Event-specific handler will be implemented in the next patch. Signed-off-by: Chang S. Bae <chang.seok.bae@intel.com> |
||
---|---|---|
misc | ||
tests | ||
ui | ||
.gitignore | ||
.travis.yml | ||
AUTHORS | ||
COPYING | ||
Makefile.am | ||
README.md | ||
activate.c | ||
autogen.sh | ||
bitmap.c | ||
bitmap.h | ||
classify.c | ||
configure.ac | ||
constants.h | ||
cpumask.h | ||
cputree.c | ||
irqbalance-ui.1 | ||
irqbalance.1 | ||
irqbalance.c | ||
irqbalance.h | ||
irqlist.c | ||
non-atomic.h | ||
numa.c | ||
placement.c | ||
procinterrupts.c | ||
thermal.c | ||
thermal.h | ||
types.h |
README.md
What is Irqbalance
Irqbalance is a daemon to help balance the cpu load generated by interrupts across all of a systems cpus. Irqbalance identifies the highest volume interrupt sources, and isolates each of them to a single unique cpu, so that load is spread as much as possible over an entire processor set, while minimizing cache miss rates for irq handlers.
Building and Installing
./autogen.sh
./configure [options]
make
make install
Developing Irqbalance
Irqbalance is currently hosted on github, and so developers are welcome to use the issue/pull request/etc infrastructure found there.
Bug reporting
When something goes wrong, feel free to send us bugreport by one of the ways described above. Your report should include:
- Irqbalance version you've been using (or commit hash)
/proc/interrupts
outputirqbalance --debug
output- content of smp_affinity files - can be obtained by e.g.:
$ for i in $(seq 0 300); do grep . /proc/irq/$i/smp_affinity /dev/null 2>/dev/null; done
- your hw hierarchy - e.g.
lstopo-no-graphics
output