LPUART eDMA in Zephyr RTOS

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

LPUART eDMA in Zephyr RTOS

544 次查看
NFRED
Contributor I

Hi all, I am currently working on a DMX driver, which runs using the LPUART driver. At the moment I am running in an issue with using the eDMA in Zephyr, where the interrupt never fires correctly and thus never sets the tx line back to idle state. 

I am mostly using the eDMA config from the lpuart_edma example. I am using Zephyr OS for scheduling but do to needing as little cpu cycles i want to use the nxp drivers directly.

Can anyone help? see software and screenshots below.

 

#include <zephyr/kernel.h>
#include <zephyr/irq.h>
#include <zephyr/device.h>
#include "../lpuart/fsl_lpuart_edma.h"
#include "../dmamux/fsl_dmamux.h"
#include "fsl_iomuxc.h"
#include "dmx.h"

#define LPDMX3LPUART3
#define LPUART_DMA_BASEADDR DMA0
#define LPUART_DMAMUX_BASEADDR DMAMUX
#define LPUART_TX_DMA_CHANNEL 0U
#define DMX_FRAME_SIZE512

static uint8_t dmx_tx_buffer[DMX_FRAME_SIZE] __attribute__((section(".nocache")));

lpuart_edma_handle_t g_lpuartEdmaHandle;
edma_handle_t g_lpuartTxEdmaHandle;
volatile bool txOnGoing = false;

void LPUART_UserCallback(LPUART_Type *base, lpuart_edma_handle_t *handle, status_t status, void *userData) {
if (status == kStatus_LPUART_TxIdle) {
txOnGoing = false;
    }
}

void lpuart3_tx_dma_irq_handler(const void *arg) {
EDMA_HandleIRQ((edma_handle_t *)arg);
}

void send_break(void){
LPDMX3->CTRL = 1<<13;
LPDMX3->CTRL = 1<<13;
LPDMX3->CTRL = 1<<13;
LPDMX3->CTRL = 1<<13;
}

void dmx_hal_init(void) {
lpuart_config_t config;
edma_config_t edmaConfig;

CLOCK_EnableClock(kCLOCK_Lpuart3);
IOMUXC_SetPinMux(IOMUXC_GPIO_AD_B1_06_LPUART3_TX, 0U);
IOMUXC_SetPinMux(IOMUXC_GPIO_AD_B1_07_LPUART3_RX, 0U);

LPUART_GetDefaultConfig(&config);
config.baudRate_Bps = 250000; // Standard DMX
config.stopBitCount = kLPUART_TwoStopBit;
LPUART_Init(LPDMX3, &config, CLOCK_GetFreq(kCLOCK_Lpuart3));

DMAMUX_Init(LPUART_DMAMUX_BASEADDR);
DMAMUX_SetSource(LPUART_DMAMUX_BASEADDR, LPUART_TX_DMA_CHANNEL, kDmaRequestMuxLPUART3Tx);
DMAMUX_EnableChannel(LPUART_DMAMUX_BASEADDR, LPUART_TX_DMA_CHANNEL);

EDMA_GetDefaultConfig(&edmaConfig);
EDMA_Init(LPUART_DMA_BASEADDR, &edmaConfig);
EDMA_CreateHandle(&g_lpuartTxEdmaHandle, LPUART_DMA_BASEADDR, LPUART_TX_DMA_CHANNEL);

LPUART_TransferCreateHandleEDMA(LPDMX3, &g_lpuartEdmaHandle, LPUART_UserCallback, NULL, &g_lpuartTxEdmaHandle, NULL);

IRQ_CONNECT(DMA0_DMA16_IRQn, 5, lpuart3_tx_dma_irq_handler, &g_lpuartTxEdmaHandle, 0);
irq_enable(DMA0_DMA16_IRQn);
}

void dmx_send_frame(const uint8_t *src_data) {
// if (txOnGoing) return;

memcpy(dmx_tx_buffer, src_data, DMX_FRAME_SIZE);


lpuart_transfer_t xfer = {
        .data = dmx_tx_buffer,
        .dataSize = DMX_FRAME_SIZE
    };

txOnGoing = true;
if (kStatus_Success != LPUART_SendEDMA(LPDMX3, &g_lpuartEdmaHandle, &xfer)) {
txOnGoing = false;
printk("DMA Transfer Failed!\n");
    }
}
Code ends up in 
 
 
(void)arch_irq_lock();
for (;;) {
        /* Spin endlessly * }
 
Thanks in advance
0 项奖励
回复
3 回复数

490 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

Hi @NFRED,

You did not specify the MCU part number.

In general, you should double‑check the LPUART eDMA interrupt configuration in both the modules and the NVIC.
It could be that instead of the ISR implemented in the project, an unimplemented ISR is firing, which would call the default ISR and result in a fatal error.

 

Regards,

Daniel

 

 

 

 

0 项奖励
回复

488 次查看
NFRED
Contributor I

Hi @danielmartynek 

 

Thanks for the reply! I am working on a MIMXRT1064.

I already thought something like a unimplemented ISR, since in the serial logger it says unhandles interrupt:0, but if I enabled that channel, it would just return a different channel.

0 项奖励
回复

441 次查看
Gavin_Jia
NXP TechSupport
NXP TechSupport

Hi @NFRED ,

Thanks for your interest in NXP MIMXRT series!

If you are using Zephyr, we recommend that your application also use the UART_Async_API. Mixing MCUXSDK and Zephyr implementations may cause issues; for example, certain DMA might be enabled by default in the Zephyr framework or reserved for other peripherals. Additionally, I’ve reviewed your code and noticed a few points that may require attention:

1. lpuartConfig.enableTx/Rx must be manually set to true;

2. For non-cached regions, it is best to use the Zephyr style:

CONFIG_NOCACHE_MEMORY=y
#define DMA_NOCACHE __nocache
static DMA_NOCACHE uint8_t rx_buf1[RX_BUF_SIZE];
 
3. Add handling for DMA_ERROR_IRQn to assist with troubleshooting.
 
 
Best regards,
Gavin
0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2333414%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3EZephyr%20%E5%AE%9E%E6%97%B6%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%E4%B8%AD%E7%9A%84%20LPUART%20eDMA%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2333414%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%A4%A7%E5%AE%B6%E5%A5%BD%EF%BC%8C%E6%88%91%E7%9B%AE%E5%89%8D%E6%AD%A3%E5%9C%A8%E5%BC%80%E5%8F%91%E4%B8%80%E4%B8%AA%20DMX%20%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%EF%BC%8C%E5%AE%83%E4%BD%BF%E7%94%A8%20LPUART%20%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%E8%BF%90%E8%A1%8C%E3%80%82%E7%9B%AE%E5%89%8D%EF%BC%8C%E6%88%91%E5%9C%A8%20Zephyr%20%E4%B8%AD%E4%BD%BF%E7%94%A8%20eDMA%20%E6%97%B6%E9%81%87%E5%88%B0%E4%BA%86%E9%97%AE%E9%A2%98%EF%BC%8C%E4%B8%AD%E6%96%AD%E6%B0%B8%E8%BF%9C%E6%97%A0%E6%B3%95%E6%AD%A3%E7%A1%AE%E8%A7%A6%E5%8F%91%EF%BC%8C%E5%9B%A0%E6%AD%A4%E6%B0%B8%E8%BF%9C%E4%B8%8D%E4%BC%9A%E5%B0%86%20tx%20%E7%BA%BF%E8%B7%AF%E8%AE%BE%E7%BD%AE%E5%9B%9E%20IDLE%E7%8A%B6%E6%80%81%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E4%B8%BB%E8%A6%81%E4%BD%BF%E7%94%A8%20lpuart_edma%20%E7%A4%BA%E4%BE%8B%E4%B8%AD%E7%9A%84%20eDMA%20%E9%85%8D%E7%BD%AE%E3%80%82%E6%88%91%E6%AD%A3%E5%9C%A8%E4%BD%BF%E7%94%A8%20Zephyr%20%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%E8%BF%9B%E8%A1%8C%E8%B0%83%E5%BA%A6%EF%BC%8C%E4%BD%86%E7%94%B1%E4%BA%8E%E9%9C%80%E8%A6%81%E5%B0%BD%E5%8F%AF%E8%83%BD%E5%B0%91%E7%9A%84%20CPU%20%E8%B5%84%E6%BA%90%EF%BC%8C%E6%88%91%E6%83%B3%E7%9B%B4%E6%8E%A5%E4%BD%BF%E7%94%A8%20nxp%20%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%E3%80%82%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%9C%89%E4%BA%BA%E8%83%BD%E5%B8%AE%E5%BF%99%E5%90%97%EF%BC%9F%E8%AF%B7%E5%8F%82%E9%98%85%E4%B8%8B%E9%9D%A2%E7%9A%84%E8%BD%AF%E4%BB%B6%E5%92%8C%E6%88%AA%E5%9B%BE%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CBLOCKQUOTE%3E%3CDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%3CZEPHYR%3E%3C%2FZEPHYR%3E%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%3CZEPHYR%3E%3C%2FZEPHYR%3E%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%3CZEPHYR%3E%3C%2FZEPHYR%3E%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%22..%2Flpuart%2Ffsl_lpuart_edma.h%22%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%22..%2Fdmamux%2Ffsl_dmamux.h%22%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%22fsl_iomuxc.h%22%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23include%3C%2FSPAN%3E%20%3CSPAN%3E%22dmx.h%22%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3ELPUART3%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3Elpuart_dma_baseaddr%3C%2FSPAN%3E%20%3CSPAN%3EDMA0%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3Elpuart_dmamux_baseaddr%3C%2FSPAN%3E%20%3CSPAN%3EDMAMUX%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3Elpuart_tx_dma_channel%3C%2FSPAN%3E%20%3CSPAN%3E0U%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3EDMX_FRAME_SIZE%3C%2FSPAN%3E%3CSPAN%3E512%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3E%E9%9D%99%E6%80%81%3C%2FSPAN%3E%20%3CSPAN%3Euint8_t%3C%2FSPAN%3E%20%3CSPAN%3Edmx_tx_buffer%3C%2FSPAN%3E%3CSPAN%3E%5B%3C%2FSPAN%3E%3CSPAN%3EDMX_FRAME_SIZE%3C%2FSPAN%3E%3CSPAN%3E%5D%20%3C%2FSPAN%3E%3CSPAN%3E__attribute__%3C%2FSPAN%3E%3CSPAN%3E((%3C%2FSPAN%3E%3CSPAN%3E%E6%AE%B5%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%22.nocache%22%3C%2FSPAN%3E%3CSPAN%3E)))%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Elpuart_edma_handle_t%3C%2FSPAN%3E%20%3CSPAN%3Eg_lpuartEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eedma_handle_t%3C%2FSPAN%3E%20%3CSPAN%3Eg_lpuartTxEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E6%98%93%E5%8F%98%3C%2FSPAN%3E%20%3CSPAN%3Ebool%3C%2FSPAN%3E%20%3CSPAN%3EtxOnGoing%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E%E5%81%87%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3ELPUART_UserCallback%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3ELPUART_Type%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3E%E5%9F%BA%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart_edma_handle_t%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3E%E5%8F%A5%E6%9F%84%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%E7%8A%B6%E6%80%81%3C%2FSPAN%3E%20%3CSPAN%3E%E7%8A%B6%E6%80%81%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3E%E7%94%A8%E6%88%B7%E6%95%B0%E6%8D%AE%3C%2FSPAN%3E%3CSPAN%3E)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Estatus%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3D%3C%2FSPAN%3E%20%3CSPAN%3EkStatus_LPUART_TxIdle%3C%2FSPAN%3E%3CSPAN%3E)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EtxOnGoing%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E%E5%81%87%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%26nbsp%3B%20%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3Elpuart3_tx_dma_irq_handler%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%E5%B8%B8%E9%87%8F%3C%2FSPAN%3E%20%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3Earg%3C%2FSPAN%3E%3CSPAN%3E)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EEDMA_HandleIRQ%3C%2FSPAN%3E%3CSPAN%3E((%3C%2FSPAN%3E%3CSPAN%3Eedma_handle_t%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3E)%3C%2FSPAN%3E%3CSPAN%3Earg%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3E%E6%97%A0%E6%95%88%3C%2FSPAN%3E%20%3CSPAN%3Esend_break%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%3CSPAN%3E)%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E-%26gt%3B%3C%2FSPAN%3E%3CSPAN%3ECTRL%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E1%3C%2FSPAN%3E%3CSPAN%3E%26lt%3B%26lt%3B%3C%2FSPAN%3E%3CSPAN%3E13%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E-%26gt%3B%3C%2FSPAN%3E%3CSPAN%3ECTRL%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E1%3C%2FSPAN%3E%3CSPAN%3E%26lt%3B%26lt%3B%3C%2FSPAN%3E%3CSPAN%3E13%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E-%26gt%3B%3C%2FSPAN%3E%3CSPAN%3ECTRL%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E1%3C%2FSPAN%3E%3CSPAN%3E%26lt%3B%26lt%3B%3C%2FSPAN%3E%3CSPAN%3E13%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E-%26gt%3B%3C%2FSPAN%3E%3CSPAN%3ECTRL%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E1%3C%2FSPAN%3E%3CSPAN%3E%26lt%3B%26lt%3B%3C%2FSPAN%3E%3CSPAN%3E13%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3Edmx_hal_init%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%3CSPAN%3E)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Elpuart_config_t%3C%2FSPAN%3E%20%3CSPAN%3E%E9%85%8D%E7%BD%AE%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eedma_config_t%3C%2FSPAN%3E%20%3CSPAN%3EedmaConfig%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3ECLOCK_EnableClock%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EkCLOCK_Lpuart3%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EIOMUXC_SetPinMux%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EIOMUXC_GPIO_AD_B1_06_LPUART3_TX%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E0U%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EIOMUXC_SetPinMux%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EIOMUXC_GPIO_AD_B1_07_LPUART3_RX%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E0U%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3ELPUART_GetDefaultConfig%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3E%E9%85%8D%E7%BD%AE%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E9%85%8D%E7%BD%AE%3C%2FSPAN%3E%3CSPAN%3E.%3C%2FSPAN%3E%3CSPAN%3E%E6%B3%A2%E7%89%B9%E7%8E%87%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E250000%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3CSPAN%3E%2F%2F%20%E6%A0%87%E5%87%86%20DMX%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E9%85%8D%E7%BD%AE%3C%2FSPAN%3E%3CSPAN%3E.%3C%2FSPAN%3E%3CSPAN%3EstopBitCount%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3EkLPUART_TwoStopBit%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3ELPUART_Init%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3E%E9%85%8D%E7%BD%AE%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3ECLOCK_GetFreq%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EkCLOCK_Lpuart3%3C%2FSPAN%3E%3CSPAN%3E))%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3EDMAMUX_Init%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Elpuart_dmamux_baseaddr%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EDMAMUX_SetSource%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Elpuart_dmamux_baseaddr%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart_tx_dma_channel%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3EkDmaRequestMuxLPUART3Tx%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EDMAMUX_EnableChannel%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Elpuart_dmamux_baseaddr%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart_tx_dma_channel%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3EEDMA_GetDefaultConfig%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3EedmaConfig%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EEDMA_Init%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Elpuart_dma_baseaddr%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3EedmaConfig%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EEDMA_CreateHandle%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Eg_lpuartTxEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart_dma_baseaddr%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart_tx_dma_channel%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3ELPUART_TransferCreateHandleEDMA%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Eg_lpuartEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3ELPUART_UserCallback%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Enull%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Eg_lpuartTxEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3ENULL%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3EIRQ_CONNECT%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EDMA0_DMA16_IRQn%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E5%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3Elpuart3_tx_dma_irq_handler%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Eg_lpuartTxEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E0%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eirq_enable%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EDMA0_DMA16_IRQn%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%20%3CSPAN%3Edmx_send_frame%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%E5%B8%B8%E9%87%8F%3C%2FSPAN%3E%20%3CSPAN%3Euint8_t%3C%2FSPAN%3E%20%3CSPAN%3E*%3C%2FSPAN%3E%3CSPAN%3E%E6%BA%90%E6%95%B0%E6%8D%AE%3C%2FSPAN%3E%3CSPAN%3E)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F%2F%20if%20(txOnGoing)%20return%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Ememcpy%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Edmx_tx_buffer%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%E6%BA%90%E6%95%B0%E6%8D%AE%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3EDMX_FRAME_SIZE%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3Elpuart_transfer_t%3C%2FSPAN%3E%20%3CSPAN%3Exfer%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%20%20%20%20%20%20%20%20.%3C%2FSPAN%3E%3CSPAN%3E%E6%95%B0%E6%8D%AE%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3Edmx_tx_buffer%3C%2FSPAN%3E%3CSPAN%3E%2C%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%20%20%20%20%20%20%20%20.%3C%2FSPAN%3E%3CSPAN%3E%E6%95%B0%E6%8D%AE%E5%A4%A7%E5%B0%8F%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3EDMX_FRAME_SIZE%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%20%20%20%20%7D%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CDIV%3E%3CSPAN%3EtxOnGoing%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3Etrue%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3EkStatus_Success%3C%2FSPAN%3E%20%3CSPAN%3E!%3D%3C%2FSPAN%3E%20%3CSPAN%3ELPUART_SendEDMA%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3ELPDMX3%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Eg_lpuartEdmaHandle%3C%2FSPAN%3E%3CSPAN%3E%2C%20%3C%2FSPAN%3E%3CSPAN%3E%26amp%3B%3C%2FSPAN%3E%3CSPAN%3Exfer%3C%2FSPAN%3E%3CSPAN%3E))%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EtxOnGoing%3C%2FSPAN%3E%20%3CSPAN%3E%3D%3C%2FSPAN%3E%20%3CSPAN%3E%E5%81%87%3C%2FSPAN%3E%3CSPAN%3E%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eprintk%3C%2FSPAN%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3E%22DMA%20%E4%BC%A0%E8%BE%93%E5%A4%B1%E8%B4%A5%EF%BC%81%3C%2FSPAN%3E%3CSPAN%3E%5Cn%3C%2FSPAN%3E%3CSPAN%3E%22%3C%2FSPAN%3E%3CSPAN%3E)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%26nbsp%3B%20%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3C%2FDIV%3E%3C%2FBLOCKQUOTE%3E%3CDIV%3E%3CDIV%3E%3CSPAN%3E%3CSPAN%3E%E4%BB%A3%E7%A0%81%E5%9C%A8%20%3C%2FSPAN%3E%3C%2FSPAN%3E%3CDIV%20class%3D%22%22%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%20class%3D%22%22%3E%26nbsp%3B%3C%2FDIV%3E%3CBLOCKQUOTE%3E%3CDIV%3E%3CDIV%3E%3CSPAN%3E(%3C%2FSPAN%3E%3CSPAN%3Evoid%3C%2FSPAN%3E%3CSPAN%3E)%3C%2FSPAN%3E%3CSPAN%3Earch_irq_lock%3C%2FSPAN%3E%3CSPAN%3E()%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E4%B8%BA%3C%2FSPAN%3E%3CSPAN%3E(%3B%3B)%20%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%20%20%20%20%20%20%20%20%2F*%20%E6%97%A0%E4%BC%91%E6%AD%A2%E5%9C%B0%E6%97%8B%E8%BD%AC%20*%20%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3C%2FDIV%3E%3C%2FBLOCKQUOTE%3E%3CDIV%3E%3CDIV%3E%3CSPAN%3E%E9%A2%84%E5%85%88%E8%87%B4%E8%B0%A2%3C%2FSPAN%3E%3C%2FDIV%3E%3C%2FDIV%3E%3C%2FDIV%3E%3C%2FDIV%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2334560%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20LPUART%20eDMA%20in%20Zephyr%20RTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2334560%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F160001%22%20target%3D%22_blank%22%3E%40%E4%B8%B9%E5%B0%BC%E5%B0%94-%E9%A9%AC%E8%92%82%E5%86%85%E5%85%8B%3C%2FA%3E%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E6%84%9F%E8%B0%A2%E6%82%A8%E7%9A%84%E5%9B%9E%E5%A4%8D%EF%BC%81%E6%88%91%E6%AD%A3%E5%9C%A8%E7%A0%94%E7%A9%B6%20MIMXRT1064%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E5%B7%B2%E7%BB%8F%E6%83%B3%E5%88%B0%E4%BA%86%E7%B1%BB%E4%BC%BC%E4%BA%8E%E6%9C%AA%E5%AE%9E%E7%8E%B0%20ISR%20%E7%9A%84%E9%97%AE%E9%A2%98%EF%BC%8C%E5%9B%A0%E4%B8%BA%E4%B8%B2%E8%A1%8C%E8%AE%B0%E5%BD%95%E5%99%A8%E4%B8%AD%E5%86%99%E7%9D%80%20unhandles%20interrupt%3A0%EF%BC%8C%E4%BD%86%E5%A6%82%E6%9E%9C%E6%88%91%E5%90%AF%E7%94%A8%E8%AF%A5%E9%80%9A%E9%81%93%EF%BC%8C%E5%AE%83%E5%8F%AA%E4%BC%9A%E8%BF%94%E5%9B%9E%E4%B8%80%E4%B8%AA%E4%B8%8D%E5%90%8C%E7%9A%84%E9%80%9A%E9%81%93%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2334551%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20LPUART%20eDMA%20in%20Zephyr%20RTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2334551%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%97%A8%EF%BC%8C%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F260737%22%20target%3D%22_blank%22%3E%40NFRED%3C%2FA%3E%E3%80%81%3C%2FP%3E%0A%3CP%3E%E6%82%A8%E6%B2%A1%E6%9C%89%E6%8C%87%E5%AE%9A%20MCU%20%E9%83%A8%E4%BB%B6%E5%8F%B7%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%B8%80%E8%88%AC%E6%9D%A5%E8%AF%B4%EF%BC%8C%E5%BA%94%E4%BB%94%E7%BB%86%E6%A3%80%E6%9F%A5%E6%A8%A1%E5%9D%97%E5%92%8C%20NVIC%20%E4%B8%AD%E7%9A%84%20LPUART%20eDMA%20%E4%B8%AD%E6%96%AD%E9%85%8D%E7%BD%AE%E3%80%82%3CBR%20%2F%3E%E5%8F%AF%E8%83%BD%E4%B8%8D%E6%98%AF%E9%A1%B9%E7%9B%AE%E4%B8%AD%E6%89%A7%E8%A1%8C%E7%9A%84%20ISR%EF%BC%8C%E8%80%8C%E6%98%AF%E4%B8%80%E4%B8%AA%E6%9C%AA%E6%89%A7%E8%A1%8C%E7%9A%84%20ISR%20%E6%AD%A3%E5%9C%A8%E5%90%AF%E5%8A%A8%EF%BC%8C%E8%BF%99%E4%BC%9A%E8%B0%83%E7%94%A8%E9%BB%98%E8%AE%A4%20ISR%20%E5%B9%B6%E5%AF%BC%E8%87%B4%E8%87%B4%E5%91%BD%E9%94%99%E8%AF%AF%E3%80%82%3C%2FP%3E%0A%3CBR%20%2F%3E%0A%3CP%3E%E6%AD%A4%E8%87%B4%EF%BC%8C%3C%2FP%3E%0A%3CP%3E%E4%B8%B9%E5%B0%BC%E5%B0%94%3C%2FP%3E%0A%3CBR%20%2F%3E%0A%3CBR%20%2F%3E%0A%3CBR%20%2F%3E%0A%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2336343%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20LPUART%20eDMA%20in%20Zephyr%20RTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2336343%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F260737%22%20target%3D%22_blank%22%3E%40NFRED%3C%2FA%3E%E3%80%81%3C%2FP%3E%0A%3CP%3E%E6%84%9F%E8%B0%A2%E6%82%A8%E5%AF%B9%20NXP%20MIMXRT%20%E7%B3%BB%E5%88%97%E7%9A%84%E5%85%B3%E6%B3%A8%EF%BC%81%3C%2FP%3E%0A%3CP%3E%E5%A6%82%E6%9E%9C%E4%BD%BF%E7%94%A8%20Zephyr%EF%BC%8C%E6%88%91%E4%BB%AC%E5%BB%BA%E8%AE%AE%E6%82%A8%E7%9A%84%E5%BA%94%E7%94%A8%E7%A8%8B%E5%BA%8F%E4%B9%9F%E4%BD%BF%E7%94%A8%20UART_Async_API%E3%80%82%E6%B7%B7%E5%90%88%E4%BD%BF%E7%94%A8%20MCUXSDK%20%E5%92%8C%20Zephyr%20%E5%AE%9E%E7%8E%B0%E5%8F%AF%E8%83%BD%E4%BC%9A%E5%AF%BC%E8%87%B4%E9%97%AE%E9%A2%98%EF%BC%9B%E4%BE%8B%E5%A6%82%EF%BC%8C%E6%9F%90%E4%BA%9B%20DMA%20%E5%8F%AF%E8%83%BD%E5%9C%A8%20Zephyr%20%E6%A1%86%E6%9E%B6%E4%B8%AD%E9%BB%98%E8%AE%A4%E5%90%AF%E7%94%A8%EF%BC%8C%E6%88%96%E4%B8%BA%E5%85%B6%E4%BB%96%E5%A4%96%E8%AE%BE%E4%BF%9D%E7%95%99%E3%80%82%E6%AD%A4%E5%A4%96%EF%BC%8C%E6%88%91%E6%9F%A5%E7%9C%8B%E4%BA%86%E6%82%A8%E7%9A%84%E4%BB%A3%E7%A0%81%EF%BC%8C%E5%8F%91%E7%8E%B0%E6%9C%89%E5%87%A0%E7%82%B9%E5%8F%AF%E8%83%BD%E9%9C%80%E8%A6%81%E6%B3%A8%E6%84%8F%EF%BC%9A%3C%2FP%3E%0A%3CP%3ElpuartConfig.enableTx%2FRx%20%E5%BF%85%E9%A1%BB%E6%89%8B%E5%8A%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA%20true%EF%BC%9B%3C%2FP%3E%0A%3CP%3E2.%E5%AF%B9%E4%BA%8E%E9%9D%9E%E7%BC%93%E5%AD%98%E5%8C%BA%E5%9F%9F%EF%BC%8C%E6%9C%80%E5%A5%BD%E4%BD%BF%E7%94%A8%20Zephyr%20%E9%A3%8E%E6%A0%BC%EF%BC%9A%3C%2FP%3E%0A%3CDIV%3E%0A%3CDIV%3E%3CSPAN%3Econfig_nocache_memory%3C%2FSPAN%3E%3CSPAN%3E%3Dy%3C%2FSPAN%3E%3C%2FDIV%3E%0A%3C%2FDIV%3E%0A%3CDIV%3E%0A%3CDIV%3E%3CSPAN%3E%23define%3C%2FSPAN%3E%20%3CSPAN%3EDMA_NOCACHE%3C%2FSPAN%3E%20%3CSPAN%3E__nocache%3C%2FSPAN%3E%3C%2FDIV%3E%0A%3CDIV%3E%0A%3CDIV%3E%3CSPAN%3E%E9%9D%99%E6%80%81%3C%2FSPAN%3E%20%3CSPAN%3EDMA_NOCACHE%3C%2FSPAN%3E%20%3CSPAN%3Euint8_t%3C%2FSPAN%3E%20%3CSPAN%3Erx_buf1%3C%2FSPAN%3E%3CSPAN%3E%5B%3C%2FSPAN%3E%3CSPAN%3ERX_BUF_SIZE%3C%2FSPAN%3E%3CSPAN%3E%5D%3B%3C%2FSPAN%3E%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%0A%3CDIV%3E3.%E5%A2%9E%E5%8A%A0%E5%AF%B9%20DMA_ERROR_IRQn%20%E7%9A%84%E5%A4%84%E7%90%86%EF%BC%8C%E4%BB%A5%E5%B8%AE%E5%8A%A9%E6%8E%92%E9%99%A4%E6%95%85%E9%9A%9C%E3%80%82%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%0A%3CDIV%3E%E6%88%91%E5%8F%91%E7%8E%B0%E6%9C%89%E4%B8%80%E4%B8%AA%E5%B8%96%E5%AD%90%E5%8F%AF%E8%83%BD%E4%BC%9A%E6%9C%89%E6%89%80%E5%B8%AE%E5%8A%A9%E3%80%82%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-RT-Crossover-MCUs%2FLPUART-eDMA-Efficient-asynch-reception-of-bursty-data-with-DMA%2Fm-p%2F1642814%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-RT-Crossover-MCUs%2FLPUART-eDMA-Efficient-asynch-reception-of-bursty-data-with-DMA%2Fm-p%2F1642814%3C%2FA%3E%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%0A%3CDIV%3E%E8%87%B4%E4%BB%A5%E6%9C%80%E8%AF%9A%E6%8C%9A%E7%9A%84%E9%97%AE%E5%80%99%EF%BC%8C%3CBR%20%2F%3EGavin%3C%2FDIV%3E%0A%3C%2FDIV%3E%0A%3C%2FDIV%3E%3C%2FLINGO-BODY%3E