嵌入式开发者社区

标题: 改写按键中断例程后,无法进入中断 [打印本页]

作者: bigrao    时间: 2017-5-7 17:39
标题: 改写按键中断例程后,无法进入中断
目前在编写一个音频处理方面程序,想要通过按键选择音频处理的模式。参考的是创龙的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);
        }
    }*/
}



作者: human    时间: 2017-5-8 11:30
先看看不能进入中断,是停在什么位置,判断一下可能是什么问题造成的
作者: bigrao    时间: 2017-5-9 09:39
human 发表于 2017-5-8 11:30
先看看不能进入中断,是停在什么位置,判断一下可能是什么问题造成的

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




欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) Powered by Discuz! X3.4