FreeBSD src
Go to file
Alexander V. Chernikov 0cba2b2802 Add support for multi-field values inside ipfw tables.
This is the last major change in given branch.

Kernel changes:
* Use 64-bytes structures to hold multi-value variables.
* Use shared array to hold values from all tables (assume
  each table algo is capable of holding 32-byte variables).
* Add some placeholders to support per-table value arrays in future.
* Use simple eventhandler-style API to ease the process of adding new
  table items. Currently table addition may required multiple UH drops/
  acquires which is quite tricky due to atomic table modificatio/swap
  support, shared array resize, etc. Deal with it by calling special
  notifier capable of rolling back state before actually performing
  swap/resize operations. Original operation then restarts itself after
  acquiring UH lock.
* Bump all objhash users default values to at least 64
* Fix custom hashing inside objhash.

Userland changes:
* Add support for dumping shared value array via "vlist" internal cmd.
* Some small print/fill_flags dixes to support u32 values.
* valtype is now bitmask of
  <skipto|pipe|fib|nat|dscp|tag|divert|netgraph|limit|ipv4|ipv6>.
  New values can hold distinct values for each of this types.
* Provide special "legacy" type which assumes all values are the same.
* More helpers/docs following..

Some examples:

3:41 [1] zfscurr0# ipfw table mimimi create valtype skipto,limit,ipv4,ipv6
3:41 [1] zfscurr0# ipfw table mimimi info
+++ table(mimimi), set(0) +++
 kindex: 2, type: addr
 references: 0, valtype: skipto,limit,ipv4,ipv6
 algorithm: addr:radix
 items: 0, size: 296
3:42 [1] zfscurr0# ipfw table mimimi add 10.0.0.5 3000,10,10.0.0.1,2a02:978:2::1
added: 10.0.0.5/32 3000,10,10.0.0.1,2a02:978:2::1
3:42 [1] zfscurr0# ipfw table mimimi list
+++ table(mimimi), set(0) +++
10.0.0.5/32 3000,0,10.0.0.1,2a02:978:2::1
2014-08-31 23:51:09 +00:00
bin Always check the limits of array index variables before using them. 2014-08-21 02:40:33 +00:00
cddl MFV r270197: 2014-08-22 22:13:36 +00:00
contrib Add the patch commited in r270147. 2014-08-18 18:07:28 +00:00
crypto Merge OpenSSL 1.0.1i. 2014-08-07 18:56:10 +00:00
etc Add "nobrowse" option. Previously automountd(8) always behaved as if 2014-08-23 12:00:45 +00:00
games Update the freebsd-tips example to use drill instead of dig since bind is no longer in base 2014-07-25 14:47:44 +00:00
gnu Add ${LIBC} to DPADD to fix "make checkdpadd" 2014-08-20 15:43:26 +00:00
include Add guards to ptrdiff_t definition in include/stddef.h 2014-08-21 15:10:10 +00:00
kerberos5 Revert r267233 for now. PIE support needs to be reworked. 2014-08-19 15:04:32 +00:00
lib Add missing break. 2014-08-20 14:58:25 +00:00
libexec Always check the limits of array index variables before using them. 2014-08-21 02:40:33 +00:00
release In arm/release.sh, continue if 'xdev-links' target fails 2014-08-11 16:31:28 +00:00
rescue Add zdb into rescue environment. 2014-08-20 00:14:41 +00:00
sbin Add support for multi-field values inside ipfw tables. 2014-08-31 23:51:09 +00:00
secure Fix typo (LIBLDNSADD -> LIBLDNS) to fix "make checkdpadd" 2014-08-19 18:27:43 +00:00
share Next round of fixes. 2014-08-21 20:33:09 +00:00
sys Add support for multi-field values inside ipfw tables. 2014-08-31 23:51:09 +00:00
tests Numerous small fixes, mostly suggested by Coverity. 2014-08-20 16:59:33 +00:00
tools Modify a few output file names as used with vt. 2014-08-21 20:35:39 +00:00
usr.bin Suppress warnings when retrieving protocol stats from interfaces that 2014-08-22 19:23:38 +00:00
usr.sbin Add "nobrowse" option. Previously automountd(8) always behaved as if 2014-08-23 12:00:45 +00:00
.arcconfig Update the URL to the phabricator instance. 2014-08-14 16:25:43 +00:00
.arclint arc: add linting for python files 2014-06-02 00:21:42 +00:00
COPYRIGHT Bump copyright year. 2013-12-31 12:18:10 +00:00
LOCKS Explicitly require Security Officer's approval for kernel PRNG bits. 2013-09-17 14:19:05 +00:00
MAINTAINERS add myself as opencrypto maintainer as I'm doing some work in the 2014-08-11 19:03:20 +00:00
Makefile Create the native-xtools target. This target creates only the cross 2014-08-18 21:04:44 +00:00
Makefile.inc1 Revert r267233 for now. PIE support needs to be reworked. 2014-08-19 15:04:32 +00:00
ObsoleteFiles.inc Bump version because challenge buffer size changed 2014-08-14 04:42:09 +00:00
README Add the cddl/ directory. 2010-11-14 11:32:56 +00:00
UPDATING Make mmap() of the console device when using ofwfb work like other supported 2014-07-29 23:11:05 +00:00

This is the top level of the FreeBSD source directory.  This file
was last revised on:
$FreeBSD$

For copyright information, please see the file COPYRIGHT in this
directory (additional copyright information also exists for some
sources in this tree - please see the specific source directories for
more information).

The Makefile in this directory supports a number of targets for
building components (or all) of the FreeBSD source tree, the most
commonly used one being ``world'', which rebuilds and installs
everything in the FreeBSD system from the source tree except the
kernel, the kernel-modules and the contents of /etc.  The ``world''
target should only be used in cases where the source tree has not
changed from the currently running version.  See:
http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html
for more information, including setting make(1) variables.

The ``buildkernel'' and ``installkernel'' targets build and install
the kernel and the modules (see below).  Please see the top of
the Makefile in this directory for more information on the
standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process, documentation
for which can be found at:
   http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
And in the config(8) man page.
Note: If you want to build and install the kernel with the
``buildkernel'' and ``installkernel'' targets, you might need to build
world before.  More information is available in the handbook.

The sample kernel configuration files reside in the sys/<arch>/conf
sub-directory (assuming that you've installed the kernel sources), the
file named GENERIC being the one used to build your initial installation
kernel.  The file NOTES contains entries and documentation for all possible
devices, not just those commonly used.  It is the successor of the ancient
LINT file, but in contrast to LINT, it is not buildable as a kernel but a
pure reference and documentation file.


Source Roadmap:
---------------
bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

games		Amusements.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

sys		Kernel sources.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.


For information on synchronizing your source tree with one or more of
the FreeBSD Project's development branches, please see:

  http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html