|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,+ W5 q8 `! X& ?! T
input mcasp_ahclkx,
5 O+ A& ~ f; I+ ?' Yinput mcasp_aclkx,) {4 }1 y! f" v$ u6 Z3 |7 B% k
input axr0,% d: f& m& ]0 D6 P% v" U" }
0 v% \8 r- d# I& n+ b( \output mcasp_afsr,9 k' t: U- j0 W! v8 P( r* `. L+ z' }
output mcasp_ahclkr,9 ]9 }- D/ ]5 U1 G' t* y) U
output mcasp_aclkr,- \9 h8 k( o# S& t
output axr1,. P& r8 X) {" ^
assign mcasp_afsr = mcasp_afsx;
) t- v" f, I- h! g/ k( cassign mcasp_aclkr = mcasp_aclkx;' I6 R+ ~7 @, q
assign mcasp_ahclkr = mcasp_ahclkx;5 q, I( T D$ `2 ~7 q) h6 j5 t
assign axr1 = axr0;
0 {) ?+ l0 O8 Q% \- P
3 y' ] p5 }5 c9 y在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 / A& p q: C) ~3 A" D
static void McASPI2SConfigure(void)* M D- ?& w9 t. X7 [
{
3 e: k. Y; F" P# i) EMcASPRxReset(SOC_MCASP_0_CTRL_REGS);; q1 u! m$ \+ Z2 [5 x Q. N
McASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */% }+ C9 t# T# z2 r
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);! e$ G U" j9 l4 J s# O3 w6 x
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units */
6 E, E5 a" h* [- Z0 wMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,( h3 O0 |" \3 g
MCASP_RX_MODE_DMA);
% w% W3 L2 X0 Q" f* UMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
2 s' v5 f! q) f/ t$ x* ^# iMCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */
2 @& c0 R6 C: bMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
3 i- u) L; A( A% e- IMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
& q' [' O1 z: B( l. b' j- t& `McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, " G# c7 l4 O7 ], F/ A o8 [* r
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */
/ n3 v% _+ x7 ]! y2 G& m5 kMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);. E& l, t* @6 r- [/ | N
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); j5 O& n J8 ~. y% a" `, F! `3 t
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
" U2 N1 y/ p$ R" @0x00, 0xFF); /* configure the clock for transmitter */: s0 p" K. |6 N0 W, f
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);- E7 Q# `0 r! y
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); # @6 c# V" J9 G$ ]( H" r0 x' U; R
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32, s1 M9 \( d9 I" Q4 m1 D
0x00, 0xFF);/ X1 w4 [7 y% L+ {* P* J
9 q4 q; d' I9 _. P$ Z/* Enable synchronization of RX and TX sections */
; n$ ?0 g1 G5 F2 @" a) ?# mMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */
: o4 ] q: G: ~8 s$ vMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
1 y- y8 O6 T5 m3 I% V3 _* dMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /*/ ^: ^7 E5 J: t; i# C; ~9 p" P
** Set the serializers, Currently only one serializer is set as5 |) t3 M: j1 X! D$ U
** transmitter and one serializer as receiver.
) i2 ~ R4 F) U*/+ E7 M ?- B+ J. U0 w: a3 X7 v9 h2 K
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);6 c+ [: a! c* h' ?% Y
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*
' \* Q+ C" S0 O8 k* ]** Configure the McASP pins : ^8 i m- b! Y/ B: a# p7 e
** Input - Frame Sync, Clock and Serializer Rx
9 ~+ G$ x) M/ P3 [0 |' J Z/ p** Output - Serializer Tx is connected to the input of the codec 1 a W5 j+ P* h* k. b
*/# \7 ^: v. Q" W( y Z& H
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);1 S% l9 I6 y$ g0 q5 F3 Z5 _6 g) I
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
# {7 h1 z# P; T# VMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX, U3 Q$ W* @# }
| MCASP_PIN_ACLKX
1 X/ B1 k& B" D( K# S- U4 u5 I| MCASP_PIN_AHCLKX
S# Z \: C- Z0 E1 E8 g% d' [7 k| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */
: i& y, }( J1 v4 ZMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
1 Z% ~" [. O) ~. D/ r| MCASP_TX_CLKFAIL
9 w% P l t0 M. C. y| MCASP_TX_SYNCERROR8 Q# e9 H; i# s1 k4 Y
| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR ) l; }3 c u) x. r
| MCASP_RX_CLKFAIL
, L- k( z" K" W9 m( F- R$ l| MCASP_RX_SYNCERROR
2 T) D& l, }( w. H' `7 | J3 {| MCASP_RX_OVERRUN);
" E2 j+ y8 Y( ?( O} static void I2SDataTxRxActivate(void)
2 V0 I1 D5 N1 j. k: f. W+ p{
% m! h- U3 H+ e; }/* Start the clocks */
" V' v5 n, L# T/ j' BMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);6 G8 j, F* Y7 u5 o% _6 C$ R
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */
* A0 {5 L. [6 k4 |" r8 {! p$ HEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,2 @ k5 b1 U& h4 M) E
EDMA3_TRIG_MODE_EVENT);! Q4 @* L* y) G3 d8 J8 n
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
% B/ W* G1 w: `EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */
' ]: x. T7 B" @( s8 K$ s/ pMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
! w% l# X! t, g4 B& L4 RMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */
! d1 Z# w/ d( u! A9 ?- Jwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */
2 A# G" V2 \$ ?; C5 N0 UMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
8 o( Q+ H4 w( E+ F2 PMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);3 \$ M D' }" q3 K- j7 i! x1 E
}
7 o' C% s% ~; T0 U% ]% ^) ~. n请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
8 Y6 G& I5 d: V3 Z' r |