嵌入式开发者社区
标题: MCASP自环配置。 [打印本页]
作者: wapdasta 时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,1 |: x3 P3 T1 k j/ B' e6 k
input mcasp_ahclkx,/ ?" E8 `$ z% N) B
input mcasp_aclkx,
7 Q" Z$ p# c; Iinput axr0,
" U8 J2 a6 b& [
/ p6 n) P4 R0 m7 u; s/ Aoutput mcasp_afsr,
9 p# N, L3 P: Y" `output mcasp_ahclkr,
# P$ C9 f( G* g0 l9 t! o, B6 V5 qoutput mcasp_aclkr,
3 T: m! \- o4 a6 Coutput axr1,
0 i" @/ n! @2 Z0 X
assign mcasp_afsr = mcasp_afsx;
, L- ?' [; w& @8 U* Z9 fassign mcasp_aclkr = mcasp_aclkx;6 G* H* W5 w4 G; P7 `
assign mcasp_ahclkr = mcasp_ahclkx;( r. k. z L1 ]/ z0 d2 e8 n
assign axr1 = axr0;
R1 F/ a) w% Y# j, H9 B$ W6 ~& B5 @4 h" U5 C1 L% c) p q' v
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
4 E& ]5 N2 V; L) m6 X# m
static void McASPI2SConfigure(void)+ L( c0 d6 R# ~+ `2 f0 H
{
1 A1 @+ m- [) V6 b% X7 iMcASPRxReset(SOC_MCASP_0_CTRL_REGS);
. e8 y, \) q& S) |5 OMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */, L" m8 g: k9 M4 ^: e( t
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
6 `/ [8 k+ i1 T0 Q& g, pMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
4 c& ?6 {! t* |. I! d0 L; y. z) J+ _McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,1 J8 Q6 p; f9 h
MCASP_RX_MODE_DMA);
3 I& A& ]* ]6 r- V- dMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
: p) {0 E! f/ Q# HMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */- c$ W8 [( R1 u; }: ~+ M- K6 e
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
4 J0 r3 G! O# g$ _/ `MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);( u; f: U! P# w2 f) F3 f' z# o
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
( m. {+ M* I& A2 o, y$ G& K" rMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */( w* _/ A5 A! W
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);, J. i, I7 c6 i5 d( O3 ]3 @
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
" @; }! x% y0 T f. o WMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
6 ?, y$ d# S: p; i0x00, 0xFF);
/* configure the clock for transmitter */7 k! n/ |' U) \' v c2 z
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);- _8 ~4 l" L8 R3 w
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); # @4 c& J/ d/ M8 u+ { ^1 b
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,7 v- b1 l0 W P( b+ j. ?6 \
0x00, 0xFF);
) t" R# {0 a% s( j5 u
% A j% y- F/ m/ P7 ]. d/* Enable synchronization of RX and TX sections */ ; B0 m- Z2 K, l" Q4 O G" S
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
3 E; W3 S4 P/ X& M) s4 F# CMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
8 s; h8 w A: z5 l) U7 S% W6 Q+ }McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
2 X9 y3 o, n" k( g** Set the serializers, Currently only one serializer is set as: [8 f8 [& J: h' B/ A4 i
** transmitter and one serializer as receiver.' j! P1 o. e0 ^% l% j7 j
*/
( y7 Y4 W0 a8 Z% I3 }McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);, ^1 ~* A3 Y; F3 p
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*& Y, g N/ J8 W$ `
** Configure the McASP pins % y. a/ j R$ Y, Z* M$ q& {7 U7 h
** Input - Frame Sync, Clock and Serializer Rx
" S! s, u2 @1 z2 w' z' U/ |** Output - Serializer Tx is connected to the input of the codec Y6 h% O7 o5 A0 U
*/- w; ~* E" t5 D# m* p+ ^ @
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
0 x8 v% z# {+ ?6 c( f) eMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));4 m& b; X v; _5 K5 T7 n
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
4 Q: q& t! O) R0 C D! R$ @ N/ r| MCASP_PIN_ACLKX
4 `) W$ T# E' o/ r| MCASP_PIN_AHCLKX* e; @* K3 T5 g& [1 {5 O( r
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
i8 Y6 X, J3 m; }* a1 ~8 U+ v9 y: PMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR . X: f$ d; C: R N9 |
| MCASP_TX_CLKFAIL % {$ r) s" p ^+ z8 ?* W6 m6 d/ n
| MCASP_TX_SYNCERROR+ A! c) N& X7 P
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR $ ?* P* j9 J5 w& `
| MCASP_RX_CLKFAIL
, T- [9 D( a D$ ^" K( F8 e7 h$ V| MCASP_RX_SYNCERROR 9 h. H0 n6 `/ W F
| MCASP_RX_OVERRUN);3 R) Z' j- H7 a" [; j* [% m7 k
}
static void I2SDataTxRxActivate(void)
( B$ L3 l4 w! u4 v' t5 }' t1 d{
& u" X+ s/ z1 z' p$ H2 K% @3 p0 \/* Start the clocks */
! s0 |0 e+ z) F2 E! d1 OMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);3 I( x/ s e3 Y
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
4 s7 q" A: g7 l" ^" p" ?, f6 KEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,( Q: @1 {+ ~+ J: X) E5 L$ |; h+ U
EDMA3_TRIG_MODE_EVENT);7 Z3 K1 G0 Z/ g, ?( D
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, : x# m! t) v3 y+ ]. v- Q& d( y
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
+ w8 M! F: w/ l/ YMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);7 |) l% g3 J* c6 p
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */* L1 c/ N8 c+ \
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */2 I8 o- g' h; N2 h6 R8 _
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);
' p7 O0 k @8 c! }( z; q: t! WMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);
5 C( }( F* B8 g3 D" L}
3 k7 b3 g% F2 `2 a7 u3 h请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
1 V3 w7 y o# C1 c- x1 G
| 欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) |
Powered by Discuz! X3.4 |