|
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。 部分代码如下 input mcasp_afsx,
" S+ ?8 k& p! p1 X8 v. p% Dinput mcasp_ahclkx,
0 }4 u6 u$ s8 Q* hinput mcasp_aclkx,. ^1 V0 P" j" s1 C
input axr0,
1 C, d, ]0 w2 a& h3 q* J8 \' X' ^5 I' \
output mcasp_afsr,
' S0 u6 M2 i* koutput mcasp_ahclkr,, f; B0 ~. E( y% h* f: o) K3 O
output mcasp_aclkr,7 m% `4 T0 z, p7 S8 _( N' X
output axr1,: i* h, [) {4 o' @) o
assign mcasp_afsr = mcasp_afsx;3 x! L5 U/ L; C, p
assign mcasp_aclkr = mcasp_aclkx;( e \! ]' s% E3 p. G ^! N
assign mcasp_ahclkr = mcasp_ahclkx;
* q5 u) J. s& uassign axr1 = axr0;
) e/ U# l! ~: } q! p* h
2 \; J# \* d3 S1 @* t- R在OMAPL138这端,通过axr0接口发固定的数,axr1接收。 在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。 一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。 部分代码如下,关于edma3的部分未做变化。 0 `$ V) o6 u1 R+ E q
static void McASPI2SConfigure(void)- {! v0 j! g- @7 G" u: k+ {5 I
{
+ X {$ ~: ]) I2 {McASPRxReset(SOC_MCASP_0_CTRL_REGS);
8 a; B1 @* ?8 n1 V8 pMcASPTxReset(SOC_MCASP_0_CTRL_REGS); /* Enable the FIFOs for DMA transfer */
6 K- q/ V( m; ]# K& p) K4 v8 AMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
# y. E3 O6 g0 h) U) ?8 WMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1); /* Set I2S format in the transmitter/receiver format units */
6 _: a9 {9 V: @( q' }5 G4 EMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
7 L D8 J: _- i! H! vMCASP_RX_MODE_DMA);! h' u0 ]; p T
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
2 C! s: A8 l* t8 HMCASP_TX_MODE_DMA); /* Configure the frame sync. I2S shall work in TDM format with 2 slots */
( a) J4 Z& q6 b: @* M6 K& c5 \McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, ' K9 B/ @ x& M( s( N/ T' C9 Q& Q
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);4 u0 h4 @' F+ \8 U
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, / ]( j& H& j0 I
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE); /* configure the clock for receiver */# M% L* T- D' E
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);4 ?7 Q7 j$ t% `/ A1 V
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
* w( ?) c/ m. L; @- K- m6 FMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,8 Z' Z/ r5 i7 ?3 Y0 n) |
0x00, 0xFF); /* configure the clock for transmitter */0 n9 t3 A! _$ f. P" [
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1); f0 h$ [: e9 r5 l- j6 f& f
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); : b0 \0 G0 h; B
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,* a( f1 A! j; B& ^
0x00, 0xFF);
5 V* b7 P$ r* s& I" R/ a9 a# t( b; u- ^) h3 k- y$ x1 N6 z3 ]' [
/* Enable synchronization of RX and TX sections */
4 h* H) B, A5 j: F3 h6 FMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS); /* Enable the transmitter/receiver slots. I2S uses 2 slots */1 T+ |$ I$ z, ^- }; ?. n0 z6 V
McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
. z& a: [/ [* K. ?2 ]McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS); /*
9 T0 b) q' i% L$ D: }+ x/ z** Set the serializers, Currently only one serializer is set as
+ r6 h* L' L) b& I, W5 G** transmitter and one serializer as receiver.
7 W) n. Y& J: z* N8 n7 p*/
" ]2 I! d, r' J0 U% C6 j% hMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);% a0 `8 Z- U' M/ u' j$ j* R
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX); /*6 C# `% w* j6 [! I1 {. ~* w4 E6 k
** Configure the McASP pins 4 l; c% J" R* u! B
** Input - Frame Sync, Clock and Serializer Rx+ x" Q1 K* c3 v
** Output - Serializer Tx is connected to the input of the codec * z- O6 g0 \) g$ W/ Y9 R$ M
*/5 H, W, Y5 V- K1 ?8 i
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);) m% @$ [% l5 [4 e5 k
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));5 }1 W6 N4 ]2 N3 @! u% q! @7 K) D
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX8 f9 O0 [8 f& h9 Z I: j
| MCASP_PIN_ACLKX, s$ F% O% X$ W, k
| MCASP_PIN_AHCLKX3 b' E9 W" g5 L/ G7 X T
| MCASP_PIN_AXR(MCASP_XSER_RX)); /* Enable error interrupts for McASP */
1 O+ f- r' s) v- W5 @7 lMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR * C# X) a, A; ?8 [4 Q* f, }$ [
| MCASP_TX_CLKFAIL 1 S8 o9 F& m$ F s( b0 P2 M7 ?
| MCASP_TX_SYNCERROR
9 M7 {, R# @2 d1 D| MCASP_TX_UNDERRUN); McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
0 k3 C0 p- z4 o0 J3 ?$ i& b' d| MCASP_RX_CLKFAIL! n# w4 ^7 W& P' x
| MCASP_RX_SYNCERROR
1 W' B/ Z) @' a# g; `| MCASP_RX_OVERRUN);
# w' w8 g/ X* K. h9 U' t/ y0 G} static void I2SDataTxRxActivate(void)1 B% L n( _* }' U1 @
{
& b" f+ Y7 {3 F4 H) C/* Start the clocks *// e m+ e7 w6 s& I b7 \7 v4 z6 T
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
9 X# ` _/ V! B6 aMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL); /* Enable EDMA for the transfer */& n/ w9 k6 M" A! r) W! D" H4 W
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
! ]- D6 l7 ]% o; k, WEDMA3_TRIG_MODE_EVENT);
+ h4 A- c* v8 p5 z* R( yEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, & J2 K2 @( D" \7 j
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT); /* Activate the serializers */' ?( X: j8 j+ _7 I5 S; A M
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);2 Y0 j" _& o2 [# N
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS); /* make sure that the XDATA bit is cleared to zero */
* @$ d( C j. E* K$ Rwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY); /* Activate the state machines */
& X' ^, f/ K }McASPRxEnable(SOC_MCASP_0_CTRL_REGS);
* E/ }& t1 u/ W8 k. F' ~" R& \* R: GMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);
3 s1 X$ J$ H# F* H9 f+ f+ p% f}
: P6 k" n! r: ^' P B- U请问:问题出在哪了,时钟按照这样配是否有错。 另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0. ; o& E5 I" h$ J$ A- m: X6 D
|