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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 11496|回复: 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,8 A) x) ~  @, k" |/ l- [$ o, Y" X
input mcasp_ahclkx,, x0 g) d( j* u5 k, O) @
input mcasp_aclkx,7 H8 B% p4 k& T: h& _9 d% E5 W
input axr0,( l* d! x6 i# L  C
3 h' {: T8 q+ A* I" j/ E# V
output mcasp_afsr,
% f. L- c8 Q/ w) w4 z& Coutput mcasp_ahclkr,7 O$ I% A8 b* T" u: g% L
output mcasp_aclkr,7 H: b6 Q" C5 ^: n7 o  `3 F/ W1 M
output axr1,- y5 ?8 C" Z. W1 K) w5 h6 D
assign mcasp_afsr = mcasp_afsx;
! e, U. V+ W( i9 I9 _& S# B; k) [assign mcasp_aclkr = mcasp_aclkx;
4 {' K  L# K$ U( \+ `. G8 h  |" Dassign mcasp_ahclkr = mcasp_ahclkx;
$ _6 G) P; ?+ ~assign axr1 = axr0;

3 C- _  w- F! k+ h* _6 p  E; L% v8 {+ m2 Q  s# I
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

, p" X" ?0 _, o. `( P9 ~
static void McASPI2SConfigure(void)
" h. ]# W& l& j. E/ F{
( v$ s/ C4 V5 |& F% Z6 h& `McASPRxReset(SOC_MCASP_0_CTRL_REGS);0 z" d8 m: @* F/ V6 ~; ]* o
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */2 F3 w  p# l6 s# F
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);+ ?; B* Q2 }5 \, a* |& G2 r" |2 s( E
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
4 q/ X9 \6 ]% ?- n/ q; k6 OMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
6 [4 z$ }- ]3 Z, DMCASP_RX_MODE_DMA);6 x" Y: c& T( @* f% _
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,, I  V$ z! q' U9 g7 E, n
MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
% j5 A. D- V- M, qMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, ' ^. z  l6 K5 v( _1 \+ e
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);) O3 z+ w9 d( n, e
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
8 G* X. I& y1 n; V: VMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
% ^0 Q8 |% o" _4 ^McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
1 }# m$ l+ o  j/ gMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); 0 O+ j" V4 d6 e; u% C1 o7 U
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
/ T: n1 A2 M& R/ l' e5 n" y' b0x00, 0xFF);
/* configure the clock for transmitter */$ [; K/ K- \$ X" X3 g
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);) n. v# ^+ y0 Q, ?9 d( y  A
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);   ?, j4 P; j. K" K: {
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
, u% J' L: ], h4 ]0x00, 0xFF);
' y8 _$ y$ Z# C' Y
3 D8 M1 Z& T6 ?) M! T, [/* Enable synchronization of RX and TX sections */ 4 |. M. c/ k9 J
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
9 B/ `" e4 y, o* ^# i. l# EMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
! U+ ]! r+ l$ u1 B' eMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*3 V$ A! z: s# }( J" v! F5 C
** Set the serializers, Currently only one serializer is set as
& }2 t9 f$ b  e: F3 G; P5 H** transmitter and one serializer as receiver.3 F0 y' v$ t% r1 h- o8 N
*/
  }( W/ |1 r9 CMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);. {9 b5 F5 w9 \2 u3 \' m
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
9 v7 a3 `: J& B. {6 M** Configure the McASP pins % L7 z* W% e4 _# |7 g! ^
** Input - Frame Sync, Clock and Serializer Rx
# s% @9 w5 c4 Z4 d** Output - Serializer Tx is connected to the input of the codec
, u4 n* ]! g! x*/
% k) v6 w1 w0 A1 r- oMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
: N4 s/ {) I& W5 {1 b) JMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));) D: L% o* _9 l+ }
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX6 `' W& q1 o2 Y7 W0 w$ I/ I: ?
| MCASP_PIN_ACLKX
& `- s0 x) l# ]2 R; e1 Q1 D| MCASP_PIN_AHCLKX
/ E9 N$ o1 |* `# v! x| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */3 r9 y4 H, v& Q% e/ ~( Z# o2 U2 K
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR 4 M0 G# {  L8 @( x
| MCASP_TX_CLKFAIL . l9 N* L5 t& t# g% u
| MCASP_TX_SYNCERROR/ d" E6 K( \8 }' J2 S! }5 |% C2 g
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
7 E# [: ?, `) F# G| MCASP_RX_CLKFAIL
7 U& n8 ]& X+ S( C+ G| MCASP_RX_SYNCERROR
) N" }' k! B' V4 V# E| MCASP_RX_OVERRUN);
/ ^2 Q' h# v: g* k- E" ]7 x4 q3 `}
static void I2SDataTxRxActivate(void)
3 i, \, t' c9 G1 s9 c, P{
( }% X  W# d! z' q/* Start the clocks */
6 e2 F" m" L# g1 A4 N$ d9 uMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);* V& q( y4 W5 l* O( N
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */, [8 Q, U  ]* x& |
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
2 s9 h3 ?, d, r- dEDMA3_TRIG_MODE_EVENT);% J6 C# ?$ [+ c" W' ?( M
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
+ V9 R' C' [: w# v9 D! Y, a% w4 cEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
2 f" m" @) W, e4 W+ B+ m2 fMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);" i& H+ D2 v0 T0 ~1 ?
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */; [3 z3 \1 o6 E5 Q- F
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */  I" y  Y( e" l  d% k" G/ P' f
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);1 b/ M9 Z# w  {, t5 @5 n) [6 T
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
% s/ ~' u: |; d+ g}

9 k& i, H% @& X
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

9 ]5 W/ @9 P" G7 b
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-7 05:58 , Processed in 0.040579 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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