|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,9 ~( n1 e; @6 N( B( |. `; v) m3 {6 r
input mcasp_ahclkx,
9 d( ^/ H/ ~+ ^" Sinput mcasp_aclkx,
: a/ o9 N/ Q6 n. b" `% y0 k, Zinput axr0, o, p5 W# w" l6 m! J
0 p* V% X( `9 g9 f
output mcasp_afsr,
) w Y7 u, z( X7 Q V$ Boutput mcasp_ahclkr,) |$ b3 _( B/ E. x
output mcasp_aclkr,
6 R6 g7 f/ v" e/ i# Soutput axr1,# K: q' K3 J$ l) l& p: _# C% S
assign mcasp_afsr = mcasp_afsx;
1 B; D3 @5 F$ q8 Q' s. Qassign mcasp_aclkr = mcasp_aclkx;
1 ~5 ?: O. b5 _" O3 t' b( o. passign mcasp_ahclkr = mcasp_ahclkx;4 z/ A% g& Q! u- s
assign axr1 = axr0;
' i8 {0 H: d2 \; o2 J; M$ D2 L" E6 a+ Q! j$ e
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 5 W% u" A2 ~1 b6 O3 R5 G
static void McASPI2SConfigure(void) ?. \* I I( M5 t
{- ^7 X' {; j- c' X" m
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
a O! h5 v6 v( w' uMcASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */
) B6 }9 b! y& n# EMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);* { ?& O- W# X5 a. V0 b
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units */
3 ~2 S9 A4 n, t2 q" ?+ e) W( S' R0 bMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,& _$ [. `3 e6 s" ]
MCASP_RX_MODE_DMA);
, B' }0 ]+ M0 t5 ~0 Q6 c$ p# Z( HMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
- N* z; h' V+ e! O3 ]- I9 W" GMCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */
/ g, L( X, y! _9 U# T( ^McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
' o: I b& }& NMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
7 ]$ ^8 U+ a9 ~/ F, CMcASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
( z8 k, @" Z& U; L, yMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */
0 B' U& M" u4 ]McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);' c9 r X: c4 Y+ a% W _
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
3 M8 @* H* \: u0 ?6 e7 L) `+ W4 EMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
0 e/ ~- P5 j) z0x00, 0xFF); /* configure the clock for transmitter */
6 K$ _) v6 L" hMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
9 _7 b5 t9 |8 {$ ZMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); + J4 z* w4 ]6 O; l( E+ Q9 {
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,! }, ~4 c* |3 M% a3 F
0x00, 0xFF);& Z0 z. h% x0 a! l; |# k7 a
Y6 q- a: |* F) Q* h$ {/* Enable synchronization of RX and TX sections */
_' M9 R5 R* j2 TMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */
+ d2 B o/ q9 W0 z/ X3 OMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);4 D5 b1 V( \6 Q5 o6 A# Q$ U8 x: T& t
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /*
6 |! M: N3 o$ E5 P$ l** Set the serializers, Currently only one serializer is set as+ M O' U u( _, n6 k
** transmitter and one serializer as receiver.
; T9 A6 j. G. s, x9 ~2 A/ C! c*/
/ z- W* V% }5 j; z) s# ?McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);+ P) ~3 K) H8 C% y8 b; w' l& l1 G2 Z9 o
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*
0 Q9 k, }$ L4 D b- D, K** Configure the McASP pins 5 {* o+ j8 m7 M! X# F$ @9 c) f
** Input - Frame Sync, Clock and Serializer Rx+ y1 T6 e& P0 T. D, m
** Output - Serializer Tx is connected to the input of the codec
, F h- a/ E, v9 p) i5 G- L; o*/6 L$ G, v5 Z2 p
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);9 R/ y+ K; O, b6 P! G6 i
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
& |0 v1 I( j$ Z% \' q& l, E* eMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX8 B" V9 J9 H% R1 [/ j/ a9 k
| MCASP_PIN_ACLKX
. R+ U, S- D" y) Z3 Q| MCASP_PIN_AHCLKX: X v3 Y7 v/ ^7 m& k! L# @
| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */' P# @# ?" p$ E8 _2 ^
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
9 _) ?: t" n9 P* [8 D' ^; c| MCASP_TX_CLKFAIL * ^# Z5 b7 L J$ O* Z& a
| MCASP_TX_SYNCERROR$ b# [' T. @2 z. {( z' N) a$ o
| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR + f e; d( a, Z/ T& G( w
| MCASP_RX_CLKFAIL1 N* t9 A% a' {' R& \2 v0 q
| MCASP_RX_SYNCERROR
; e$ p8 Y, }$ Y0 J7 V| MCASP_RX_OVERRUN);( e. c" J9 }8 G+ |! Z
} static void I2SDataTxRxActivate(void)
H V- b* d Q9 i2 P' X" D{$ [3 s0 o' y6 i1 ]4 M
/* Start the clocks */# l, y8 ]- Y6 r- { K
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
j6 B% l( D$ ?9 UMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */
, k' f. C p; uEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,! h+ A ?8 y* e' [ }
EDMA3_TRIG_MODE_EVENT);* A# ? _- L a
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
4 k) e# C' d+ |2 x9 l* X5 [EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */: s/ [: U o H/ L6 ~8 `
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);# `; o5 Z5 K( M! v! N7 T8 D
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */
U$ X' C0 i" d# ]9 Pwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */
9 [% _& x1 Z8 W3 }2 XMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);# S( l0 ~0 L6 R) G2 g, C6 \8 ~
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
! k& q1 ?( y& F2 g} / n- z; e* l; r! p. z
请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0. 1 T5 K. p; ]- W$ W% g
|