MCASP自环配置。 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9835|回复: 0
打印 上一主题 下一主题

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1214

积分

金牌会员

Rank: 6Rank: 6

积分
1214
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,, N' t5 \# ]$ ^  a
input mcasp_ahclkx,
  V' S9 H4 F. S8 n* i0 z2 ]1 Minput mcasp_aclkx,
  `& r3 p& O2 T9 _2 einput axr0,1 \, B" T$ ]8 B0 C4 ?3 O9 I  {

5 {) s) i) _& o: qoutput mcasp_afsr,
& [1 q4 H7 \7 goutput mcasp_ahclkr,/ H) S+ ]0 i' J  c1 x
output mcasp_aclkr,
  |' x. [& Y2 r+ {, R4 Qoutput axr1,' `$ R! q, u5 c. |
assign mcasp_afsr = mcasp_afsx;$ O( g+ D5 L- p3 c4 `# V2 b# a$ A. b
assign mcasp_aclkr = mcasp_aclkx;! @$ |( P* m8 k+ u0 g
assign mcasp_ahclkr = mcasp_ahclkx;
: t) D5 L! g7 g  Z" J9 uassign axr1 = axr0;
. z2 r# u! m2 ^: G5 ], I0 n; e

/ y2 f0 Z4 |& `* s
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
6 c# d  u: p( H8 `* ]
static void McASPI2SConfigure(void)
' {$ E$ H% {3 r& C' l4 }: B5 A{
% O" q! L- n: u* [$ l7 ^; i/ Y: K6 ]6 PMcASPRxReset(SOC_MCASP_0_CTRL_REGS);
$ K1 b4 r& W$ ~' {8 X' Z7 [McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
5 D8 S$ u6 I' P' }McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
! U! f$ b: d. {, ]1 DMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
" A& {; I/ r+ v  C) L! p1 |# uMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,- H* u& i6 p" ^% w  A
MCASP_RX_MODE_DMA);; \! a4 M6 N* x( f' S
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,# c; e9 Q, w2 F8 p1 x. O
MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots *// }! T! V+ I0 m! ]* c- C$ y
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
& A* b) v2 k1 t8 G" l4 A8 EMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);3 C2 t5 }( M6 T/ C# y2 h" @
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,   F5 p1 x7 {1 G1 t
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */9 G2 ^( U( e8 x) i, k2 A
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
8 r0 U4 M& X- P4 L9 K# h4 }McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
. A: N; A& t# VMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,( s1 {1 R' c$ f* I( `
0x00, 0xFF);
/* configure the clock for transmitter */) K2 z5 R  A" C
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);5 X" V7 N) z/ T* W2 ~
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 0 [* T; f7 m6 X5 L# v# X4 h
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32," F+ U& p3 @- |! Q+ L
0x00, 0xFF);
. G& {' `9 E; t
9 k$ }, G$ m5 d. V$ y7 e5 `, H/* Enable synchronization of RX and TX sections */ 5 Y8 T. I0 r# Y
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
# k& \/ G7 C! f5 M* rMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
, l( `$ S* x: h, r% E8 tMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
5 h2 J; i2 ?9 A! C9 }1 u** Set the serializers, Currently only one serializer is set as
+ }! _8 M, L- i% d" s** transmitter and one serializer as receiver.; O: U* T+ R+ ?$ L4 Z8 e+ O% ]& s
*/
1 J( }0 K' L7 q8 m) fMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
0 x6 x+ p' Z& m6 K' AMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
+ F4 t0 v: a' f- w/ U** Configure the McASP pins : M; @/ v- R6 h+ V
** Input - Frame Sync, Clock and Serializer Rx* b0 w8 ~9 o  Y% d
** Output - Serializer Tx is connected to the input of the codec " b" V" O( w4 t" C: C  n' c) F4 G5 G
*/
# a; F" l. W  v' OMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
2 H$ H0 q* j- @, F# z4 A! XMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));- ~% Z, ?# L! y- g* Y. W
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
# o) _+ U/ |" U6 u| MCASP_PIN_ACLKX0 n& e" n7 A* m- G0 {- B6 o
| MCASP_PIN_AHCLKX
9 w( `* c$ b7 l9 y% j- c9 p& j3 y| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */7 u/ D: W1 Y, h& S1 @1 \
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR , Z6 [  G/ r" T$ @6 j
| MCASP_TX_CLKFAIL
+ Q+ m5 E8 |0 y; c4 b+ G( f+ B| MCASP_TX_SYNCERROR
1 J) B& P) F; d5 @  D: i; N| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR & L# J) ^) ]' f2 t0 C7 _
| MCASP_RX_CLKFAIL8 N5 u6 l& \) X: Z" z/ {) g' ]7 t
| MCASP_RX_SYNCERROR
) x/ S2 a* \+ F! g0 k* ^) M| MCASP_RX_OVERRUN);- Q& o) r3 x' }% H3 y5 q
}
static void I2SDataTxRxActivate(void)
7 B3 c6 t- h  {& I& h. A1 o{
  ^$ e+ U* C- @1 C$ U4 i, x/* Start the clocks */# l2 G4 y- Q0 K/ S: P7 W- `# j
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);5 f5 w$ Z! c% ^
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
. x* ]( `2 o( G6 \5 @% cEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,, D2 M' V" h+ v8 F- N& F7 ?
EDMA3_TRIG_MODE_EVENT);
; I; l( }3 v& c1 ]2 k- b  `- KEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
. Q$ y# g' k# M* @1 i. mEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
4 I) S7 d: p) {3 s3 Y$ fMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);' W9 j9 n! R6 L. s" g2 X
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
$ B7 l2 X. }' X2 ~. f4 Q$ rwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */" k: j. M9 H9 r
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);* j8 c* J0 A% m. C. l
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
- ]) ^  N5 `7 E* ]5 f}
1 ?: ]+ ]' i5 ?5 k" S
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

. o, M' R. `- g1 v$ h8 h
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

点击跳转“创龙科技服务通”

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2026-1-21 14:35 , Processed in 0.039723 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表