前言
最近在学习zynq中的lwip协议族,找不到很好的记笔记的地方,所以就用csdn记录一下自己的学习过程。现在对lwip不熟悉,只是把官方的lwip echo server例程跑了一下,能跑通就一点点的照着学了,笔记都是根据自己的理解写的,而且部分内容可能也只针对lwip echo server例程有效,笔记可以供有缘人参考,但不敢保证全对,有不对的地方也期待有高人指点一二。
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/weixin_40356705/article/details/136824649
一、概述
- 原型
void tcp_accept(struct tcp_pcb *pcb, tcp_accept_fn accept)
- 参数
struct tcp_pcb *pcb :一个指向tcp_pcb结构的指针(pcb)
tcp_accept_fn accept:函数指针(其类型为tcp_accept_fn),指向待调用的函数 - 作用
为处于LISTEN状态的TCP连接设置一个回调函数,当新的连接建立时,这个回调函数将被调用。这是一种常见的异步编程模式,允许程序在等待新连接时继续执行其他任务。
二、函数体
void tcp_accept(struct tcp_pcb *pcb, tcp_accept_fn accept)
{
LWIP_ASSERT_CORE_LOCKED(); //断言,用来确保核心已经被锁定。如果核心没有锁定,这个断言可能会失败,导致程序停止执行。
if ((pcb != NULL) && (pcb->state == LISTEN)) {
// 条件判断,确保传入的pcb指针不为空,并且其状态为LISTEN。
struct tcp_pcb_listen *lpcb = (struct tcp_pcb_listen *)pcb;
// 将pcb指针强制转换为tcp_pcb_listen类型的指针,并赋值给lpcb。这是因为tcp_pcb_listen可能是tcp_pcb的一个特定类型或子类,专门用于处理LISTEN状态的TCP连接。
lpcb->accept = accept; //该函数的主语句,用来注册接受回调函数
//将传入的accept函数指针赋值给lpcb的accept成员。这样,当新的连接建立时,就可以调用这个函数了。
} 。
}
三、调用关系
被start_application调用,没有调用其他函数。在实际使用中将accept_callback函数注册给了pcb结构体