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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 11279|回复: 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," R/ {# f3 y# G; R0 l, O; W; p7 @
input mcasp_ahclkx,# u; q9 v+ k- _
input mcasp_aclkx,
5 U/ @8 w" I" R$ |* h% ainput axr0,
. Q& [4 x) S6 ]9 a6 o) J
0 K8 |2 a# E& ^0 O: Toutput mcasp_afsr,% k! n: e3 [0 \
output mcasp_ahclkr,+ O6 q& L0 a4 ~/ Z% \
output mcasp_aclkr,
& L7 q+ u' M7 |3 \. g2 z/ coutput axr1,/ G1 Z) G; l3 m" j& w3 h
assign mcasp_afsr = mcasp_afsx;" Y( l4 k' K/ a% u2 T
assign mcasp_aclkr = mcasp_aclkx;
( L5 t6 |1 ?: }$ Jassign mcasp_ahclkr = mcasp_ahclkx;; T* V. k0 ?. k6 @
assign axr1 = axr0;
$ u3 l* _; R/ [

! T8 e/ d2 ^0 x3 M+ C9 {& s
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
! y  H* z# q* r4 b/ f# j
static void McASPI2SConfigure(void)
# k) b" f) A0 m{
7 F" t& d% W( `* v0 F- w7 qMcASPRxReset(SOC_MCASP_0_CTRL_REGS);
7 }& N' p4 f9 \% \8 i3 gMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
1 W; t) p* y- K0 v& {3 Y, CMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
# U9 ?( o1 a2 y. }! M& TMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
$ o- O- |  c* E: D: T' V  z3 tMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
7 E( U! p9 G( q  a# L3 c$ gMCASP_RX_MODE_DMA);
6 ~: g7 w2 |& H+ _McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
) b9 B+ u- n' k1 f" \+ A: eMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */6 X9 N" E$ Y( a# M+ C( g: B* j0 f
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
2 _5 n4 t1 W/ i, t& @MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);; Z3 d& H. ?$ W* R, ]" z
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, : k- f/ r; p& r! z
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
' m' c. |- e0 M6 W: u' `  AMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);1 w3 [. u+ j) z4 D7 k+ B' k2 u4 q  R
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
1 z4 ^, g  P9 }' A3 q- I$ V, m9 m. aMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
: b* A- {8 Z8 y/ w5 k' Y0x00, 0xFF);
/* configure the clock for transmitter */
3 s: `8 U9 }) U7 Q& [McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);" L8 O' O) E( j: S4 R' P
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 1 B6 Y& Z  B# q- |
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,- z; O& u4 S2 E; ]! S
0x00, 0xFF);& a. z$ A# M2 p
9 Q* }& w2 T# k! n) i
/* Enable synchronization of RX and TX sections */
( ?. o1 Q$ M9 V: W7 ?, MMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
0 d, ?' D6 W2 y9 i  @. Z6 {/ QMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);) a1 i+ F' }. J8 k) }3 b0 b4 F
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*5 `" m" a7 T" Y  X+ ]3 W. z
** Set the serializers, Currently only one serializer is set as) P* ~7 c2 U; q; O- S
** transmitter and one serializer as receiver.
- s$ w! Y8 Q6 p+ F! @6 M*/6 [0 \' |# O5 s  X; B# o. n" \
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);% @- W  g; r6 ~3 r% n( s
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
) @( L% ]0 }5 G2 Y( J; \3 S% M+ X** Configure the McASP pins 3 r  b' S: J% b/ c  c( d0 S
** Input - Frame Sync, Clock and Serializer Rx
- |1 I6 O# A" C** Output - Serializer Tx is connected to the input of the codec 3 ]# e1 L4 I" j9 x  z
*/
4 Z$ ?" |! U) r4 m- b6 [. Y; qMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);' r- Z0 ^/ o4 Z& H1 B
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));! T) J  P  V0 k* Q: F) S# U
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX: U3 N- s' C- @4 v6 C
| MCASP_PIN_ACLKX- i  e: s" ~2 n6 {
| MCASP_PIN_AHCLKX
  @$ e8 |, I8 h; a& R8 v| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */! S3 o$ i  J% E/ z% Q
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
3 @1 G; W$ w8 L6 l+ v$ }4 h| MCASP_TX_CLKFAIL
4 ^6 N5 W3 I, h" z| MCASP_TX_SYNCERROR
* r2 r$ E/ v  Y, F8 d, Z4 |( U8 f| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR : |# u- @" w5 F* }8 |) x+ W
| MCASP_RX_CLKFAIL
0 z4 i  G# u# v9 f| MCASP_RX_SYNCERROR
& L" m2 p6 t8 @8 r0 x% {| MCASP_RX_OVERRUN);
# b2 Y- f) ~6 C* w* \( y( w( k}
static void I2SDataTxRxActivate(void)
2 @4 U  t4 y: n, P2 E( a{
* W$ S4 l8 c8 A& g- f8 j6 S/* Start the clocks */' y+ U1 G0 ?; q2 N7 B# a& m# y8 M
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
4 \" y# M- }4 \: l7 X  VMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */# ^2 q4 w' ~# C( z
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
' @* O7 g/ S* D' Q( L: y) IEDMA3_TRIG_MODE_EVENT);7 r+ F) z' i) _1 }9 g2 f( ]4 a# t3 {
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 6 ?! x  [  D, @7 b! N5 k& p! ]
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
9 d6 ], K7 F% f8 ~McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);. \& K8 i1 t5 M" M) o  i! a
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */) B3 ?1 @, j: @. S$ D1 ^
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
8 e4 `  s2 T2 E+ b) G! }% KMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
  D; i, }. k6 ~* `, e! q; O  ^McASPTxEnable(SOC_MCASP_0_CTRL_REGS);# r  I* N( ~. J# L' C* e$ I2 I
}

0 l9 o8 h' `5 c& a% }
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
" {% q! j: o" E; Q
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-1 01:33 , Processed in 0.041978 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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