我是靠谱客的博主 含糊金鱼,最近开发中收集的这篇文章主要介绍linux网卡的接收和发送,[linux]网络报文发送、接收调用链,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

网络报文从应用程序产生,通过网卡发送,在另一端的网卡接收数据并传递给应用程序。这个过程网络报文在内核中调用了一系列的函数。下面把这些函数列举出来,方便我们了解网络报文的流程。

发送流程:

write

|

sys_write

|

sock_sendmsg

|

inet_sendmsg

|

tcp_sendmsg

|

tcp_push_one

|

tcp_transmit_skb

|

ip_queue_xmit

|

ip_route_output

|

ip_queue_xmit

|

ip_queue_xmit2

|

ip_output

|

ip_finish_output

|

neith_connected_output

|

dev_queue_xmit ---------------|

|                                           |

|                                          queue_run

|                                           |

|                                          queue_restart

|                                           |

hard_start_xmit-----------------|

接收流程:

netif_rx

|

netif_rx_schedule

|

_cpu_raise_softirq

|

net_rx_action

|

ip_rcv

|

ip_rcv_finish

|

ip_route_input

|

ip_local_deliver

|

ip_local_deliver_finish

|

tcp_v4_rcv

|

tcp_v4_do_rcv

|

tcp_rcv_established------------------|

|                                                   |

tcp_data_queue                            |

|                                                   |

_skb_queue_tail----------------------|

|

data_ready

|

sock_def_readable

|

wake_up_interruptible

|

tcp_data_wait

|

tcp_recvmsg

|

inet_recvmsg

|

sock_recvmsg

|

sock_read

|

read

数据包在应用层称为data,在TCP层称为segment,在IP层称为packet,在数据链路层称为frame。

最后

以上就是含糊金鱼为你收集整理的linux网卡的接收和发送,[linux]网络报文发送、接收调用链的全部内容,希望文章能够帮你解决linux网卡的接收和发送,[linux]网络报文发送、接收调用链所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(60)

评论列表共有 0 条评论

立即
投稿
返回
顶部