STM32实验及笔记 —— 🕹️(038)LwIP Tcp Server开发例程
»
(001)HAL库LED点灯
(002)HAL库LCD帧动画
(003)HAL库FFT动态频谱
(004)HAL库FFT Speed Up
(005)HAL库认识DMA
(006)看门狗总结
(007)GPIO使用步骤
(008)CubeIDE实现USB外设*
(009)为什么C99
(010)Linux UDP广播注意事项
(011)Linux非阻塞TCP
(012)ARM架构防烧脚本
(013)OpenWrt交叉编译
(014)C99基本数据类型
(015)C99 结构体
(016)C99 枚举
(017)C99 的函数及左值右值
(018)C99 的指针*
(019)C99 只有值赋值,没有move*
(020)C99 数组及结构体中的数组存储空间
(021)C99标准函数库没有函数模板
(022)POSIX线程库pthread的同步锁*
(023)POSIX线程库pthread的多线程*
(024)C99的条件语句
(025)C99的选择语句
(026)C99的循环语句
(027)C99标准库中的计时与等待 *
(028)C语言中的高精度计算库GMP *
(029)C语言中的Web服务*
(030)C语言中的字符转码ICU*
(031)从几个方面显然C语言比C++效率高*
(032)C99中的弱函数weak
(033)MTU TCP SOCKET
(034)STM32 UART连续发送数据函数
(035)STM32 UART连续接收数据函数
(036)STM32重定向printf输出到USART的方法
(037)STM32 Normal与Circle
(038)STM32 UART传输错误标志位的清除
(039)STM32 UART传输空闲中断
(040)STM32 串口、RS232是单根线发数据
(041)STM32 RS485差分信号通信
(042)STM32 等待DMA传输完成指定的字节数
(043)STM32进入低功耗模式
(044)DMA传输完成中断需要清空TCx标志位
(045)STM32软件函数命名规范
(046)在单字节完成中断中处理Idle
(047)C99内置宏
(048)使能中断后中断服务程序才起作用
(049)STM32程序启动过程
(050)STM32热加载新的程序固件
(051)中断向量表的指定
(052)STM32程序内的地址空间
(053)STM32修改主程序存放的地方
(054)Bootloader参考
(055)Keil中的下载算法
(056)编译器优化出错点
🍓(001)关闭交换分区
🍓(002)格式化U盘为ext4并设定块大小为1k
🍓(003)获取linux版本信息及硬件架构信息
🍓(004)最新版Ubuntu加速
🍓(005)不稳定网络克隆360浏览器内核脚本
🍓(006)Ubuntu24.04无法运行firefox注意事项
🍓(007)MAC地址
🍓(008)RMII和PHY
🍓(009)Ubuntu Server防火墙配置
🍓(010)Linux主动让出CPU
🍓(011)Linux硬件概念
🍓(012)Linux系统中的进程间通信
🍓(013)Git禁止强制推送
🍓(014)Git禁止reset --hard
🍓(015)将未写入的缓存立即写入硬盘
🍓(016)拷贝pre-receive到每个git仓库的脚本
🍓(017)sshd密码输入错误禁用IP3分钟
🖥️(001)异机备份低功耗自用Git服务器搭建
🖥️(002)OpenWRT配置注意事项
🕹️(001)while(1){}让出CPU后重进
🕹️(002)FreeRTOS主要函数
🕹️(003)FreeRTOS临界区ENTER_CRITICAL
🕹️(004)FreeRTOS NULL未定义问题的解决
🕹️(005)优先级最低的ARM硬件中断PENDSV
🕹️(006)任务优先级层数配置
🕹️(007)不同优先级任务创建注意事项
🕹️(008)关闭同级任务的时间片轮转
🕹️(009)OTA技术
🕹️(010)FreeRTOS静态任务创建
🕹️(011)FreeRTOS列出任务列表
🕹️(012)FreeRTOS堆空间使用量统计
🕹️(013)FreeRTOS通过任务名获取TaskHandle
🕹️(014)FreeRTOS常用任务创建方式
🕹️(015)FreeRTOS解决优先级反转的任务死锁
🕹️(016)FreeRTOS超级中断:SVC
🕹️(017)FreeRTOS中断处理函数运行在特权级
🕹️(018)FreeRTOS SVC进入用户模式的方法
🕹️(019)FreeRTOS实现绝对时间间隔开始任务
🕹️(020)FreeRTOS低功耗通过Tickless实现
🕹️(021)FreeRTOS IdleHook
🕹️(022)FreeRTOS Hooks
🕹️(023)FreeRTOS主动让出CPU
🕹️(024)FreeRTOS信号量
🕹️(025)FreeRTOS解决优先级反转问题的方法
🕹️(026)FreeRTOS获得任务的优先级
🕹️(027)FreeRTOS设置任务的优先级
🕹️(028)FreeRTOS中函数的前缀
🕹️(029)硬件中断中不能调用FreeRTOS的函数
🕹️(030)底半操作的任务接收信号量处理数据
🕹️(031)启用无限期等待
🕹️(032)中断处理函数中调用FreeRTOS的函数
🕹️(033)对于FreeRTOS顶半与底半操作的原则
🕹️(034)STM32中的FATFS支持exFat
🕹️(035)FreeRTOS中的消息队列
🕹️(036)FreeRTOS中的定时任务
🕹️(037)默认生成代码没法ping板子的原因
🕹️(038)LwIP Tcp Server开发例程
🕹️(039)切记别用mutex
🕹️(040)MEMP与Pbuf的关系
🕹️(041)FreeRTOS连接ESP WiFi(待完成)
📟(001)CMSIS标准学习
🕹️(001)函数调用被优化
LwIP Tcp Server开发例程(总结自ChatGPT):
LwIP核心单线程,所有协议栈操作和回调都在一个线程中运行。

void TcpServerInit(void)
{
    struct tcp_pcb *tcp_server_pcb;
    tcp_server_pcb = tcp_new();
    tcp_bind(tcp_server_pcb, IP_ADDR_ANY, 8080);
    tcp_server_pcb = tcp_listen(tcp_server_pcb);
    tcp_accept(tcp_server_pcb, TcpServerAcceptCallback);  //主循环中需要不断地调用sys_check_timeouts来检查有没有新的Tcp连接的到来
}
 
static err_t TcpServerAcceptCallback(void *arg, struct tcp_pcb *pcb, err_t err)
{
    if (pcb == NULL) {
        return ERR_MEM; // 无法创建新的连接
    }
    tcp_accepted(pcb);// 通知 LwIP 当前连接已被接受
    tcp_recv(pcb, TcpServerRecvCallback);// 注册接收数据的回调函数
    return ERR_OK;
}
 
static err_t TcpServerRecvCallback(void *arg, struct tcp_pcb *pcb, struct pbuf *tcp_recved_pbuf, err_t err)
{
    if (tcp_recved_pbuf == NULL) {
        // 远程端已关闭连接
        tcp_close(pcb);
        return ERR_OK;
    }
    if (err != ERR_OK) {
        // 如果发生错误,释放 pbuf 并返回错误
        struct pbuf *current_pbuf = tcp_recved_pbuf;
        struct pbuf *tmp_pbuf = tcp_recved_pbuf;
        while (current_pbuf != NULL) {
            tmp_pbuf = current_pbuf;
            current_pbuf = current_pbuf->next;
            pbuf_free(tmp_pbuf);
        }
        return err;
    }
    //以下处理数据
    size_t total_len = tcp_recved_pbuf->tot_len;// tot_len 是链表中所有节点的 len 累加值
    struct pbuf *current_pbuf = tcp_recved_pbuf;
    struct pbuf *tmp_pbuf = tcp_recved_pbuf;
    while (current_pbuf != NULL) {
        tcp_write(pcb, current_pbuf->payload, current_pbuf->len, 1);  //echo全部pbuf块数据
        tmp_pbuf = current_pbuf;
        current_pbuf = current_pbuf->next;
        pbuf_free(tmp_pbuf);
    }
    tcp_recved(pcb, total_len);
//恢复收发窗口:当应用层处理完接收到的数据后,需要增加接收窗口的大小,以便继续接收新的数据‌
    return ERR_OK;
}
最后,建议采用Unix Socket开发方式开发LwIP的socket代码。
«
——张人杰·www.v-signon.com学习者共勉
返回上一页
备案号:京ICP备19038994号-2
个人作品网站:www.up-task.com 主办:个人 English
网站内容如有侵权,请联系删除:1307776259@qq.com