#!/bin/awk -f # Before running this script please ensure that your PATH is # typical as you use for compilation/installation. I use # /bin /sbin /usr/bin /usr/sbin /usr/local/bin, but it may # differ on your system. BEGIN { usage = "If some fields are empty or look unusual you may have an old version.\n" usage = usage "Compare to the current minimal requirements in Documentation/Changes.\n" print usage system("uname -a") printf("\n") printversion("GNU C", version("gcc -dumpversion 2>&1")) printversion("GNU Make", version("make --version 2>&1")) printversion("Binutils", version("ld -v 2>&1")) printversion("Util-linux", version("mount --version 2>&1")) printversion("Mount", version("mount --version 2>&1")) printversion("Module-init-tools", version("depmod -V 2>&1")) printversion("E2fsprogs", version("tune2fs 2>&1")) printversion("Jfsutils", version("fsck.jfs -V 2>&1")) printversion("Reiserfsprogs", version("reiserfsck -V 2>&1")) printversion("Reiser4fsprogs", version("fsck.reiser4 -V 2>&1")) printversion("Xfsprogs", version("xfs_db -V 2>&1")) printversion("Pcmciautils", version("pccardctl -V 2>&1")) printversion("Pcmcia-cs", version("cardmgr -V 2>&1")) printversion("Quota-tools", version("quota -V 2>&1")) printversion("PPP", version("pppd --version 2>&1")) printversion("Isdn4k-utils", version("isdnctrl 2>&1")) printversion("Nfs-utils", version("showmount --version 2>&1")) if (system("test -r /proc/self/maps") == 0) { while (getline <"/proc/self/maps" > 0) { n = split($0, procmaps, "/") if (/libc.*so$/ && match(procmaps[n], /[0-9]+([.]?[0-9]+)+/)) { ver = substr(procmaps[n], RSTART, RLENGTH) printversion("Linux C Library", ver) break } } } printversion("Dynamic linker (ldd)", version("ldd --version 2>&1")) while ("ldconfig -p 2>/dev/null" | getline > 0) { if (/(libg|stdc)[+]+\.so/) { libcpp = $NF break } } if (system("test -r " libcpp) == 0) printversion("Linux C++ Library", version("readlink " libcpp)) printversion("Procps", version("ps --version 2>&1")) printversion("Net-tools", version("ifconfig --version 2>&1")) printversion("Kbd", version("loadkeys -V 2>&1")) printversion("Console-tools", version("loadkeys -V 2>&1")) printversion("Oprofile", version("oprofiled --version 2>&1")) printversion("Sh-utils", version("expr --v 2>&1")) printversion("Udev", version("udevadm --version 2>&1")) printversion("Wireless-tools", version("iwconfig --version 2>&1")) if (system("test -r /proc/modules") == 0) { while ("sort /proc/modules" | getline > 0) { mods = mods sep $1 sep = " " } printversion("Modules Loaded", mods) } } function version(cmd, ver) { while (cmd | getline > 0) { if (!/ver_linux/ && match($0, /[0-9]+([.]?[0-9]+)+/)) { ver = substr($0, RSTART, RLENGTH) break } } close(cmd) return ver } function printversion(name, value, ofmt) { if (value != "") { ofmt = "%-20s\t%s\n" printf(ofmt, name, value) } } '2'/>context:space:mode:
authorFlorian Westphal <fw@strlen.de>2017-01-23 18:21:59 +0100
committerPablo Neira Ayuso <pablo@netfilter.org>2017-02-02 14:31:56 +0100
commita9e419dc7be6997409dca6d1b9daf3cc7046902f (patch)
treeff33b9a6415926bc627d1ad6e49eece8ef417b43 /include
parent303223092081963513494b4377fa1ac9e362ed4b (diff)
netfilter: merge ctinfo into nfct pointer storage area
After this change conntrack operations (lookup, creation, matching from ruleset) only access one instead of two sk_buff cache lines. This works for normal conntracks because those are allocated from a slab that guarantees hw cacheline or 8byte alignment (whatever is larger) so the 3 bits needed for ctinfo won't overlap with nf_conn addresses. Template allocation now does manual address alignment (see previous change) on arches that don't have sufficent kmalloc min alignment. Some spots intentionally use skb->_nfct instead of skb_nfct() helpers, this is to avoid undoing the skb_nfct() use when we remove untracked conntrack object in the future. Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'include')
-rw-r--r--include/linux/skbuff.h21
-rw-r--r--include/net/netfilter/nf_conntrack.h11
2 files changed, 15 insertions, 17 deletions
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h