FreeBSD manual
download PDF document: ng_device.4.pdf
NG_DEVICE(4) FreeBSD Kernel Interfaces Manual NG_DEVICE(4)
NAME
ng_device - device netgraph node type
SYNOPSIS
#include <netgraph/ng_device.h>
DESCRIPTION
A device node is both a netgraph node and a system device interface.
When a device node is created, a new device entry appears which is
accessible via the regular file operators such as open(2), close(2),
read(2), write(2), etc.
The first node is created as /dev/ngd0, subsequent nodes are /dev/ngd1,
/dev/ngd2, etc.
HOOKS
A device node has a single hook with an arbitrary name. All data coming
in over the hook will be presented to the device for read(2). All data
coming in from the device entry by write(2) will be forwarded to the
hook.
CONTROL MESSAGES
The device node supports the generic control messages, plus the
following:
NGM_DEVICE_GET_DEVNAME
Returns the device name corresponding to the node.
NGM_DEVICE_ETHERALIGN
Apply the system ETHER_ALIGN offset to mbufs sent out the node's
hook, if running on an architecture that requires strict alignment.
Use this option when the data being injected via the device node
ultimately ends up being fed into the protocol stack as ethernet
packets (e.g., via an ng_eiface(4) node).
SHUTDOWN
This node shuts down upon receipt of a NGM_SHUTDOWN control message, or
upon hook disconnection. The associated device entry is removed and
becomes available for use by future device nodes.
SEE ALSO
netgraph(4), ngctl(8)
HISTORY
The device node type was first implemented in FreeBSD 5.0.
AUTHORS
Mark Santcroos <marks@ripe.net>
Gleb Smirnoff <glebius@FreeBSD.org>
FreeBSD 14.2-RELEASE November 8, 2021 FreeBSD 14.2-RELEASE