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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1215

积分

金牌会员

Rank: 6Rank: 6

积分
1215
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,- _- u& i! C6 Q; K: J2 Z9 c
input mcasp_ahclkx,
9 J2 I: r! O3 P9 k& }9 sinput mcasp_aclkx,
, }6 m+ q1 E& l/ ^& _% Rinput axr0,
$ q3 ?" I7 v- l2 b5 U) a9 x2 h9 [! ]- w
output mcasp_afsr,6 a3 f  o) X+ G) |5 V6 d
output mcasp_ahclkr,
  l0 A8 a0 m0 C$ {; Z8 youtput mcasp_aclkr,' ]0 u3 m% [  M& h' b% c
output axr1,
! Y' u: c& P8 f) ]+ A8 n2 `6 G
assign mcasp_afsr = mcasp_afsx;
" `4 C5 A$ R' a" D% Jassign mcasp_aclkr = mcasp_aclkx;3 K( u4 R: H2 z
assign mcasp_ahclkr = mcasp_ahclkx;2 ]- X1 Z% |# F; _: N( f2 W3 K
assign axr1 = axr0;

# ?" a% B2 U0 \- ?
7 a' N- A: E+ t5 `: M8 ]
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

9 P, d# C# P1 T, Q5 t3 R5 v
static void McASPI2SConfigure(void)
$ K( ?1 D* W, w4 C% P  K{
6 @% q' u- l* n5 N7 q- VMcASPRxReset(SOC_MCASP_0_CTRL_REGS);: F# a$ ?8 i" g
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */( j$ b; ]2 c% T3 |
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
6 o# s7 W& I7 o. }+ PMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
9 T1 F8 M& ?  VMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,! {7 k8 U0 u) K1 y  N2 z6 h( i4 P  n: v
MCASP_RX_MODE_DMA);) z( n/ n; o* ^' o6 C, G
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
9 F) G# ^" t% z3 X7 KMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
, D4 X, I- j9 v5 i: OMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, ; d3 s1 B6 z4 u$ X2 @
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
- B' X) Y2 q3 S2 q- eMcASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
2 ^! W) O; F: s! ZMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
  `3 T4 \7 V6 I. X; yMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);  `3 m. V% U. F4 l3 i
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
+ S3 E8 ]3 U+ w: F' TMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,' v7 O" a' A5 k4 ?8 J' K: \$ T
0x00, 0xFF);
/* configure the clock for transmitter */
$ z. I3 j( ?2 h1 p0 }! [( JMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);! d( P$ l2 o6 f! r) Q
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
0 a$ c# G* h" x4 r! WMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,! O( U/ P7 S; f  W9 Z' k
0x00, 0xFF);
3 `! _6 J- w% U5 E% Y7 f3 I8 L  H3 {! d% Y& ~) e
/* Enable synchronization of RX and TX sections */ 8 {- N* M9 p7 h" x- {% Z" {; a
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */) u& j+ v. \6 I0 A
McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
2 p* {1 \4 B+ K# @# ~& BMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
0 }1 K4 e5 Z  H  l6 h; U** Set the serializers, Currently only one serializer is set as/ H( N8 W: b, s' N+ ]
** transmitter and one serializer as receiver.) Y. i: k' h, `% V% ?3 r" o& w1 `  b
*/
7 j! z+ P" B+ {McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
( u( q3 F( D4 p' YMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
' L$ j# s3 I, v7 z1 W2 R( F' S2 S** Configure the McASP pins
7 ~; r, S& D5 G8 [' A/ b  w6 o** Input - Frame Sync, Clock and Serializer Rx2 ?0 J! D, g$ _+ b, Q
** Output - Serializer Tx is connected to the input of the codec
) W9 n0 C! `  S$ W0 X*/
) M% z/ j# L+ X' D3 a, G9 _# GMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
* p0 T3 r# a7 X$ {McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));3 I5 M. }5 k$ h8 C6 f
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
% s8 ^, H+ E3 n' D  X5 r7 j- l| MCASP_PIN_ACLKX
6 A+ [7 d0 b3 W6 x. z| MCASP_PIN_AHCLKX7 w6 P: q2 x+ L$ V! }" Q7 s
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
- q( T. p1 C& s4 QMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR ; `5 |8 q& K/ w+ b* C! p
| MCASP_TX_CLKFAIL
. C1 D1 F% c0 g. q( F| MCASP_TX_SYNCERROR
3 h# v+ ~! K) U: ]: X# j| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR , L+ [0 o2 X5 W7 w0 v
| MCASP_RX_CLKFAIL
4 X& y# ?6 Y5 e2 B9 h* }4 u| MCASP_RX_SYNCERROR . ~1 ~1 H& Y. W  c) E6 S; t. t
| MCASP_RX_OVERRUN);% i) }) u0 P/ s5 y+ i9 D
}
static void I2SDataTxRxActivate(void)
) \/ l# }; m' f  L; y# w{
: R0 R4 |3 x! U! P' L- m/* Start the clocks */) ?" L, q2 k' R, E
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
) y; L9 M% h" k) u: _  iMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */9 L& z( M4 f& q, v
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,6 o0 e4 ^0 `8 P3 x
EDMA3_TRIG_MODE_EVENT);: B$ x4 r- }( o8 _
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
# P- \* k- _2 n- t3 c9 yEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
- p$ Y+ O7 a# j# Q+ ~; ~McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
  l6 M  m5 p, b( |* V) OMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
7 ~8 e- J0 k( S+ r6 h! I& Hwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */* B0 c9 e; A% Q( E( N$ ^
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);
5 Q, S3 t- [4 F. h+ IMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);1 k2 T( L" ?4 n
}
; J; _  ~1 _: |$ ]$ x. O+ Z* I( M
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
& A0 J! w. C0 k; l( `9 h4 |
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-12 19:18 , Processed in 0.037890 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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