81 lines
1.9 KiB
ReStructuredText
81 lines
1.9 KiB
ReStructuredText
.. _promiscuous_interface:
|
|
|
|
Promiscuous Mode
|
|
################
|
|
|
|
.. contents::
|
|
:local:
|
|
:depth: 2
|
|
|
|
Overview
|
|
********
|
|
|
|
Promiscuous mode is a mode for a network interface controller that
|
|
causes it to pass all traffic it receives to the application rather than
|
|
passing only the frames that the controller is specifically programmed
|
|
to receive. This mode is normally used for packet sniffing as used
|
|
to diagnose network connectivity issues by showing an application
|
|
all the data being transferred over the network. (See the
|
|
`Wikipedia article on promiscuous mode
|
|
<https://en.wikipedia.org/wiki/Promiscuous_mode>`_ for more information.)
|
|
|
|
The network promiscuous APIs are used to enable and disable this mode,
|
|
and to wait for and receive a network data to arrive. Not all network
|
|
technologies or network device drivers support promiscuous mode.
|
|
|
|
Sample usage
|
|
************
|
|
|
|
First the promiscuous mode needs to be turned ON by the application like this:
|
|
|
|
.. code-block:: c
|
|
|
|
ret = net_promisc_mode_on(iface);
|
|
if (ret < 0) {
|
|
if (ret == -EALREADY) {
|
|
printf("Promiscuous mode already enabled\n");
|
|
} else {
|
|
printf("Cannot enable promiscuous mode for "
|
|
"interface %p (%d)\n", iface, ret);
|
|
}
|
|
}
|
|
|
|
|
|
If there is no error, then the application can start to wait for network data:
|
|
|
|
.. code-block:: c
|
|
|
|
while (true) {
|
|
pkt = net_promisc_mode_wait_data(K_FOREVER);
|
|
if (pkt) {
|
|
print_info(pkt);
|
|
}
|
|
|
|
net_pkt_unref(pkt);
|
|
}
|
|
|
|
|
|
Finally the promiscuous mode can be turned OFF by the application like this:
|
|
|
|
.. code-block:: c
|
|
|
|
ret = net_promisc_mode_off(iface);
|
|
if (ret < 0) {
|
|
if (ret == -EALREADY) {
|
|
printf("Promiscuous mode already disabled\n");
|
|
} else {
|
|
printf("Cannot disable promiscuous mode for "
|
|
"interface %p (%d)\n", iface, ret);
|
|
}
|
|
}
|
|
|
|
|
|
See :ref:`net-promiscuous-mode-sample` for a more comprehensive example.
|
|
|
|
|
|
API Reference
|
|
*************
|
|
|
|
.. doxygengroup:: promiscuous
|
|
:project: Zephyr
|