我在 ADSP-SC584 上的 MDMA 传输有问题。我在 CCES IDE 2.8.3 工作
我以 MDMA CrossCore 示例项目为例,对数据流的 ARM 方向进行了更改。所以初始化是一样的(MCAPI地址和中断的SID)。
我有一个复杂的问题:
当我使用 ICE-1000 运行调试项目,并使用 MDMA 运行 DSP 内核发送数据时,ARM 内核不会触发。但是当我逐步执行 MDMA 发送 ARM 内核触发器时,我可以在 DDR ARM 区域缓冲区等中看到数据
当我最终运行两个内核时,我得到了ard fault错误
未注册处理程序时引发 ID (IID) 0x7fffffff 的启用中断。
在 DSP 项目中打开 MDMA:
ADI_DMA_RESULT eResult = ADI_DMA_SUCCESS;
//*************************************************************************
// Open MDMA channel
//*************************************************************************
DBG_MSG ( "Core1: Opening MDMA channel\n");
eResult = adi_mdma_Open (MEMCOPY_STREAM_ID, &MemDmaStreamMem[0],
&hMemDmaStream, &hSrcDmaChannel, &hDestDmaChannel,
NULL,
NULL);
if (eResult != ADI_DMA_SUCCESS)
{
DBG_MSG ("Failed to open MDMA stream, Error Code: 0x%08X\n",
eResult);
return ARM_LINK_ERROR;
}
//*************************************************************************
// Configure MDMA channel
//*************************************************************************
adi_mdma_EnableChannelInterrupt (hDestDmaChannel, false, false); // Disable the MDMA destination transfer complete interrupt
adi_mdma_GetChannelSID (hDestDmaChannel, &nSid_SHARC1_Master); // Get the channel SID for the MDMA destination complete interrupt
/*add sharc int offset*/
//adi_sec_SetPriority(nSid_SHARC1_Master,ADI_SEC_MAX_INT_PRIO);
nSid_SHARC1_Master += SHARC_INT_OFFSET;
//adi_sec_SetCoreID (nSid_SHARC1_Master, ADI_SEC_CORE_0);
adi_mdma_EnableChannelInterrupt (hSrcDmaChannel, true, true); // Enable the MDMA source transfer complete interrupt
DBG_MSG ( "\n Destination Channel interrupt SID: \t%08X\n ",
(unsigned int) nSid_SHARC1_Master);
#if 1
eResult = adi_dma_UpdateCallback (hSrcDmaChannel, MemDmaCallback, hMemDmaStream); // Register source transfer complete interrupt
/* IF (Failure) */
if (eResult != ADI_DMA_SUCCESS)
{
DBG_MSG ("Failed to set DMA callback, Error Code: 0x%08X\n",eResult);
return ARM_LINK_ERROR;
}
#endif
在 ARM 从站上安装中断:
adi_int_InstallHandler (nSID_SHARC_Master, DataTransferFromSHARCComplete, NULL, true);
我可以看到 MCAPI 向我发送了正确的中断 SID(带有 ARM 的偏移量)
使用 RTOS 在 ARM 上回调:
void DataTransferFromSHARCComplete(uint32_t SID, void *pCBParam)
{
// Save the CPU registers
CPU_SR_ALLOC();
// Protect a critical section
CPU_CRITICAL_ENTER();
// Make the kernel aware that
// the interrupt has started
OSIntEnter();
CPU_CRITICAL_EXIT();
// Handle the interrupt
static uint32_t test=0;
test= BufferFromSHARC1[0];
BufferFromSHARC1[0]=0;
// Make the kernel aware that
// the interrupt has ended
OSIntExit();
}
我需要通过 UDP 将从 DSP 获得的数据发送到 PC。UDP 发送独立工作,DMA 传输独立工作,但在一起我总是得到 0x7fffffff IID 错误。