|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,! i; K4 }! c1 _8 Y; T
input mcasp_ahclkx,8 V4 K! v: E( V5 p2 u+ M
input mcasp_aclkx,
! A: h" Q7 ^ W! Z [% q% }input axr0,
: j6 I" q! b9 j9 e5 ^% X
1 m! t* |. _ N2 W4 _9 ioutput mcasp_afsr,9 _0 H) L$ r$ v7 a4 U
output mcasp_ahclkr,
) Q% q, v) A1 H+ F" \2 j6 b$ }output mcasp_aclkr,+ J; u9 s% [* j# ~4 H* K {3 e
output axr1,
, p e$ D3 o* f! k# H assign mcasp_afsr = mcasp_afsx;+ ?, v: g/ m; G& F; |. |( o& k7 H
assign mcasp_aclkr = mcasp_aclkx;
% S# p- J, ~( t gassign mcasp_ahclkr = mcasp_ahclkx;, c5 Z0 q, h* f/ C
assign axr1 = axr0; - V" a0 Y( o: q; ~0 B S+ f, h& z
8 I& g B9 _% o$ G3 O4 a) n
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 " z4 y6 H# W2 |3 i" C+ q8 J- Q) ~8 \
static void McASPI2SConfigure(void) e+ B( V) {+ z% |) W3 ?+ x
{4 h7 C, t9 k/ L( g1 x5 z5 m7 O# ~
McASPRxReset(SOC_MCASP_0_CTRL_REGS);1 ]; {% l8 u+ C9 v) `' V. ~
McASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */7 ]3 }( N8 i$ F) S; q/ ~
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);# m4 g x. s, V5 U0 C5 l
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units */
5 k: \% A) x0 NMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
# y2 {; ]1 w$ C! OMCASP_RX_MODE_DMA);
# s8 }3 w; `) }3 L; WMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,! V* G' M o5 Z3 Y& v
MCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */
# \ j. J2 c: H+ e4 RMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
9 M1 a7 g% F( OMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);/ N, Z0 k7 z i5 V8 ~( L* P7 _- ~
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, : p5 A8 J8 X& t8 H, ~
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */
3 \& T- \2 N* a \0 ~9 BMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
# u1 h8 ^9 p9 ^) K" E0 s3 [McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
& x1 W6 B! P3 uMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,3 T) s; P% D; S- T. j; p
0x00, 0xFF); /* configure the clock for transmitter */5 P2 `+ Z. _7 ]
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);" ?) e. H" W! x& C. j. b9 w
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
& w4 q/ X: e5 Q) U8 LMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
- q2 I1 D+ e( Z" m3 `6 t5 \9 N9 K0x00, 0xFF);
$ K9 \7 q, P. G2 ]7 U0 P
+ d! N& W8 B- r7 d; K: ~0 v/* Enable synchronization of RX and TX sections */ 4 j' F, b8 S' C6 A
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */
8 Q2 t/ D4 r3 V. R6 x7 d" {McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
7 H- q" t4 m# A. v8 ]# z5 {McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /** M, t y4 v* n' P4 ]
** Set the serializers, Currently only one serializer is set as/ B2 T. b2 ]+ N: d" x7 m
** transmitter and one serializer as receiver.7 {# ?! D% T; K* h- X$ r
*/
! v, [8 L! c' G' D2 gMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);* C& Y# Y3 E% J
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*
8 O. i) e9 ^- U; f8 f** Configure the McASP pins
w( j1 X* ?! d. A ^1 D** Input - Frame Sync, Clock and Serializer Rx
# y* a$ J J! V' R, y** Output - Serializer Tx is connected to the input of the codec " y* y! H+ k+ {+ v* u- v
*/
+ |) g6 j' d* Z- C$ o& p6 ^McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);0 Q. B0 d, M3 s" K
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
2 |" W- r) I8 B' v4 l0 yMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
) m) P; S- C, `| MCASP_PIN_ACLKX* ^3 ~ N' s I, K
| MCASP_PIN_AHCLKX, |6 L" W, z8 z: @0 e! ~$ A, f
| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */
% t& i! A4 K/ g2 E# w3 q) x3 qMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR 4 H5 N8 @( O, s* E" v" M. o
| MCASP_TX_CLKFAIL
7 O: R2 ~8 b3 P. X3 Y9 y! }' v| MCASP_TX_SYNCERROR; d% g, B' P# Q; S1 ~- A- [
| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
L8 P: a/ u; _: o0 I- ?; c| MCASP_RX_CLKFAIL2 r" c& e( S# [' e8 \
| MCASP_RX_SYNCERROR
" n# V; n) z0 i; M5 _8 n| MCASP_RX_OVERRUN);
, S0 H' T2 @. e, R" s1 `} static void I2SDataTxRxActivate(void)
; J, { E7 @, m+ I6 P{" H M0 o& A$ B$ u% f$ A6 u2 u" {
/* Start the clocks */
' r6 h# Y+ l7 W0 s6 h q# b1 L3 H, e( ^McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);9 p( q2 A" j9 u$ W
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */
1 n3 b# u6 ]$ z0 [EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,# f3 I$ K2 f# {; A9 S b+ |4 B
EDMA3_TRIG_MODE_EVENT);" i* s; Z* f. N1 R1 m" q# y
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, ! C" { H$ T. ~1 A' ?" d3 R
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */3 M' x! ^/ e8 G; H/ q) ^: B
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);3 b6 i) K: ]0 d l P" d! l) h
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */
A' \4 P* a+ S- Z# U. rwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */
$ K' L' N+ R) j& L/ qMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);' X- _6 O& f. }: L9 }$ @/ `
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);- |# ~: j# F* q+ E- o% t
}
* K4 ]: ^4 C1 R0 E; ?/ f请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0. - F; t* o: Q& P% \: n3 S& ?( Y
|