ESP32-S3中断,uart_driver_install返回错误ESP_ERR_NOT_FOUND

先上文档,ESP32 中断介绍官方文档:

Interrupt allocation - ESP32 - — ESP-IDF 编程指南 latest 文档

esp_intr_alloc函数说明,一般也不会直接调用该函数

翻到这个函数因为在初始化串口时uart_driver_install函数返回错误ESP_ERR_NOT_FOUND,定义如下:

#define ESP_ERR_NOT_FOUND           0x105   /*!< Requested resource not found */

然后逐层挖下次,是esp_intr_alloc报上来的错误,实际意思是中断的资源用完,不过也不知道哪里用完了,esp32S3串口有3个,我只是开了2个串口,包含日志输出的串口

一般调用uart_driver_install时最后一个参数都是使用默认0,例子里大多数也是intr_alloc_flags 为0,intr_alloc_flags参数介绍为:

intr_alloc_flags 参数:
 * @param intr_alloc_flags Flags used to allocate the interrupt. One or multiple (ORred)
 *        ESP_INTR_FLAG_* values. See esp_intr_alloc.h for more info. Do not set ESP_INTR_FLAG_IRAM here
 *        (the driver's ISR handler is not located in IRAM)



可用值:
/** @brief Interrupt allocation flags
 *
 * These flags can be used to specify which interrupt qualities the
 * code calling esp_intr_alloc* needs.
 *
 */

//Keep the LEVELx values as they are here; they match up with (1<<level)
#define ESP_INTR_FLAG_LEVEL1        (1<<1)  ///< Accept a Level 1 interrupt vector (lowest priority)
#define ESP_INTR_FLAG_LEVEL2        (1<<2)  ///< Accept a Level 2 interrupt vector
#define ESP_INTR_FLAG_LEVEL3        (1<<3)  ///< Accept a Level 3 interrupt vector
#define ESP_INTR_FLAG_LEVEL4        (1<<4)  ///< Accept a Level 4 interrupt vector
#define ESP_INTR_FLAG_LEVEL5        (1<<5)  ///< Accept a Level 5 interrupt vector
#define ESP_INTR_FLAG_LEVEL6        (1<<6)  ///< Accept a Level 6 interrupt vector
#define ESP_INTR_FLAG_NMI           (1<<7)  ///< Accept a Level 7 interrupt vector (highest priority)
#define ESP_INTR_FLAG_SHARED        (1<<8)  ///< Interrupt can be shared between ISRs
#define ESP_INTR_FLAG_EDGE          (1<<9)  ///< Edge-triggered interrupt
#define ESP_INTR_FLAG_IRAM          (1<<10) ///< ISR can be called if cache is disabled
#define ESP_INTR_FLAG_INTRDISABLED  (1<<11) ///< Return with this interrupt disabled

#define ESP_INTR_FLAG_LOWMED    (ESP_INTR_FLAG_LEVEL1|ESP_INTR_FLAG_LEVEL2|ESP_INTR_FLAG_LEVEL3) ///< Low and medium prio interrupts. These can be handled in C.
#define ESP_INTR_FLAG_HIGH      (ESP_INTR_FLAG_LEVEL4|ESP_INTR_FLAG_LEVEL5|ESP_INTR_FLAG_LEVEL6|ESP_INTR_FLAG_NMI) ///< High level interrupts. Need to be handled in assembly.

#define ESP_INTR_FLAG_LEVELMASK (ESP_INTR_FLAG_LEVEL1|ESP_INTR_FLAG_LEVEL2|ESP_INTR_FLAG_LEVEL3| \
                                 ESP_INTR_FLAG_LEVEL4|ESP_INTR_FLAG_LEVEL5|ESP_INTR_FLAG_LEVEL6| \
                                 ESP_INTR_FLAG_NMI) ///< Mask for all level flags

intr_alloc_flags参数最终会传给esp_intr_alloc,从错误ESP_ERR_NOT_FOUND知道中断资源用完了,ESP提供了一种共享的方式使用中断,也就是使用ESP_INTR_FLAG_SHARED代替0传入,采用共享中断的方式,直接改一个是没效果的,共享嘛,要其他和你共享,其他也要改成共享的方式才行。不重要的中断,我全部干脆都使用共享中断,改了GPIO、TWAI、音频、UART...,从文档看到使用共享中断后中断等级只能使用level-1,即最低等级中断。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
配送一个自己写的串口驱动程序 用DMA接收数据 接收完会产生一个空闲中断 由此可判断接收完一个包的数据 再配送一个我自己写的动态内存管理 跟ESP8266的驱动 在项目中测试460800的波特率 30kb一秒的数据接收 一包1024个字节 每包需要应答15字节的情况下 AT指令处理是使用多个缓冲级来处理模块发送过来的数据 分别有模块应答缓冲级 跟等待应答的缓冲级、被忽略的AT指令集的缓冲级(例如注册一个SEND OK\r\n则模块应答此条指令立刻清除缓冲级释放内存无需等待超时直接忽略)还有需要回调的缓冲级(则出现此指令调用回调函数)都是通过注册的方式来实现 如果出现一包跟指令被分到一个包内 AT处理函数一样可以搜索到AT指令 使用strstr函数来实现 函数的缓冲级都是指针不占用内存 使用动态内存管理的方式 有数据则创建内存放入数据作为一个缓冲级 如果模块应答的数据在规定的时间内没有响应则删除此缓冲级 函数前都有注释介绍 下面介绍一些常用的函数: at_init初始化一些变量已经串口 at_time_task使用定时器回调 1毫秒回调一次 用来计数超时的指令缓冲&等待超时的计数 at_clear_all 在模块开机的时候可能会有很多乱数据 可以在初始化完毕后使用此函数清除所有缓冲级 释放所有内存 at_processing处理AT的应答超时的指令(做删除释放内存的动作),还有处理等待的AT指令 此函数一定要不断循环处理 可以加入到定时器 目前我实验是在UCOS上的 所以直接创建个任务来执行此函数 当程序在等待某个AT指令的时候此函数会寻找接收的缓冲级是否有等待的AT指令 at_cmd_cb_hand回调处理函数 如果接收缓冲级出现某个已经注册的指令则回调注册时所填写的函数地址 at_send_cmd 发送一个AT指令 可以用跟printf一样使用 %d等等 at_send_data 发送数据的时候所使用 需要填写长度 at_cmd_ignore_register 注册一个被忽略的AT指令 带入参数 *s (例如填写一个"SEND OK" 则模块应答的此条指令直接被忽略 释放内存 被忽略之前会检查此缓冲级会不会带有别的AT指令需要回调的) at_cmd_ignore_cancel 取消被忽略的指令 则取消已经注册的被忽略的AT指令 at_cmd_cb_register AT指令的回调注册 例如参数填写"+IPD",函数名a 则出现+IPD的时候回调a函数 a函数有类型 在at.h文件里面有 at_cmd_cb_cancel注销回调你懂得 at_wait_cmd 等待一个AT指令集或者超时则立刻返回 等待途中会不断调用OS的延迟程序 让系统能有时间去执行其他任务 使用方法例如{ at_send_cmd("AT+UART=%u,%u,%u,%u,%u\r\n",baudrate,databit,stopbit,parity,flow_control); return (esp_error)at_wait_cmd("\r\nOK\r\n",2000,NULL); } at_error at_wait2_cmd(char *s,char *s2,u16 timeout,u8 *index) 此函数是等待两个AT指令集 如果出现一个则立刻返回 返回值h文件有介绍 AT_DONE则出现此条指令 index参数则提取应答的缓冲首地址 使用at_buf_get函数获取首地址 使用完后要调用at_free_buf来清除并释放这个缓冲级 at_buf_len_get查询此应答的缓冲级长度 如果在index填写NULL则不需要缓冲级首地址 直接清除释放缓冲级
### 回答1: esp32-wroom-32e_devkitc 是一款基于 ESP32-WROOM-32E 模组的开发板,它采用了开放源代码的 ESP-IDF 开发框架,支持 Wi-Fi 和蓝牙通信。中文参考手册为开发者提供了详细的技术规格和使用指南。 这份参考手册首先介绍了 ESP32-WROOM-32E 模组的硬件组成和技术规格。模组具有双核 Tensilica LX6 处理器,主频高达 240MHz,支持多种外设接口,如 GPIO、UART、SPI、I2C 等,使其具备了丰富的扩展性。此外,模组还具备 Wi-Fi 802.11 b/g/n/e/i 和蓝牙 4.2 支持。 接着,参考手册详细介绍了如何搭建开发环境和配置开发板。它详细阐述了如何下载和安装 ESP-IDF 开发框架,以及如何配置开发环境和编译项目。开发者可以按照参考手册提供的步骤来快速搭建开发环境。 在使用手册的后续部分,详细描述了开发板的各个方面。它包括如何使用 Wi-Fi 进行连接和通信,如何使用蓝牙进行数据传输,以及如何通过 GPIO 与外部设备进行交互等。此外,手册还提供了丰富的示例代码和代码解释,帮助开发者更好地理解和应用相关功能。 最后,手册还介绍了开发板的固件更新方法,以及一些建议和常见问题解答。开发者可以根据手册中提供的信息和指南来解决常见问题,也可以参考手册获取开发者社区的相关资源和支持。 综上所述,esp32-wroom-32e_devkitc 中文参考手册是一份非常详细和全面的开发指南,可以帮助开发者快速上手和开发基于 ESP32-WROOM-32E 的应用程序。 ### 回答2: esp32-wroom-32e_devkitc 中文参考手册是一个详细介绍 ESP32-WROOM-32E 开发板的使用手册。手册从硬件介绍、软件开发环境搭建、编程语言和连接方式等多个方面对开发板进行了全面讲解。 首先,手册介绍了 ESP32-WROOM-32E 开发板的硬件配置,包括板载的芯片、外设、接口等。通过详细的硬件介绍,开发者可以了解到开发板的基本构造和硬件特性,为后续的软件开发提供基础。 接着,手册详细介绍了软件开发环境的搭建过程。它包括了开发环境的安装方法、编译调试工具的配置以及对应的驱动程序等。开发者可以按照手册中的指引,快速搭建开发环境,并开始进行软件开发。 在编程方面,手册提供了多种编程语言的使用说明,包括 C 语言和 MicroPython。每种语言都有详细的语法介绍和示例代码,方便开发者快速上手。此外,手册还介绍了如何使用各种库函数和API接口,以及涉及到的常用开发工具和调试方法。 最后,手册还展示了一些常见的连接方式和示例应用,例如如何与传感器、无线通信模块和云平台进行连接,并进行数据传输和控制。这些示例可以帮助开发者理解和应用 ESP32-WROOM-32E 开发板在实际项目中的应用场景。 总之,esp32-wroom-32e_devkitc 中文参考手册对 ESP32-WROOM-32E 开发板进行了全面而详尽的介绍,包括硬件和软件开发环境,编程语言和连接方式等。对于使用这款开发板的开发者来说,手册是一份非常宝贵的参考资料,可以帮助他们快速入门和顺利开展项目开发。 ### 回答3: ESP32-WROOM-32E DevKitC是一种基于ESP32-WROOM-32E模组的开发板,它集成了丰富的功能和接口,方便开发者进行硬件和软件开发。 这份中文参考手册为使用者提供了关于开发板硬件和软件方面的详细信息和指导。首先,手册介绍了开发板的硬件组成,包括主控芯片、存储器、引脚布局等。通过详细的图表和说明,使用者可以清楚了解各个组件的功能和连接方式。 接下来,手册介绍了开发板的软件开发环境搭建,包括开发工具的安装、驱动程序的配置等。使用者可以按照手册提供的步骤,轻松地搭建好开发环境,为后续的软件开发做好准备。 手册还提供了关于开发板的软件开发方法和示例代码。使用者可以了解如何使用ESP-IDF开发框架进行开发,并按照示例代码进行实验和测试。手册中还提供了丰富的代码注释和详细的参数说明,帮助使用者理解代码逻辑和功能实现。 此外,手册还包含了开发板的测试和调试方法,以及对常见问题的解答。这些信息可以帮助使用者在开发过程中遇到问题时迅速定位和解决,提高开发效率。 总而言之,ESP32-WROOM-32E DevKitC中文参考手册为使用者提供了全面的开发指南,包含了硬件和软件方面的详细信息和指导。使用者可以通过这份手册,快速上手开发,实现自己的创意和想法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值