LPC55S69 DMA Channel Chain Example

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

LPC55S69 DMA Channel Chain Example

跳至解决方案
2,045 次查看
andrew_lonsdale
Contributor II

I have been trying to understand how to configure the InputMux to chain DMA's using the DMA Channel Chain Example, and I have come to the conclusion that the example doesn't quite do what it says in the readme.txt.

The original configuration for the input mux is:

#define DEMO_DMA_CHANNEL_TRIGGER_INPUT0 kINPUTMUX_Otrig0ToDma0
#define DEMO_DMA_CHANNEL_TRIGGER_OUTPUT0 kINPUTMUX_Dma0Hash0TxTrigoutToTriginChannels

    INPUTMUX_Init(INPUTMUX);
    INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL2, DEMO_DMA_CHANNEL_TRIGGER_INPUT0);
    INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL1, DEMO_DMA_CHANNEL_TRIGGER_INPUT0);
    INPUTMUX_AttachSignal(INPUTMUX, 0, DEMO_DMA_CHANNEL_TRIGGER_OUTPUT0);
    INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL0, DEMO_DMA_CHANNEL_TRIGGER_INPUT0);

I think that the completion of DMA channel 0 triggers DMA channels 1, 2 and the second transfer of DMA channel 0, rather than the completion of DMA channel1 causing the second descriptor of DMA channel 0 to execute (as suggested in the readme).

I have changed the inputmux configuration as follows:


#define DEMO_DMA_CHANNEL1 1
#define DEMO_DMA_CHANNEL0 0
#define DEMO_DMA_CHANNEL2 2
#define DEMO_DMA_CHANNEL_TRIGGER_INPUT0 kINPUTMUX_Otrig0ToDma0
#define DEMO_DMA_CHANNEL_TRIGGER_INPUT1 kINPUTMUX_Otrig1ToDma0
#define OTRIG0 0
#define OTRIG0 1
#define DEMO_DMA_CHANNEL_TRIGGER_OUTPUT0 ((DMA0_OTRIG_INMUX0 << PMUX_SHIFT) + DEMO_DMA_CHANNEL0)
#define DEMO_DMA_CHANNEL_TRIGGER_OUTPUT1 ((DMA0_OTRIG_INMUX0 << PMUX_SHIFT) + DEMO_DMA_CHANNEL1)

INPUTMUX_Init(INPUTMUX);
INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL2, DEMO_DMA_CHANNEL_TRIGGER_INPUT0);
INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL1, DEMO_DMA_CHANNEL_TRIGGER_INPUT0);
INPUTMUX_AttachSignal(INPUTMUX, OTRIG0, DEMO_DMA_CHANNEL_TRIGGER_OUTPUT0);
INPUTMUX_AttachSignal(INPUTMUX, OTRIG1, DEMO_DMA_CHANNEL_TRIGGER_OUTPUT1);
INPUTMUX_AttachSignal(INPUTMUX, DEMO_DMA_CHANNEL0, DEMO_DMA_CHANNEL_TRIGGER_INPUT1);

I think this more clearly shows how to configure the example as per the readme. If I have it wrong, please comment.

Hope this helps someone.

Charles

标签 (1)
0 项奖励
回复
1 解答
1,856 次查看
Alice_Yang
NXP TechSupport
NXP TechSupport

Hello Charles Lonsdale,

Thanks for your sharing, I agree with you.

BR

Alice

在原帖中查看解决方案

0 项奖励
回复
2 回复数
1,857 次查看
Alice_Yang
NXP TechSupport
NXP TechSupport

Hello Charles Lonsdale,

Thanks for your sharing, I agree with you.

BR

Alice

0 项奖励
回复
1,856 次查看
andrew_lonsdale
Contributor II

Hi Alice,

Thanks for checking it over and confirming.

Kind regards

Charles

0 项奖励
回复