HardenedBSD src tree
Go to file
Alexander V. Chernikov 74b22066b0 Make rule table kernel-index rewriting support any kind of objects.
Currently we have tables identified by their names in userland
with internal kernel-assigned indices. This works the following way:

When userland wishes to communicate with kernel to add or change rule(s),
it makes indexed sorted array of table names
(internally ipfw_obj_ntlv entries), and refer to indices in that
array in rule manipulation.
Prior to committing new rule to the ruleset kernel
a) finds all referenced tables, bump their refcounts and change
 values inside the opcodes to be real kernel indices
b) auto-creates all referenced but not existing tables and then
 do a) for them.

Kernel does almost the same when exporting rules to userland:
 prepares array of used tables in all rules in range, and
 prepends it before the actual ruleset retaining actual in-kernel
 indexes for that.

There is also special translation layer for legacy clients which is
able to provide 'real' indices for table names (basically doing atoi()).

While it is arguable that every subsystem really needs names instead of
numbers, there are several things that should be noted:

1) every non-singleton subsystem needs to store its runtime state
somewhere inside ipfw chain (and be able to get it fast)
2) we can't assume object numbers provided by humans will be dense.

Existing nat implementation (O(n) access and LIST inside chain) is a
good example.

Hence the following:
* Convert table-centric rewrite code to be more generic, callback-based
* Move most of the code from ip_fw_table.c to ip_fw_sockopt.c
* Provide abstract API to permit subsystems convert their objects
  between userland string identifier and in-kernel index.
  (See struct opcode_obj_rewrite) for more details
* Create another per-chain index (in next commit) shared among all subsystems
* Convert current NAT44 implementation to use new API, O(1) lookups,
 shared index and names instead of numbers (in next commit).

Sponsored by:	Yandex LLC
2015-04-27 08:29:39 +00:00
bin Pet manlint 2015-04-26 10:38:26 +00:00
cddl Add manual pages for the io, ip, proc, sched, tcp and udp DTrace providers. 2015-04-18 21:00:36 +00:00
contrib The fmodl compat shims on arm/mips/powerpc aren't complete 2015-04-27 06:46:33 +00:00
crypto
etc Integrate tools/regression/fifo into the FreeBSD test suite as tests/sys/fifo 2015-04-27 08:15:17 +00:00
games
gnu
include Move ALTQ from contrib to net/altq. The ALTQ code is for many years 2015-04-16 20:22:40 +00:00
kerberos5
lib Build/install libc, librt, libthr, and msun NetBSD test suites on all 2015-04-27 06:49:27 +00:00
libexec Support file verification in MAC. 2015-04-22 01:54:25 +00:00
release Create the arm64/aarch64 VM disk image as MBR instead of 2015-04-23 01:04:14 +00:00
rescue
sbin Generalize object reference handling in ipfw rules. 2015-04-26 10:53:35 +00:00
secure
share Improve smb(4) man page. 2015-04-26 12:24:42 +00:00
sys Make rule table kernel-index rewriting support any kind of objects. 2015-04-27 08:29:39 +00:00
tests Integrate tools/regression/fifo into the FreeBSD test suite as tests/sys/fifo 2015-04-27 08:15:17 +00:00
tools Integrate tools/regression/fifo into the FreeBSD test suite as tests/sys/fifo 2015-04-27 08:15:17 +00:00
usr.bin hexdump: Don't use uninitialized struct stat. 2015-04-26 21:34:55 +00:00
usr.sbin ath3kfw, bcmfw, bthidcontrol, bthidd all require usb(4); build them 2015-04-27 06:34:51 +00:00
.arcconfig phabricator related changes: 2015-04-20 20:33:22 +00:00
.arclint phabricator related changes: 2015-04-20 20:33:22 +00:00
COPYRIGHT
LOCKS
MAINTAINERS
Makefile Add arm64 to universe if binutils is available. 2015-04-16 22:35:19 +00:00
Makefile.inc1 Serialize all of _kerberos5_bootstrap_tools to avoid build failures involving 2015-04-21 10:17:25 +00:00
ObsoleteFiles.inc Reincorporate documentation lost with update to nvi 2.1.3 2015-04-26 07:52:43 +00:00
README README: changes and fixups 2015-04-19 07:16:44 +00:00
UPDATING Make it harder to specify invalid LIBADD by causing values without 2015-04-16 15:34:22 +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.  See build(7)
and 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.  See build(7), config(8),
and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
for more information.

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 kernel configuration files reside in the sys/<arch>/conf
sub-directory.  GENERIC is the default configuration used in release builds.
NOTES contains entries and documentation for all possible
devices, not just those commonly used.


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.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

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