#include <net/ethernet.h>
(это часть glibc) даст определения ETHERTYPE_*:/* Ethernet protocol ID's */
#define ETHERTYPE_PUP 0x0200 /* Xerox PUP */
#define ETHERTYPE_SPRITE 0x0500 /* Sprite */
#define ETHERTYPE_IP 0x0800 /* IP */
#define ETHERTYPE_ARP 0x0806 /* Address resolution */
#define ETHERTYPE_REVARP 0x8035 /* Reverse ARP */
#define ETHERTYPE_AT 0x809B /* AppleTalk protocol */
#define ETHERTYPE_AARP 0x80F3 /* AppleTalk ARP */
#define ETHERTYPE_VLAN 0x8100 /* IEEE 802.1Q VLAN tagging */
#define ETHERTYPE_IPX 0x8137 /* IPX */
#define ETHERTYPE_IPV6 0x86dd /* IP protocol version 6 */
#define ETHERTYPE_LOOPBACK 0x9000 /* used to test interfaces */
The first step in determining the target CPU for RPS is to calculate a
flow hash over the packet’s addresses or ports (2-tuple or 4-tuple hash
depending on the protocol). This serves as a consistent hash of the
associated flow of the packet.
То есть мне желательно записывать по одному элементу
это гарантирует порядок обработки в рамках одного идентификатора, но не всех
о максимально возможной производительности придётся забыть.
что сделало приложение переносимым
pthread_cond_wait(¬ify, mtx); // Выполнение работы
Если я правильно вас понял, то под
бе семафор
вы имели в виду мьютекс.
add_executable(2sem_main main.c)