嵌入式开发者社区
标题: MCASP自环配置。 [打印本页]
作者: wapdasta 时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
1 J; A% E7 H; q z' [input mcasp_ahclkx,, B5 u5 ~% d3 Q+ @! N0 e
input mcasp_aclkx,
9 E( I9 E# F; j1 f$ A- Vinput axr0,, W L0 C4 X6 w) K3 K( n# Z6 }' @- p4 E4 `
$ P8 g6 `+ q/ X8 x1 j: J5 i2 H3 Zoutput mcasp_afsr,
. j5 S* n) s2 {; ~1 L: \- ^output mcasp_ahclkr,* x' A* t8 O b3 Z, j/ E4 ^
output mcasp_aclkr,# ?) z9 m4 W8 o/ U/ B
output axr1,
9 F1 J; c' c0 |- O1 T* ?; G0 }
assign mcasp_afsr = mcasp_afsx;
t9 H7 i+ D/ y3 z1 [assign mcasp_aclkr = mcasp_aclkx;
& R9 v! H1 L0 ^" w) i( Gassign mcasp_ahclkr = mcasp_ahclkx;
! T$ J/ Y) k+ k8 x5 tassign axr1 = axr0;
0 m: p3 d, o3 x8 K' [- E8 h. b, \2 h B2 _% q# C% N$ `
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
/ ~' M2 E ^' P0 a4 R% L* Ostatic void McASPI2SConfigure(void), J5 @ b6 o" h2 g1 i% T1 K
{8 B# A4 S: v7 V: Q7 X# E& g4 @1 y
McASPRxReset(SOC_MCASP_0_CTRL_REGS);0 Q5 t( r8 _* c, _/ Q8 D7 ?
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */- d$ L2 G5 B. G6 u! ^
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
& t5 ?) d- p8 U% O) t4 eMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */' ]; N! B p* D b3 V4 ?
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
8 B5 ^5 v9 O( bMCASP_RX_MODE_DMA);) r% W6 M8 ?$ G! M; p$ J
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,: S0 I! g7 x/ S$ Q1 U/ l) n4 J7 Z& @. P
MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
$ p0 D- z1 R3 m6 {6 OMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, , w, [8 s, J* _- \
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);, L( |8 u6 R* B. x3 M, L
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
1 g2 c. h4 s) Q# u6 A6 gMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
1 Y( ~5 }1 j# O# o8 DMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0); [) g. u8 J( W1 ~5 B3 B
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
9 H3 A4 ^4 ]) HMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
2 T# z* {7 H8 ~& p6 u0x00, 0xFF);
/* configure the clock for transmitter */
# T4 e9 g6 E. F6 G4 r" j/ EMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);. r( Q; Y" W! O/ [. j
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); : |- K' O0 ~9 |+ F
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,6 c* m* f- R2 P. G
0x00, 0xFF);8 Y5 O5 [* r# z
0 O! O0 o$ z0 z' b
/* Enable synchronization of RX and TX sections */ ' L' D& d; A; Q$ E/ T+ H
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
* d' z$ ]: \% ], wMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
9 S9 S( v$ y0 A" [McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
X; w8 N" o, I+ Y** Set the serializers, Currently only one serializer is set as% a3 e! [" @7 n& Z! b. H- I* F
** transmitter and one serializer as receiver.
9 b! b$ z- t$ H( n0 g* {7 {# E*/% s% t; x" ~4 N& I
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
( N8 a @& V2 Q: I* J0 d; O% I) aMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
% w! x" g3 k) B q: S* `. ]7 z% T& M** Configure the McASP pins
; |& S, i5 b: y% I. E, a1 {** Input - Frame Sync, Clock and Serializer Rx4 W4 p' c3 S. u& @
** Output - Serializer Tx is connected to the input of the codec ( e5 l6 p. g% o! Q1 N* q$ Q5 |
*/ \+ U/ N( I5 L" w9 l4 p
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);9 I: O$ x2 x# k
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
2 D) X2 I3 e! [: }1 WMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX2 W9 G; G; X& j" H: s/ @ q& C* V+ |
| MCASP_PIN_ACLKX O* a7 y2 q) @/ D- u2 s4 k
| MCASP_PIN_AHCLKX
0 d4 `9 B3 A" ?3 t7 B h| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
. c2 ^( y" W& [; B- R: f* QMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
2 d K& R$ A5 `- {4 t| MCASP_TX_CLKFAIL
. D* V; j2 K# q| MCASP_TX_SYNCERROR# B% w" y5 S. r, X7 y" o
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR 6 q: `, s% c1 B1 j
| MCASP_RX_CLKFAIL. z. O2 J: E5 f7 O% @* D, g
| MCASP_RX_SYNCERROR ! ?$ d6 c7 {6 C, t1 G E
| MCASP_RX_OVERRUN);
, N6 ]7 U& g$ @+ {% F}
static void I2SDataTxRxActivate(void)" K1 Z" N6 s, b
{; J' v/ C" z' u( k( E- k
/* Start the clocks */
- f5 G s7 B% B& n/ OMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);- |+ c; I" _$ u9 I( s$ L
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */9 y6 ^( j: k' ~9 J; \3 y
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
. M( o% D6 f0 V8 O$ q7 E& |5 T8 pEDMA3_TRIG_MODE_EVENT); e) c( m/ I" ]2 t2 T r* `
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
) o7 E) v( L* {8 _EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */2 I8 |4 \2 `" H: z) ?
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);9 Q) j9 [3 l9 O: a4 U: @2 E$ Z
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */% }8 d5 I1 F6 v/ a
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
* { t* p' \$ t3 ]9 A+ C+ qMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
4 B& t+ X* q$ H2 DMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);2 J w+ c( H. b5 H
}
2 \ L2 R* X! a$ p; K5 j& Z7 R, D
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
. m/ H; Z6 [0 ?9 T; C& a- U
| 欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) |
Powered by Discuz! X3.4 |