|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,$ ?4 `! n* c5 i- {9 k/ R3 C
input mcasp_ahclkx,$ c$ E; X) K6 h; h" E( @- |
input mcasp_aclkx,* `4 A$ {. p! ~/ h
input axr0,
+ ]/ E( M" T3 D2 S2 f9 L/ p, M! N0 ^* L, w
output mcasp_afsr,7 }2 Z$ i- B! H# O
output mcasp_ahclkr,/ N, Y9 Y: v! z3 X
output mcasp_aclkr,$ S; v* ?, G2 w5 d
output axr1,
* b- i u! u1 H' E0 `) j& {1 k& g assign mcasp_afsr = mcasp_afsx;
& U' K' v: h7 R; p4 vassign mcasp_aclkr = mcasp_aclkx;
: @$ u+ d) D; G/ v6 ?. ~assign mcasp_ahclkr = mcasp_ahclkx;
* ^8 {. g' N7 b3 ^5 ~assign axr1 = axr0; 5 Y7 |9 W- Q- W7 C6 D6 p% x
5 H, D# j; r. G. P9 X: I% M
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 * u) [1 A3 S8 e' p" Q
static void McASPI2SConfigure(void)
1 p$ b" V3 m: A& l& d' G{
9 I6 j) X; m1 o6 r8 U9 vMcASPRxReset(SOC_MCASP_0_CTRL_REGS);3 f9 z6 a9 ^( R
McASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */( o7 G/ l* j0 l. w2 M- m) E. ~
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
) ~; n; {" U7 L1 \& |9 L# ~McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units *// j( ~( q$ K; s M( p( L5 r
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,7 r" Y0 p. s! B9 F/ g
MCASP_RX_MODE_DMA);. `9 Y3 z \' n5 ]* V, W
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
7 k( X# E, B5 i }5 _; O/ _1 XMCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */8 p& s( J- F, ~3 y' R
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
: O" n! V) V! a5 GMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);; g; c) ~! h' y# m: ^% j- a
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
- P: B" W. C! F+ K- d: K6 X% y- I: \MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */! P# T$ a7 K B) |
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
: K; H% t8 R/ o# N [, [) [McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); 1 ^7 }/ y) V$ n4 d" f) a% P
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
- Z* q/ t( ~ N; c$ I% F8 ~$ e0x00, 0xFF); /* configure the clock for transmitter */; K$ t4 w: j" |2 x
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1); P7 u9 @3 t) G. w
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
+ R. _+ ?2 v, a/ {McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
0 S" p- F+ b+ i/ B0x00, 0xFF);, y4 q7 y6 e) i0 a' Z6 ]
; H& H# [% T2 \! S# r/* Enable synchronization of RX and TX sections */ ) s, n7 U/ h# }% p. o+ P; @
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */
/ A; @, i5 \, L3 J' k7 eMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
* U+ x5 P, u5 s2 [+ g3 }McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /*7 m& c5 y% D' L# z0 E* N P- Q+ U
** Set the serializers, Currently only one serializer is set as- T$ ], \+ ?- p$ F4 T% [
** transmitter and one serializer as receiver.( ]4 H( ~1 O) h& W4 Y# g! k) L6 O
*/
) x/ a. T0 @' ? G/ o. n5 l/ MMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);/ N% I9 t& B* W
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*1 ^# `6 Y8 u7 l* h6 j6 Z
** Configure the McASP pins / L$ k9 w9 j9 G: f. n4 S+ u( `
** Input - Frame Sync, Clock and Serializer Rx
3 T6 U) ?, D7 S# V" j$ {* Z2 k** Output - Serializer Tx is connected to the input of the codec $ x4 j" q& z0 U( b2 s) C( s
*/
5 Y- t0 e! {$ A. \McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);3 f/ w! @1 j$ m) b
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
2 U: P: F+ x1 Y5 s) R2 O- dMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX. p6 z. f! a* F e: N
| MCASP_PIN_ACLKX
) f1 y: C5 z) z# c| MCASP_PIN_AHCLKX
' O s5 G, |) p) Q8 r4 M| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */8 ^4 [- Q5 |$ A$ j7 [
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
6 E3 K/ C% \2 m: ?| MCASP_TX_CLKFAIL 9 L/ F( z& q* o) K( |& D* m
| MCASP_TX_SYNCERROR! h | V) n8 l* d \
| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR " n/ S# d' l! m0 U
| MCASP_RX_CLKFAIL. _5 |/ I! n: c& {9 K. o7 B0 d! [
| MCASP_RX_SYNCERROR
# t5 ?9 O% f: \| MCASP_RX_OVERRUN);' ]5 ~% J5 b: x
} static void I2SDataTxRxActivate(void)
3 K0 E# i4 O9 o$ X5 \4 o1 j{
3 J+ m! o# B: c- O, E( h4 J/* Start the clocks */" r9 g8 c. \: _" }6 p; I* y. p
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);9 s! q& d# l: J1 L
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */
) R- k8 F& k7 a$ oEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,5 n1 y3 j8 ?3 O6 W% L# V8 \1 U
EDMA3_TRIG_MODE_EVENT);
$ W; o+ I* N9 d- Z% ]% k& uEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 8 P9 C$ ~2 ]& ^+ V
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */
$ s8 Q7 @/ P* ^% P/ A, UMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
/ I# Y' H! e* L$ FMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */' n3 N, k2 z1 L* Z( o) y
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */( B$ f! n( e9 @( \4 ~2 L
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);4 X3 ?7 L3 t" w* t. _+ [
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);! O/ ]: k2 Q2 k1 Q
} 5 e5 Z) G# C) m' f }; w
请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0. - V# ?' I* s. F' [! K
|