MCASP自环配置。 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 10233|回复: 0
打印 上一主题 下一主题

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1214

积分

金牌会员

Rank: 6Rank: 6

积分
1214
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,+ W5 q8 `! X& ?! T
input mcasp_ahclkx,
5 O+ A& ~  f; I+ ?' Yinput mcasp_aclkx,) {4 }1 y! f" v$ u6 Z3 |7 B% k
input axr0,% d: f& m& ]0 D6 P% v" U" }

0 v% \8 r- d# I& n+ b( \output mcasp_afsr,9 k' t: U- j0 W! v8 P( r* `. L+ z' }
output mcasp_ahclkr,9 ]9 }- D/ ]5 U1 G' t* y) U
output mcasp_aclkr,- \9 h8 k( o# S& t
output axr1,. P& r8 X) {" ^
assign mcasp_afsr = mcasp_afsx;
) t- v" f, I- h! g/ k( cassign mcasp_aclkr = mcasp_aclkx;' I6 R+ ~7 @, q
assign mcasp_ahclkr = mcasp_ahclkx;5 q, I( T  D$ `2 ~7 q) h6 j5 t
assign axr1 = axr0;

0 {) ?+ l0 O8 Q% \- P
3 y' ]  p5 }5 c9 y
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
/ A& p  q: C) ~3 A" D
static void McASPI2SConfigure(void)* M  D- ?& w9 t. X7 [
{
3 e: k. Y; F" P# i) EMcASPRxReset(SOC_MCASP_0_CTRL_REGS);; q1 u! m$ \+ Z2 [5 x  Q. N
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */% }+ C9 t# T# z2 r
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);! e$ G  U" j9 l4 J  s# O3 w6 x
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
6 E, E5 a" h* [- Z0 wMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,( h3 O0 |" \3 g
MCASP_RX_MODE_DMA);
% w% W3 L2 X0 Q" f* UMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
2 s' v5 f! q) f/ t$ x* ^# iMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
2 @& c0 R6 C: bMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
3 i- u) L; A( A% e- IMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
& q' [' O1 z: B( l. b' j- t& `McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, " G# c7 l4 O7 ], F/ A  o8 [* r
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
/ n3 v% _+ x7 ]! y2 G& m5 kMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);. E& l, t* @6 r- [/ |  N
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);   j5 O& n  J8 ~. y% a" `, F! `3 t
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
" U2 N1 y/ p$ R" @0x00, 0xFF);
/* configure the clock for transmitter */: s0 p" K. |6 N0 W, f
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);- E7 Q# `0 r! y
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); # @6 c# V" J9 G$ ]( H" r0 x' U; R
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,  s1 M9 \( d9 I" Q4 m1 D
0x00, 0xFF);/ X1 w4 [7 y% L+ {* P* J

9 q4 q; d' I9 _. P$ Z/* Enable synchronization of RX and TX sections */
; n$ ?0 g1 G5 F2 @" a) ?# mMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
: o4 ]  q: G: ~8 s$ vMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
1 y- y8 O6 T5 m3 I% V3 _* dMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*/ ^: ^7 E5 J: t; i# C; ~9 p" P
** Set the serializers, Currently only one serializer is set as5 |) t3 M: j1 X! D$ U
** transmitter and one serializer as receiver.
) i2 ~  R4 F) U*/+ E7 M  ?- B+ J. U0 w: a3 X7 v9 h2 K
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);6 c+ [: a! c* h' ?% Y
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
' \* Q+ C" S0 O8 k* ]** Configure the McASP pins : ^8 i  m- b! Y/ B: a# p7 e
** Input - Frame Sync, Clock and Serializer Rx
9 ~+ G$ x) M/ P3 [0 |' J  Z/ p** Output - Serializer Tx is connected to the input of the codec 1 a  W5 j+ P* h* k. b
*/# \7 ^: v. Q" W( y  Z& H
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);1 S% l9 I6 y$ g0 q5 F3 Z5 _6 g) I
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
# {7 h1 z# P; T# VMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX, U3 Q$ W* @# }
| MCASP_PIN_ACLKX
1 X/ B1 k& B" D( K# S- U4 u5 I| MCASP_PIN_AHCLKX
  S# Z  \: C- Z0 E1 E8 g% d' [7 k| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
: i& y, }( J1 v4 ZMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
1 Z% ~" [. O) ~. D/ r| MCASP_TX_CLKFAIL
9 w% P  l  t0 M. C. y| MCASP_TX_SYNCERROR8 Q# e9 H; i# s1 k4 Y
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR ) l; }3 c  u) x. r
| MCASP_RX_CLKFAIL
, L- k( z" K" W9 m( F- R$ l| MCASP_RX_SYNCERROR
2 T) D& l, }( w. H' `7 |  J3 {| MCASP_RX_OVERRUN);
" E2 j+ y8 Y( ?( O}
static void I2SDataTxRxActivate(void)
2 V0 I1 D5 N1 j. k: f. W+ p{
% m! h- U3 H+ e; }/* Start the clocks */
" V' v5 n, L# T/ j' BMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);6 G8 j, F* Y7 u5 o% _6 C$ R
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
* A0 {5 L. [6 k4 |" r8 {! p$ HEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,2 @  k5 b1 U& h4 M) E
EDMA3_TRIG_MODE_EVENT);! Q4 @* L* y) G3 d8 J8 n
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
% B/ W* G1 w: `EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
' ]: x. T7 B" @( s8 K$ s/ pMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
! w% l# X! t, g4 B& L4 RMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
! d1 Z# w/ d( u! A9 ?- Jwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
2 A# G" V2 \$ ?; C5 N0 UMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
8 o( Q+ H4 w( E+ F2 PMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);3 \$ M  D' }" q3 K- j7 i! x1 E
}

7 o' C% s% ~; T0 U% ]% ^) ~. n
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

8 Y6 G& I5 d: V3 Z' r
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

点击跳转“创龙科技服务通”

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2026-2-1 11:31 , Processed in 0.054420 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表