【以太网数据结构】以太网头部
2015-11-24 17:14
393 查看
以太网封包格式如图所示:
![](http://img.blog.csdn.net/20151010200458516)
以太网目的地址和源地址各占6个字节,该地址即平常所说的网卡的MAC。每个网卡在全球拥有唯一的MAC!
在地址后面有两个字节表示类型,如:0800表示此真数据是IP数据,0806表示ARP请求。后面博客会针对讲解。
类型字段之后是数据,对于以太网,数据段大小为46-1500字节,不足46字节的数据将被自动补足到46字节。如ARP协议的数据格式为28字节,为了符合规范,其后被填充了18个字节以达到最少46字节的要求。
CRC字段用于对帧内数据进行校验,保证数据传输的正确性,通常是硬件实现的。
以太网数据包格式较为简单,简述到此!
最后留一个问题,以太网数据包在网络中最终传输到目的地是用的IP来寻址还是MAC来寻址?(想一想,如果只是没有目的地IP,数据会准确的送达到目的地吗?倘若只是没有MAC呢?)
在局域网内,协议栈根据MAC来精确的将数据送达到指定网卡,而在广域网中,数据在网际中肆意穿梭,直到到达目的IP(当然,数据包有生存时间的限制,以防止数据包在网络中无限循环下去)
相关源代码
在linux/if_ether.h文件中,以太网包头结构体定义如下:
获取以太网包头函数(提示:测试该函数返回值不为空后再使用)
以太网目的地址和源地址各占6个字节,该地址即平常所说的网卡的MAC。每个网卡在全球拥有唯一的MAC!
在地址后面有两个字节表示类型,如:0800表示此真数据是IP数据,0806表示ARP请求。后面博客会针对讲解。
类型字段之后是数据,对于以太网,数据段大小为46-1500字节,不足46字节的数据将被自动补足到46字节。如ARP协议的数据格式为28字节,为了符合规范,其后被填充了18个字节以达到最少46字节的要求。
CRC字段用于对帧内数据进行校验,保证数据传输的正确性,通常是硬件实现的。
以太网数据包格式较为简单,简述到此!
最后留一个问题,以太网数据包在网络中最终传输到目的地是用的IP来寻址还是MAC来寻址?(想一想,如果只是没有目的地IP,数据会准确的送达到目的地吗?倘若只是没有MAC呢?)
在局域网内,协议栈根据MAC来精确的将数据送达到指定网卡,而在广域网中,数据在网际中肆意穿梭,直到到达目的IP(当然,数据包有生存时间的限制,以防止数据包在网络中无限循环下去)
相关源代码
在linux/if_ether.h文件中,以太网包头结构体定义如下:
[code]#define ETH_ALEN 6 struct ethhdr { unsigned char h_dest[ETH_ALEN]; /* destination eth addr */ unsigned char h_source[ETH_ALEN]; /* source ether addr */ __be16 h_proto; /* packet type ID field */ } __attribute__((packed)); //packed属性:使用该属性可以使得变量或者结构体成员使用最小的对齐方式,即对变量是一字节对齐,对域(field)是位对齐。
获取以太网包头函数(提示:测试该函数返回值不为空后再使用)
[code]static inline struct ethhdr *eth_hdr(const struct sk_buff *skb) { return (struct ethhdr *)skb_mac_header(skb); }
相关文章推荐
- JavaScript 数据结构(5):单链表 LinkList
- NP-完全性介绍
- Hashing Table
- 线性表的顺序列表实现
- 数据结构绪论
- 数据结构(Java)——二叉查找树
- DFS应用——查找强分支
- DFS应用——遍历有向图+判断有向图是否有圈
- 算法和数据结构就是编程的一个重要部分,你若失掉了算法和数据结构,你就把一切都失掉了。——佚名
- redis数据结构详解之Hash(四)
- DFS应用——寻找欧拉回路
- 数据结构:关于重建二叉树的三种思路
- 数据结构:关于重建二叉树的三种思路
- 负载均衡的基本算法
- redis数据结构-简单动态字符串(sds)
- HDU 1800-Flying to the Mars(trie树)
- 数据结构 — 图 之 MST(最小生成树 — prim算法 )
- python数据结构(一)
- 【数据结构和算法】排序算法之四:希尔排序
- 【数据结构和算法】排序算法之四:希尔排序