mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
176 lines
5.6 KiB
C
176 lines
5.6 KiB
C
/*********************************************************************************************************************
|
||
* COPYRIGHT NOTICE
|
||
* Copyright (c) 2020,<2C><><EFBFBD>ɿƼ<C9BF>
|
||
* All rights reserved.
|
||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>QQȺ<51><C8BA><EFBFBD><EFBFBD>Ⱥ<EFBFBD><C8BA>824575535
|
||
*
|
||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݰ<EFBFBD>Ȩ<EFBFBD><C8A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɿƼ<C9BF><C6BC><EFBFBD><EFBFBD>У<EFBFBD>δ<EFBFBD><CEB4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ҵ<EFBFBD><D2B5>;<EFBFBD><CDBE>
|
||
* <20><>ӭ<EFBFBD><D3AD>λʹ<CEBB>ò<EFBFBD><C3B2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><DEB8><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD>뱣<EFBFBD><EBB1A3><EFBFBD><EFBFBD><EFBFBD>ɿƼ<C9BF><C6BC>İ<EFBFBD>Ȩ<EFBFBD><C8A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
*
|
||
* @file eru_dma
|
||
* @company <09>ɶ<EFBFBD><C9B6><EFBFBD><EFBFBD>ɿƼ<C9BF><C6BC><EFBFBD><EFBFBD><EFBFBD>˾
|
||
* @author <09><><EFBFBD>ɿƼ<C9BF>(QQ3184284598)
|
||
* @version <09>鿴doc<6F><63>version<6F>ļ<EFBFBD> <20>汾˵<E6B1BE><CBB5>
|
||
* @Software ADS v1.2.2
|
||
* @Target core TC264D
|
||
* @Taobao https://seekfree.taobao.com/
|
||
* @date 2020-3-23
|
||
********************************************************************************************************************/
|
||
|
||
|
||
#include "IfxDma_Dma.h"
|
||
#include "IfxScuEru.h"
|
||
#include "isr_config.h"
|
||
#include "zf_assert.h"
|
||
#include "zf_eru_dma.h"
|
||
|
||
|
||
typedef struct
|
||
{
|
||
Ifx_DMA_CH linked_list[8];//DMA<4D><41><EFBFBD><EFBFBD>
|
||
IfxDma_Dma_Channel channel; //DMAͨ<41><CDA8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
}DMA_LINK;
|
||
|
||
#if(0 == ERU_DMA_INT_SERVICE)
|
||
#pragma section all "cpu0_dsram"
|
||
IFX_ALIGN(256) DMA_LINK dma_link_list;
|
||
|
||
#elif(1 == ERU_DMA_INT_SERVICE)
|
||
#pragma section all "cpu1_dsram"
|
||
IFX_ALIGN(256) DMA_LINK dma_link_list;
|
||
|
||
#endif
|
||
#pragma section all restore
|
||
|
||
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
// @brief eru<72><75><EFBFBD><EFBFBD>dma<6D><61>ʼ<EFBFBD><CABC>
|
||
// @param dma_ch ѡ<><D1A1>DMAͨ<41><CDA8>
|
||
// @param source_addr <20><><EFBFBD><EFBFBD>Դ<EFBFBD><D4B4>ַ
|
||
// @param destination_addr <20><><EFBFBD><EFBFBD>Ŀ<EFBFBD>ĵ<EFBFBD>ַ
|
||
// @param eru_pin <09><><EFBFBD>ô<EFBFBD><C3B4><EFBFBD><EFBFBD><EFBFBD>eruͨ<75><CDA8>
|
||
// @param trigger <09><><EFBFBD>ô<EFBFBD><C3B4><EFBFBD><EFBFBD><EFBFBD>ʽ
|
||
// @param dma_count <09><><EFBFBD><EFBFBD>dma<6D><61><EFBFBD>ƴ<EFBFBD><C6B4><EFBFBD>
|
||
// @return void
|
||
// Sample usage:
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
uint8 eru_dma_init(IfxDma_ChannelId dma_ch, uint8 *source_addr, uint8 *destination_addr, ERU_PIN_enum eru_pin, TRIGGER_enum trigger, uint16 dma_count)
|
||
{
|
||
IfxDma_Dma_Channel dmaChn;
|
||
//eru<72><75><EFBFBD><EFBFBD>DMAͨ<41><CDA8><EFBFBD><EFBFBD> <20><>eru<72>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>eru<72><75><EFBFBD><EFBFBD><EFBFBD>ȼ<EFBFBD><C8BC><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8>
|
||
eru_init(eru_pin, trigger);
|
||
|
||
IfxDma_Dma_Config dmaConfig;
|
||
IfxDma_Dma_initModuleConfig(&dmaConfig, &MODULE_DMA);
|
||
|
||
IfxDma_Dma dma;
|
||
IfxDma_Dma_initModule(&dma, &dmaConfig);
|
||
|
||
IfxDma_Dma_ChannelConfig cfg;
|
||
IfxDma_Dma_initChannelConfig(&cfg, &dma);
|
||
|
||
uint8 list_num, i;
|
||
uint16 single_channel_dma_count;
|
||
|
||
ZF_ASSERT(!(dma_count%8));//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ8<CEAA>ı<EFBFBD><C4B1><EFBFBD>
|
||
|
||
|
||
list_num = 1;
|
||
single_channel_dma_count = dma_count / list_num;
|
||
if(16384 < single_channel_dma_count)
|
||
{
|
||
while(TRUE)
|
||
{
|
||
single_channel_dma_count = dma_count / list_num;
|
||
if((single_channel_dma_count <= 16384) && !(dma_count % list_num))
|
||
{
|
||
break;
|
||
}
|
||
list_num++;
|
||
if(list_num > 8) ZF_ASSERT(FALSE);
|
||
}
|
||
}
|
||
|
||
|
||
if(1 == list_num)
|
||
{
|
||
cfg.shadowControl = IfxDma_ChannelShadow_none;
|
||
cfg.operationMode = IfxDma_ChannelOperationMode_single;
|
||
cfg.shadowAddress = 0;
|
||
}
|
||
else
|
||
{
|
||
cfg.shadowControl = IfxDma_ChannelShadow_linkedList;
|
||
cfg.operationMode = IfxDma_ChannelOperationMode_continuous;
|
||
cfg.shadowAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), (unsigned)&dma_link_list.linked_list[1]);
|
||
}
|
||
|
||
cfg.requestMode = IfxDma_ChannelRequestMode_oneTransferPerRequest;
|
||
cfg.moveSize = IfxDma_ChannelMoveSize_8bit;
|
||
cfg.busPriority = IfxDma_ChannelBusPriority_high;
|
||
|
||
cfg.sourceAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), source_addr);
|
||
cfg.sourceAddressCircularRange = IfxDma_ChannelIncrementCircular_none;
|
||
cfg.sourceCircularBufferEnabled = TRUE;
|
||
|
||
cfg.destinationAddressIncrementStep = IfxDma_ChannelIncrementStep_1;
|
||
|
||
cfg.channelId = (IfxDma_ChannelId)dma_ch;
|
||
cfg.hardwareRequestEnabled = FALSE;
|
||
cfg.channelInterruptEnabled = TRUE;
|
||
cfg.channelInterruptPriority = ERU_DMA_INT_PRIO;
|
||
cfg.channelInterruptTypeOfService = ERU_DMA_INT_SERVICE;
|
||
|
||
|
||
|
||
cfg.destinationAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), destination_addr);
|
||
|
||
cfg.transferCount = single_channel_dma_count;
|
||
|
||
IfxDma_Dma_initChannel(&dmaChn, &cfg);
|
||
|
||
if(1 < list_num)
|
||
{
|
||
i = 0;
|
||
while(i < list_num)
|
||
{
|
||
cfg.destinationAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), destination_addr + single_channel_dma_count * i);
|
||
if(i == (list_num - 1)) cfg.shadowAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), (unsigned)&dma_link_list.linked_list[0]);
|
||
else cfg.shadowAddress = IFXCPU_GLB_ADDR_DSPR(IfxCpu_getCoreId(), (unsigned)&dma_link_list.linked_list[i+1]);
|
||
cfg.transferCount = single_channel_dma_count;
|
||
|
||
IfxDma_Dma_initLinkedListEntry((void *)&dma_link_list.linked_list[i], &cfg);
|
||
i++;
|
||
}
|
||
}
|
||
|
||
|
||
IfxDma_Dma_getSrcPointer(&dma_link_list.channel)->B.CLRR = 1;
|
||
|
||
return list_num;
|
||
}
|
||
|
||
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
// @brief dmaֹͣ
|
||
// @param dma_ch ѡ<><D1A1>DMAͨ<41><CDA8>
|
||
// @return void
|
||
// Sample usage:
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
void dma_stop(IfxDma_ChannelId dma_ch)
|
||
{
|
||
IfxDma_disableChannelTransaction(&MODULE_DMA, dma_ch);
|
||
}
|
||
|
||
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
// @brief dma<6D><61><EFBFBD><EFBFBD>
|
||
// @param dma_ch ѡ<><D1A1>DMAͨ<41><CDA8>
|
||
// @return void
|
||
// Sample usage:
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
void dma_start(IfxDma_ChannelId dma_ch)
|
||
{
|
||
IfxDma_enableChannelTransaction(&MODULE_DMA, dma_ch);
|
||
}
|