改写按键中断例程后,无法进入中断 - TMS320C6748 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 3759|回复: 2
打印 上一主题 下一主题

[已解决] 改写按键中断例程后,无法进入中断

[复制链接]

20

主题

48

帖子

211

积分

中级会员

Rank: 3Rank: 3

积分
211
跳转到指定楼层
楼主
发表于 2017-5-7 17:39:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
目前在编写一个音频处理方面程序,想要通过按键选择音频处理的模式。参考的是创龙的GPIO_KEY例程和AUDIO_LINE_IN例程。
具体做法是以LINE_IN例程为基础,将按键中断的代码融合进去,但是添加后发现一直进不去中断。主函数如下所示:
后来发现如果将下面标红的函数注释后就可以进入中断了,但是仔细查看了这两个函数,都是一些配置函数,不知道是什么原因导致进不去中断?
附件PDF是完整的main.c文件,对中断这一块不是很清楚,求指点。
int main(void)
{
    unsigned short parToSend;
    unsigned short parToLink;

    // 串口终端初始化 使用串口2
    //UARTStdioInit();

    //UARTPuts("\r\n ============Test Start===========.\r\n", -1);
        //UARTPuts("Welcome to StarterWare Audio_Line_In Demo application.\r\n\r\n", -1);
        //UARTPuts("This application loops back the input at LINE_IN of the EVM to the LINE_OUT of the EVM\r\n\r\n", -1);

        // I2C 模块引脚配置
    I2CPinMuxSetup(0);

    // McASP 引脚配置
    McASPPinMuxSetup();

    // 使能 EDMA3 PSC
    PSCModuleControl(SOC_PSC_0_REGS, HW_PSC_CC0, PSC_POWERDOMAIN_ALWAYS_ON,
                     PSC_MDCTL_NEXT_ENABLE);
    PSCModuleControl(SOC_PSC_0_REGS, HW_PSC_TC0, PSC_POWERDOMAIN_ALWAYS_ON,
                     PSC_MDCTL_NEXT_ENABLE);

    // 外设使能配置
    PSCInit();

    // GPIO 管脚复用配置
    GPIOBankPinMuxSet();

    // GPIO 管脚初始化
    GPIOBankPinInit();

    // DSP 中断初始化
    InterruptInit();

    // GPIO 管脚中断初始化
    GPIOBankPinInterruptInit();

    // 初始化 I2C 接口地址为 AIC31 的地址
    I2CSetup(SOC_I2C_0_REGS, I2C_SLAVE_CODEC_AIC31);
    I2CIntRegister(C674X_MASK_INT7, SYS_INT_I2C0_INT);

    // 初始化 AIC31 音频芯片
   InitAIC31I2S();


   // 初始化 McASP 为 EDMA 方式
   InitMcaspEdma();

   unsigned int i;

    // 主循环
    for(;;)
    {
            // 亦可以使用查询法查询中断状态

            if(Flag)
            {
                    // 核心板 LED
                    for(i=0x00FFFFF;i>0;i--);                          // 延时
                    GPIOPinWrite(SOC_GPIO_0_REGS, 109, GPIO_PIN_LOW);
                    GPIOPinWrite(SOC_GPIO_0_REGS, 110, GPIO_PIN_HIGH);

                    for(i=0x00FFFFF;i>0;i--);                          // 延时
                    GPIOPinWrite(SOC_GPIO_0_REGS, 109, GPIO_PIN_HIGH);
                    GPIOPinWrite(SOC_GPIO_0_REGS, 110, GPIO_PIN_LOW);
            }
    }



    // 主循环,当一个新的 buffer 接收完成后,lastFullRxBuf 将会在接收完成中断
    // 里更新。如果 lastFullRxBuf 与 lastSentTxBuf 不相等就会发送新的数据。
   /* while(1)
    {
        if(lastFullRxBuf != lastSentTxBuf)
        {
                // 标志将要设置的下一个要传输数据的链接 DAM 参数
            parToSend =  PAR_TX_START + (parOffTxToSend % NUM_PAR);
            parOffTxToSend = (parOffTxToSend + 1) % NUM_PAR;
            parToLink  = PAR_TX_START + parOffTxToSend;

            lastSentTxBuf = (lastSentTxBuf + 1) % NUM_BUF;

            // 复制 buffer
            memcpy((void *)txBufPtr[lastSentTxBuf],
                   (void *)rxBufPtr[lastFullRxBuf],
                   AUDIO_BUF_SIZE);

            // 设置相应的 DMA 参数用于发送数据
            BufferTxDMAActivate(lastSentTxBuf, NUM_SAMPLES_PER_AUDIO_BUF,
                                (unsigned short)parToSend,
                                (unsigned short)parToLink);
        }
    }*/
}


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

3

主题

852

帖子

3538

积分

创龙

Rank: 8Rank: 8

积分
3538
沙发
发表于 2017-5-8 11:30:15 | 只看该作者
先看看不能进入中断,是停在什么位置,判断一下可能是什么问题造成的
回复 支持 反对

使用道具 举报

20

主题

48

帖子

211

积分

中级会员

Rank: 3Rank: 3

积分
211
板凳
 楼主| 发表于 2017-5-9 09:39:32 | 只看该作者
human 发表于 2017-5-8 11:30
先看看不能进入中断,是停在什么位置,判断一下可能是什么问题造成的

经过调试,问题解决了,原来按键1和DMA都是用的可屏蔽中断5,把DMA的可屏蔽中断修改为6就可以了,多谢指点
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2024-5-20 21:59 , Processed in 0.037157 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表