详解sockaddr_ll 设备无关的物理层地址结构

2023-12-21 08:08

本文主要是介绍详解sockaddr_ll 设备无关的物理层地址结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

sockaddr_ll: 表示设备无关的物理层地址结构

定义:

[cpp] view plain copy
  1. struct sockaddr_ll {  
  2.         unsigned short  sll_family;  
  3.         __be16          sll_protocol;  
  4.         int             sll_ifindex;  
  5.         unsigned short  sll_hatype;  
  6.         unsigned char   sll_pkttype;  
  7.         unsigned char   sll_halen;  
  8.         unsigned char   sll_addr[8];  
  9. };  
sll_family: 和sockaddr_in中的sa_family一样,地址族的意思。

sll_protocol: 表示上层的协议类型,有如下选择:

[cpp] view plain copy
  1. 源文件为<linux/if_ether.h>  
  2. /* 
  3. * These are the defined Ethernet Protocol ID's. 
  4. */  
  5.   
  6. #define ETH_P_LOOP 0x0060 /* Ethernet Loopback packet */  
  7. #define ETH_P_PUP 0x0200 /* Xerox PUP packet */  
  8. #define ETH_P_PUPAT 0x0201 /* Xerox PUP Addr Trans packet */  
  9. #define ETH_P_IP 0x0800 /* Internet Protocol packet */  
  10. #define ETH_P_X25 0x0805 /* CCITT X.25 */  
  11. #define ETH_P_ARP 0x0806 /* Address Resolution packet */  
  12. #define ETH_P_BPQ 0x08FF /* G8BPQ AX.25 Ethernet Packet*/  
  13. #define ETH_P_IEEEPUP 0x0a00 /* Xerox IEEE802.3 PUP packet */  
  14. #define ETH_P_IEEEPUPAT 0x0a01 /* Xerox IEEE802.3 PUP Addr Trans packet */  
  15. #define ETH_P_DEC 0x6000 /* DEC Assigned proto */  
  16. #define ETH_P_DNA_DL 0x6001 /* DEC DNA Dump/Load */  
  17. #define ETH_P_DNA_RC 0x6002 /* DEC DNA Remote Console */  
  18. #define ETH_P_DNA_RT 0x6003 /* DEC DNA Routing */  
  19. #define ETH_P_LAT 0x6004 /* DEC LAT */  
  20. #define ETH_P_DIAG 0x6005 /* DEC Diagnostics */  
  21. #define ETH_P_CUST 0x6006 /* DEC Customer use */  
  22. #define ETH_P_SCA 0x6007 /* DEC Systems Comms Arch */  
  23. #define ETH_P_RARP 0x8035 /* Reverse Addr Res packet */  
  24. #define ETH_P_ATALK 0x809B /* Appletalk DDP */  
  25. #define ETH_P_AARP 0x80F3 /* Appletalk AARP */  
  26. #define ETH_P_IPX 0x8137 /* IPX over DIX */  
  27. #define ETH_P_IPV6 0x86DD /* IPv6 over bluebook */  
  28. #define ETH_P_PPP_DISC 0x8863 /* PPPoE discovery messages */  
  29. #define ETH_P_PPP_SES 0x8864 /* PPPoE session messages */  
  30. #define ETH_P_ATMMPOA 0x884c /* MultiProtocol Over ATM */  
  31. #define ETH_P_ATMFATE 0x8884 /* Frame-based ATM Transport  
  32. * over Ethernet  
  33. */  
一般是IP的话选ETH_P_IP。
sll_ifindex: 表示接口类型,源文件<linux/netdevice.h>,有如下选择:
[cpp] view plain copy
  1. /* Media selection options. */  
  2. enum {  
  3. IF_PORT_UNKNOWN = 0,  
  4. IF_PORT_10BASE2,  
  5. IF_PORT_10BASET,  
  6. IF_PORT_AUI,  
  7. IF_PORT_100BASET,  
  8. IF_PORT_100BASETX,  
  9. IF_PORT_100BASEFX  
  10. };  
sll_hatype: ARP 硬件地址类型。可以选择,源文件为<net/if_arp.h>
[cpp] view plain copy
  1. /* ARP protocol HARDWARE identifiers. */  
  2. #define ARPHRD_NETROM 0 /* From KA9Q: NET/ROM pseudo. */  
  3. #define ARPHRD_ETHER 1 /* Ethernet 10/100Mbps. */  
  4. #define ARPHRD_EETHER 2 /* Experimental Ethernet. */  
  5. #define ARPHRD_AX25 3 /* AX.25 Level 2. */  
  6. #define ARPHRD_PRONET 4 /* PROnet token ring. */  
  7. #define ARPHRD_CHAOS 5 /* Chaosnet. */  
  8. #define ARPHRD_IEEE802 6 /* IEEE 802.2 Ethernet/TR/TB. */  
  9. #define ARPHRD_ARCNET 7 /* ARCnet. */  
  10. #define ARPHRD_APPLETLK 8 /* APPLEtalk. */  
  11. #define ARPHRD_DLCI 15 /* Frame Relay DLCI. */  
  12. #define ARPHRD_ATM 19 /* ATM. */  
  13. #define ARPHRD_METRICOM 23 /* Metricom STRIP (new IANA id). */  
sll_pkttype:包含分组类型
有效的分组类型:
目标地址是本地主机的分组用的 PACKET_HOST,
物理层广播分组用的 PACKET_BROADCAST ,
发送到一个物理层多路广播地址的分组用的 PACKET_MULTICAST,
在混杂(promiscuous)模式下的设备驱动器发向其他主机的分组用的PACKET_OTHERHOST,
本源于本地主机的分组被环回到分组套接口用的 PACKET_OUTGOING。
这些类型只对接收到的分组有意义。
sll_addr 和 sll_halen: 包括物理层(例如 IEEE 802.3)地址和地址长度,精确的解释依赖于设备。
sll_halen 为MAC地址长度(6 bytes)
源文件<linux/if_ether.h>
[cpp] view plain copy
  1. #define ETH_ALEN 6 /* Octets in one ethernet addr */  
  2. #define ETH_HLEN 14 /* Total octets in header. */  
  3. #define ETH_ZLEN 60 /* Min. octets in frame sans FCS */  
  4. #define ETH_DATA_LEN 1500 /* Max. octets in payload */  
  5. #define ETH_FRAME_LEN 1514 /* Max. octets in frame sans FCS */  
sll_addr[8] 为目的MAC地址(按sockaddr_in.sin_addr为目的IP地址推测)

这篇关于详解sockaddr_ll 设备无关的物理层地址结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/519206

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

webapp地址

F:\LSP\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor