我是靠谱客的博主 含糊金鱼,这篇文章主要介绍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网卡内容请搜索靠谱客的其他文章。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部