|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,
) e b# M: B$ Iinput mcasp_ahclkx,& f' O2 O; k3 @6 E0 n9 s" c
input mcasp_aclkx,* Q9 `, y/ L4 y0 _% T9 @2 Q; m
input axr0,* B$ T4 V. [2 I' }3 W6 {
9 m1 Z3 R+ A; y: e9 x: M2 J2 Zoutput mcasp_afsr,- J* W. l4 `; s6 R! a, H6 K" u$ ^
output mcasp_ahclkr,; J7 D/ b: M; X' c: Q4 L' D
output mcasp_aclkr,# {3 f" [8 W/ S- d5 ? M
output axr1,
# B6 r6 E6 J/ c& Z( v assign mcasp_afsr = mcasp_afsx;
& S4 P w8 F- C7 w- C9 Tassign mcasp_aclkr = mcasp_aclkx;9 X$ N3 ~8 U# t/ z' n4 D) y" h
assign mcasp_ahclkr = mcasp_ahclkx;
) V0 b$ S# M0 I2 S j- hassign axr1 = axr0; 8 W7 L: Y2 t5 N: X
3 o; O0 S; u3 K
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 9 N) r9 u+ M3 d* r
static void McASPI2SConfigure(void)( Y& T/ @+ i$ M3 w
{: V d d, H) ]% n
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
* |' U. o+ D/ SMcASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */! Q ~ z9 L" y) C6 c8 ~
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);5 N) y. g4 m8 k* Z% \3 M
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units */
4 ^# y, W# N2 Y- w$ E: K# iMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,) R8 [$ g/ S6 K4 \
MCASP_RX_MODE_DMA);
4 ~8 c t" F1 a, aMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,! A9 X; ^9 P% x+ f9 H
MCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */; A% ]4 L- z8 D/ ~, G& n& X
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, " E; b4 E6 T' {) ^
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);3 D4 R6 ~4 x3 ^1 p
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, 0 u; D5 E7 D0 H( V. [9 W/ _
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */
8 L) K2 b+ C9 B) a2 c4 c+ kMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
* M1 }) s5 _3 N/ J# S, M/ U3 m& ]$ G$ rMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); 6 {3 ]( _# q0 u2 e( A, x! O
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,0 X, W+ Y( f) d9 K
0x00, 0xFF); /* configure the clock for transmitter */0 Y' u1 W3 p# J, h
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);$ B7 \) z, W2 L
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 2 {( i) [4 S6 s4 p( ~5 y
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
( J$ x. z$ z# K- \% b0x00, 0xFF);
1 y# u/ w: v, k. Q: A# a5 g! v0 f! W* r% u( i$ ]
/* Enable synchronization of RX and TX sections */
. Z* |' Y" p! Z I; y2 JMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */
* d9 q+ \9 t- w2 UMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);+ p3 ~$ f+ b+ Q& m: j# x
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /*
: l' T# Q/ ]; y/ C** Set the serializers, Currently only one serializer is set as, l0 u& X) t. {1 F/ m9 M$ I: S( t6 V
** transmitter and one serializer as receiver.: ]' c- S# T! q) h
*/
7 k3 Y% R7 d9 gMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
- i# }) a. x5 q- m0 r2 V+ }1 nMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*/ o u* q2 U1 G0 B! V4 t4 O& z
** Configure the McASP pins 8 @7 X. M, k" t
** Input - Frame Sync, Clock and Serializer Rx
' h6 S! s5 P, x% o** Output - Serializer Tx is connected to the input of the codec ; b7 I) g& Q3 j. ?) @
*/" k( H0 {0 V% w4 W8 j
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
. {7 _# P- [! qMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
' O/ Y: }8 P/ j) X2 cMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX& |: w" m- n! _9 ^
| MCASP_PIN_ACLKX6 ~1 m+ H ^8 V: [
| MCASP_PIN_AHCLKX
) N, A$ E l2 M/ `7 k: _| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */3 u" ^' ^$ y$ ^8 a, p
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
; @& Z' V/ |& @5 k| MCASP_TX_CLKFAIL
4 y& S" J4 {. M% G. v| MCASP_TX_SYNCERROR
6 ^/ u; T4 A: h6 B& X/ M5 H| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR & i G+ G/ B) S2 a. \/ Y) {
| MCASP_RX_CLKFAIL
- R' z! i) v; y" K4 U$ L7 Z| MCASP_RX_SYNCERROR
$ b7 ~( d0 P* n| MCASP_RX_OVERRUN);
w4 v7 k X( A3 z* D( [} static void I2SDataTxRxActivate(void)8 A& {- ~+ Y: d( n# E% B
{
* f- h( i* z2 t/* Start the clocks */$ {( B: n% i- B* J% ~- d
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);% M2 {5 x4 [4 W" r- v9 o1 R+ z5 T) K8 `
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */
4 j" y5 N0 O5 l4 j9 e' ]EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
" k! q9 g5 x4 bEDMA3_TRIG_MODE_EVENT);
. c) ]% H2 Y* O9 E) w% }4 CEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
x/ P: Y$ G5 S9 \* m( T ?EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */2 ~* t- ]6 q! p; H
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
: t! g1 P5 Z" [& A0 ^. i; ^; b TMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */
g; F, J. c4 {$ l+ t) R( a5 wwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */
& w- `7 F* V6 XMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
$ x! C9 O; ^5 C, \! WMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);. ^6 H! z" ] Z- d: g
}
: |6 ~8 Q: x0 M; Z* c. [请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0. " D1 P0 I9 s5 S
|