杰理AD14N/AD15N---串口中断问题

由于AD15的SDK中,uart_dev.c文件中没有串口中断的demo,所以之前的项目一直用read的方式去读串口数据,但是这种读的方式是阻塞的方式,所以不太好用,今天做了个项目,也要用到串口,于是又研究了以下AD15的串口中断问题,摸索了下调通了代码如下:


#include "app_config.h"
#include "includes.h"
#include "asm/power_interface.h"
#include "asm/power/p33.h"
#include "cpu.h"
#include "uart_dev.h"

#define LOG_TAG_CONST       NORM
#define LOG_TAG             "[uart]"
#include "debug.h"

#if 1
#include "typedef.h"
#define DMA_BUF_LEN2			64



static u8 tmp_buf[DMA_BUF_LEN2] = {0};
static u8 usr_uart_buf[DMA_BUF_LEN2] __attribute__((aligned(4)));
static const uart_bus_t *ut0 = NULL;
extern const uart_bus_t *uart_dev_open(const struct uart_platform_data_t *arg);
void usr_uart_recieve(u8*data,u16 len);

static void usr_uart_isr_hook(void *arg, u32 status)
{
    const uart_bus_t *ubus = arg;

    if (status == UT_RX_OT) {
        u32 len = ubus->read(tmp_buf, 64, 0);
        if (len != 0) {
            usr_uart_recieve(tmp_buf,len);
           // log_info("uart_rx_ot len : %d", len);
           // log_info_hexdump(tmp_buf, len);
        }
    }
}

static int uart_dev_init(const uart_bus_t *ut)
{
    memset((void *)usr_uart_buf, 0, sizeof(usr_uart_buf));
    struct uart_platform_data_t arg;
    arg.tx_pin = IO_PORTA_06;
    arg.rx_pin = IO_PORTA_07;
    arg.rx_cbuf = usr_uart_buf;
    arg.rx_cbuf_size = 64;//
    arg.frame_length = 64;//
    arg.rx_timeout = 20;
    arg.isr_cbfun = usr_uart_isr_hook;
    arg.argv = JL_UT0;
    arg.is_9bit = 0;
    arg.baud = 115200;
    ut = uart_dev_open(&arg);
    if (NULL != ut) {
        return 0;
    } else {
        return -1;
    }
}

void usr_uart_init(void)
{
    if (0 != uart_dev_init(ut0)) {
        log_info("######uart_usr init fail!\n");
        return;
    }
}


static void UT0_putbyte(char a)
{
    if (JL_UT0->CON & BIT(0)) {
        JL_UT0->BUF = a;
        __asm__ volatile("csync");
        if ((JL_UT0->CON & BIT(2)) == 0) {
            while ((JL_UT0->CON & BIT(15)) == 0);
            JL_UT0->CON |= BIT(13);
        }
    }
}

void usr_uart_send(u8* data,u16 len)///串口1发送函数
{
    u16 i=0;
    for (i = 0; i < len; i ++) {
        UT0_putbyte(*(data + i));
    }
}

void usr_uart_recieve(u8*data,u16 len)///串口1接收回调函数
{
    log_info("uart_recieve_len: %d\n",len);
    log_info_hexdump(data, len);
}






#endif

工程中需要包含uart_dev.c

另外要注意串口0不支持DMA,串口1可支持DMA.

方案开发,技术交流可联系微信:life5270

<think>好的,我需要帮助用户了解杰理AD14N芯片如何播放音乐。首先,我要整理用户提供的参考信息,看看有哪些关键点需要注意。 根据引用[2],AD14N属于内部没有FLASH的A0芯片,必须外接一个FLASH来存储代码和资源。而音乐文件可能需要另一个外置FLASH来存放,特别是音频资源。引用[1]提到外置Flash烧录音乐文件的步骤,包括确定SPI Flash接线、使用工具进行烧录。引用[3]则说明支持WAV格式,但文件太大,可能需要转换或压缩。 接下来,用户的问题是关于使用方法,所以步骤需要详细但清晰。首先可能需要硬件连接,比如SPI Flash的接线,然后准备音乐文件,确保格式正确,再使用烧录工具将文件写入Flash。最后是代码层面的配置,比如初始化驱动和调用播放接口。 还要注意文件系统的支持,因为音乐文件存储在Flash中,可能需要特定的文件系统格式,比如FAT32。另外,代码部分可能需要初始化音频模块和文件系统,然后读取文件进行播放。 相关问题部分需要围绕用户可能遇到的后续问题展开,比如支持的音频格式、烧录失败怎么办、如何优化音质、降低功耗以及多文件管理等。 最后,确保所有步骤符合引用中的信息,并且用中文清晰表达,使用正确的LaTeX格式,如行内公式用$...$,独立公式用$$...$$。同时检查引用标注的位置是否合适,比如在提到外置Flash时添加[^1][^2],在文件格式时添加[^3]。</think>### 杰理AD14N芯片播放音乐的使用方法 #### 1. **硬件准备** - **芯片型号确认**:AD14N属于A0系列芯片,需外接SPI Flash存储代码和资源文件[^2]。 - **SPI Flash接线**:确保SPI Flash与芯片的CLK、MISO、MOSI、CS引脚正确连接(参考原理图)。 - **音频输出配置**:连接DAC或PWM音频输出模块至扬声器。 #### 2. **音乐文件准备** - **格式要求**:支持WAV格式,但需注意文件体积较大。建议采样率44.1kHz、16位量化位数。 - **文件转换**:若使用其他格式(如MP3),需转换为芯片支持的格式或集成解码库。 - **文件系统**:将音乐文件存储至外置Flash的指定分区(通常需格式化为FAT32)。 #### 3. **烧录音乐文件** - **工具选择**:使用杰理提供的烧录工具(如JL_Flash_Tool)将音乐文件写入外置Flash。 - **烧录步骤**: 1. 连接芯片的调试接口(如UART或USB)。 2. 配置烧录工具,选择目标Flash地址和文件。 3. 执行烧录并校验数据完整性。 #### 4. **软件开发** - **驱动初始化**: ```c // 初始化SPI Flash驱动 spi_flash_init(); // 初始化音频解码模块 audio_decoder_init(); ``` - **文件读取与播放**: ```c // 打开音乐文件 FILE *fp = fopen("/flash/music.wav", "rb"); // 读取数据并送入音频缓冲区 while (!feof(fp)) { fread(audio_buffer, sizeof(uint16_t), BUFFER_SIZE, fp); audio_play(audio_buffer, BUFFER_SIZE); } fclose(fp); ``` #### 5. **关键配置** - **内存管理**:外置Flash需划分代码区与资源区,避免地址冲突[^2]。 - **实时性优化**:通过DMA传输减少CPU占用,确保音频流畅。 --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jim天河

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值