| .. -*- coding: utf-8; mode: rst -*- |
| NET_ADD_IF - Creates a new network interface for a given Packet ID. |
| .. c:function:: int ioctl( int fd, NET_ADD_IF, struct dvb_net_if *net_if ) |
| File descriptor returned by :ref:`open() <frontend_f_open>`. |
| pointer to struct :c:type:`dvb_net_if` |
| The NET_ADD_IF ioctl system call selects the Packet ID (PID) that |
| contains a TCP/IP traffic, the type of encapsulation to be used (MPE or |
| ULE) and the interface number for the new interface to be created. When |
| the system call successfully returns, a new virtual network interface is |
| The struct :c:type:`dvb_net_if`::ifnum field will be |
| filled with the number of the created interface. |
| .. flat-table:: struct dvb_net_if |
| - Packet ID (PID) of the MPEG-TS that contains data |
| - number of the DVB interface. |
| - Encapsulation type of the feed. It can be: |
| ``DVB_NET_FEEDTYPE_MPE`` for MPE encoding or |
| ``DVB_NET_FEEDTYPE_ULE`` for ULE encoding. |
| On success 0 is returned, on error -1 and the ``errno`` variable is set |
| appropriately. The generic error codes are described at the |
| :ref:`Generic Error Codes <gen-errors>` chapter. |