LPC55S69 SPI DMA Example doesn't function properly when changing Flexcomm port

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

LPC55S69 SPI DMA Example doesn't function properly when changing Flexcomm port

跳至解决方案
1,386 次查看
AveryDauben
Contributor II

When using the spi_dma_b2b example, I simply switched the SPI7 defines and clock source to SPI3, activated it's pins in the pin tool and it stops functioning. Here is the defines I changes, notice how the DMA channels are updated as well for Flexcomm 3.

#define EXAMPLE_SPI_MASTER SPI3
#define EXAMPLE_SPI_MASTER_IRQ FLEXCOMM3_IRQn
#define EXAMPLE_SPI_MASTER_CLK_SRC kCLOCK_Flexcomm3
#define EXAMPLE_SPI_MASTER_CLK_FREQ CLOCK_GetFlexCommClkFreq(3U)
#define EXAMPLE_SPI_SSEL 0
#define EXAMPLE_DMA DMA0
#define EXAMPLE_SPI_MASTER_RX_CHANNEL 10
#define EXAMPLE_SPI_MASTER_TX_CHANNEL 11
#define EXAMPLE_MASTER_SPI_SPOL kSPI_SpolActiveAllLow

Then I change this code for Flexcomm 3 as well:

/* attach 12 MHz clock to SPI3 */
CLOCK_AttachClk(kFRO12M_to_FLEXCOMM3);

/* reset FLEXCOMM for SPI */
RESET_PeripheralReset(kFC3_RST_SHIFT_RSTn);

At this point it stops working, so I believe something in the background is needing to be changed as well, but I'm not familiar with the SPI, DMA or SPI_DMA drivers.

Thank you for your help!

标签 (2)
标记 (3)
0 项奖励
回复
1 解答
1,346 次查看
Habib_MS
NXP Employee
NXP Employee

Hello @AveryDauben,

The DMA has a separate DMA request for each Flexcomm, as shown in the following image:

Habib_MS_0-1744062424504.png


If you wish to modify the Flexcomm, it is essential to modify these channels. For example, channels 18 and 19 correspond to the Flexcomm 7 interface, which is why the macros are defined as follows:

#define EXAMPLE_SPI_MASTER_RX_CHANNEL 18
#define EXAMPLE_SPI_MASTER_TX_CHANNEL 19


Also, if you experience any issue, does not hesitate to let me know.

BR
Habib.

在原帖中查看解决方案

0 项奖励
回复
4 回复数
1,347 次查看
Habib_MS
NXP Employee
NXP Employee

Hello @AveryDauben,

The DMA has a separate DMA request for each Flexcomm, as shown in the following image:

Habib_MS_0-1744062424504.png


If you wish to modify the Flexcomm, it is essential to modify these channels. For example, channels 18 and 19 correspond to the Flexcomm 7 interface, which is why the macros are defined as follows:

#define EXAMPLE_SPI_MASTER_RX_CHANNEL 18
#define EXAMPLE_SPI_MASTER_TX_CHANNEL 19


Also, if you experience any issue, does not hesitate to let me know.

BR
Habib.

0 项奖励
回复
1,288 次查看
AveryDauben
Contributor II
@Habib_MS

Hello,
could you please attach the file that you are looking at? The Dual-DMA usage pdf on the LPC55S6x page is not fully up-to-date. Thank you!
0 项奖励
回复
1,203 次查看
Habib_MS
NXP Employee
NXP Employee

Hello @AveryDauben,

The table was taken from the user manual, which you can find on this page:

Habib_MS_1-1744646940073.png

BR
Habib.

0 项奖励
回复
1,325 次查看
AveryDauben
Contributor II

Thank you, this fixed the issue. I must've had an outdated version of the DMA channels as FlexComm 2 and 3 aren't switched on this pdf.

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2073981%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E6%9B%B4%E6%94%B9%20Flexcomm%20%E7%AB%AF%E5%8F%A3%E6%97%B6%EF%BC%8CLPC55S69%20SPI%20DMA%20%E7%A4%BA%E4%BE%8B%E6%97%A0%E6%B3%95%E6%AD%A3%E5%B8%B8%E8%BF%90%E8%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2073981%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%BD%93%E4%BD%BF%E7%94%A8%20spi_dma_b2b%20%E7%A4%BA%E4%BE%8B%E6%97%B6%EF%BC%8C%E6%88%91%E5%8F%AA%E6%98%AF%E5%B0%86%20SPI7%20%E5%AE%9A%E4%B9%89%E5%92%8C%E6%97%B6%E9%92%9F%E6%BA%90%E5%88%87%E6%8D%A2%E4%B8%BA%20SPI3%EF%BC%8C%E5%9C%A8%E5%BC%95%E8%84%9A%E5%B7%A5%E5%85%B7%E4%B8%AD%E6%BF%80%E6%B4%BB%E5%AE%83%E7%9A%84%E5%BC%95%E8%84%9A%EF%BC%8C%E5%AE%83%E5%B0%B1%E5%81%9C%E6%AD%A2%E8%BF%90%E8%A1%8C%E4%BA%86%E3%80%82%E4%BB%A5%E4%B8%8B%E6%98%AF%E6%88%91%E6%9B%B4%E6%94%B9%E7%9A%84%E5%AE%9A%E4%B9%89%EF%BC%8C%E8%AF%B7%E6%B3%A8%E6%84%8F%20Flexcomm%203%20%E7%9A%84%20DMA%20%E9%80%9A%E9%81%93%E6%98%AF%E5%A6%82%E4%BD%95%E6%9B%B4%E6%96%B0%E7%9A%84%E3%80%82%3C%2FP%3E%3CP%3E%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER%20SPI3%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%20EXAMPLE_SPI_MASTER_IRQ%20FLEXCOMM3_IRQn%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER_CLK_SRC%20kCLOCK_Flexcomm3%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%20EXAMPLE_SPI_MASTER_CLK_FREQ%20CLOCK_GetFlexCommClkFreq(3U)%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_SSEL%200%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%20EXAMPLE_DMA%20DMA0%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER_RX_CHANNEL%2010%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER_TX_CHANNEL%2011%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%20EXAMPLE_MASTER_SPI_SPOL%20kSPI_SpolActiveAllLow%3C%2FP%3E%3CP%3E%E7%84%B6%E5%90%8E%E6%88%91%E4%B9%9F%E4%B8%BA%20Flexcomm%203%20%E6%9B%B4%E6%94%B9%E4%BA%86%E6%AD%A4%E4%BB%A3%E7%A0%81%EF%BC%9A%3C%2FP%3E%3CP%3E%2F*%20%E5%B0%86%2012%20MHz%20%E6%97%B6%E9%92%9F%E8%BF%9E%E6%8E%A5%E5%88%B0%20SPI3%20*%2F%3CBR%20%2F%3E%E6%97%B6%E9%92%9F%E8%BF%9E%E6%8E%A5%E6%97%B6%E9%92%9F%EF%BC%88kfro12m_%E5%88%B0flexcomm3%EF%BC%89%EF%BC%9B%3C%2FP%3E%3CP%3E%2F*%20%E9%87%8D%E7%BD%AE%20SPI%20%E7%9A%84%20FLEXCOMM%20*%2F%3CBR%20%2F%3E%E9%87%8D%E7%BD%AE%E5%A4%96%E8%AE%BE%E9%87%8D%E7%BD%AE%EF%BC%88kFC3_RST_SHIFT_RSTn%EF%BC%89%EF%BC%9B%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%AD%A4%E6%97%B6%E5%AE%83%E5%81%9C%E6%AD%A2%E5%B7%A5%E4%BD%9C%EF%BC%8C%E6%89%80%E4%BB%A5%E6%88%91%E7%9B%B8%E4%BF%A1%E5%90%8E%E5%8F%B0%E7%9A%84%E4%B8%80%E4%BA%9B%E4%B8%9C%E8%A5%BF%E4%B9%9F%E9%9C%80%E8%A6%81%E6%94%B9%E5%8F%98%EF%BC%8C%E4%BD%86%E6%88%91%E4%B8%8D%E7%86%9F%E6%82%89%20SPI%E3%80%81DMA%20%E6%88%96%20SPI_DMA%20%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%E3%80%82%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%84%9F%E8%B0%A2%E6%82%A8%E7%9A%84%E5%B8%AE%E5%8A%A9%EF%BC%81%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-2073981%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CLINGO-LABEL%3ELPC55xx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3E%E5%A4%96%E8%AE%BE%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2080135%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9B%B4%E6%94%B9%20Flexcomm%20%E7%AB%AF%E5%8F%A3%E6%97%B6%EF%BC%8CLPC55S69%20SPI%20DMA%20%E7%A4%BA%E4%BE%8B%E6%97%A0%E6%B3%95%E6%AD%A3%E5%B8%B8%E8%BF%90%E8%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2080135%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3EHello%26nbsp%3B%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F248824%22%20target%3D%22_blank%22%3E%40AveryDauben%3C%2FA%3E%2C%3C%2FP%3E%0A%3CP%3E%E8%AF%A5%E8%A1%A8%E6%A0%BC%E5%8F%96%E8%87%AA%E7%94%A8%E6%88%B7%E6%89%8B%E5%86%8C%EF%BC%8C%E6%82%A8%E5%8F%AF%E4%BB%A5%E5%9C%A8%E6%AD%A4%3CA%20href%3D%22https%3A%2F%2Fwww.nxp.com%2Fproducts%2FLPC55S6x%23documentation%22%20target%3D%22_self%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3E%E9%A1%B5%E9%9D%A2%3C%2FA%3E%E6%89%BE%E5%88%B0%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22Habib_MS_1-1744646940073.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Habib_MS_1-1744646940073.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F332967i364B6328AB14B1EF%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22Habib_MS_1-1744646940073.png%22%20alt%3D%22Habib_MS_1-1744646940073.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3EBR%3CBR%20%2F%3EHabib.%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2079326%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9B%B4%E6%94%B9%20Flexcomm%20%E7%AB%AF%E5%8F%A3%E6%97%B6%EF%BC%8CLPC55S69%20SPI%20DMA%20%E7%A4%BA%E4%BE%8B%E6%97%A0%E6%B3%95%E6%AD%A3%E5%B8%B8%E8%BF%90%E8%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2079326%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F231807%22%20target%3D%22_blank%22%3E%40Habib_MS%3C%2FA%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%E4%BD%A0%E5%A5%BD%EF%BC%8C%3CBR%20%2F%3E%E6%82%A8%E8%83%BD%E9%99%84%E4%B8%8A%E6%82%A8%E6%AD%A3%E5%9C%A8%E6%9F%A5%E7%9C%8B%E7%9A%84%E6%96%87%E4%BB%B6%E5%90%97%EF%BC%9FLPC55S6x%20%E9%A1%B5%E9%9D%A2%E4%B8%8A%E7%9A%84%20Dual-DMA%20%E4%BD%BF%E7%94%A8%20pdf%20%E5%B9%B6%E9%9D%9E%E5%AE%8C%E5%85%A8%E6%98%AF%E6%9C%80%E6%96%B0%E7%9A%84%E3%80%82%E8%B0%A2%E8%B0%A2%E4%BD%A0%EF%BC%81%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2076451%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9B%B4%E6%94%B9%20Flexcomm%20%E7%AB%AF%E5%8F%A3%E6%97%B6%EF%BC%8CLPC55S69%20SPI%20DMA%20%E7%A4%BA%E4%BE%8B%E6%97%A0%E6%B3%95%E6%AD%A3%E5%B8%B8%E8%BF%90%E8%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2076451%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E8%B0%A2%E8%B0%A2%EF%BC%8C%E9%97%AE%E9%A2%98%E8%A7%A3%E5%86%B3%E4%BA%86%E3%80%82%E6%88%91%E4%BD%BF%E7%94%A8%E7%9A%84%20DMA%20%E9%80%9A%E9%81%93%E7%89%88%E6%9C%AC%E8%82%AF%E5%AE%9A%E6%98%AF%E8%BF%87%E6%97%B6%E7%9A%84%EF%BC%8C%E5%9B%A0%E4%B8%BA%E8%BF%99%E4%B8%AA%20pdf%20%E4%B8%8A%E6%B2%A1%E6%9C%89%E5%88%87%E6%8D%A2%20FlexComm%202%20%E5%92%8C%203%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2075458%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9B%B4%E6%94%B9%20Flexcomm%20%E7%AB%AF%E5%8F%A3%E6%97%B6%EF%BC%8CLPC55S69%20SPI%20DMA%20%E7%A4%BA%E4%BE%8B%E6%97%A0%E6%B3%95%E6%AD%A3%E5%B8%B8%E8%BF%90%E8%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2075458%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3EHello%20%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F248824%22%20target%3D%22_blank%22%3E%40AveryDauben%3C%2FA%3E%2C%3C%2FP%3E%0A%3CP%3EDMA%20%E5%AF%B9%E6%AF%8F%E4%B8%AA%20Flexcomm%20%E9%83%BD%E6%9C%89%E5%8D%95%E7%8B%AC%E7%9A%84%20DMA%20%E8%AF%B7%E6%B1%82%EF%BC%8C%E5%A6%82%E4%B8%8B%E5%9B%BE%E6%89%80%E7%A4%BA%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22Habib_MS_0-1744062424504.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Habib_MS_0-1744062424504.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F331701iEDAA9B34E6453B90%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22Habib_MS_0-1744062424504.png%22%20alt%3D%22Habib_MS_0-1744062424504.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%3CBR%20%2F%3E%E5%A6%82%E6%9E%9C%E6%82%A8%E5%B8%8C%E6%9C%9B%E4%BF%AE%E6%94%B9%20Flexcomm%EF%BC%8C%E5%88%99%E5%BF%85%E9%A1%BB%E4%BF%AE%E6%94%B9%E8%BF%99%E4%BA%9B%E9%80%9A%E9%81%93%E3%80%82%E4%BE%8B%E5%A6%82%EF%BC%8C%E9%80%9A%E9%81%9318%E5%92%8C19%E5%AF%B9%E5%BA%94%E4%BA%8EFlexcomm%207%E6%8E%A5%E5%8F%A3%EF%BC%8C%E5%9B%A0%E6%AD%A4%E5%AE%8F%E5%AE%9A%E4%B9%89%E5%A6%82%E4%B8%8B%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER_RX_CHANNEL%2018%3CBR%20%2F%3E%20%23%E5%AE%9A%E4%B9%89%E7%A4%BA%E4%BE%8B_SPI_MASTER_TX_CHANNEL%2019%3C%2FP%3E%0A%3CP%3E%3CBR%20%2F%3E%E6%AD%A4%E5%A4%96%EF%BC%8C%E5%A6%82%E6%9E%9C%E6%82%A8%E9%81%87%E5%88%B0%E4%BB%BB%E4%BD%95%E9%97%AE%E9%A2%98%EF%BC%8C%E8%AF%B7%E9%9A%8F%E6%97%B6%E5%91%8A%E8%AF%89%E6%88%91%E3%80%82%3C%2FP%3E%0A%3CP%3EBR%3CBR%20%2F%3EHabib.%3C%2FP%3E%3C%2FLINGO-BODY%3E