MCASP自环配置。 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1211

积分

金牌会员

Rank: 6Rank: 6

积分
1211
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,% C! W$ R$ I, d+ j9 F7 F* T& j) W
input mcasp_ahclkx,1 {! Z& ]" R# c( g2 }- t
input mcasp_aclkx,
/ {4 P# L8 H. w, [6 j8 Vinput axr0,6 D% D! \" q! L- H' F
9 v' l! O' Z1 M: w1 V
output mcasp_afsr,
2 {: W4 P) a$ A& Z) a4 I% Toutput mcasp_ahclkr,
3 ~" f& w! L4 j7 M8 Moutput mcasp_aclkr,0 d/ Q% s# `( W
output axr1,* S+ k" y1 `  r; _' ^6 S7 {
assign mcasp_afsr = mcasp_afsx;% U3 j. O' j8 l+ }; p/ ]  h+ C/ u
assign mcasp_aclkr = mcasp_aclkx;: O$ W& S  _, G: E) _' ?6 g
assign mcasp_ahclkr = mcasp_ahclkx;5 _1 W+ t& O: i& t' p
assign axr1 = axr0;
5 q* u& a& a# @

# N3 L9 S2 w$ h2 i
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

8 W* X. j* Y; w+ S
static void McASPI2SConfigure(void)
' G  {; s2 d% i+ @( q  S1 n  w{- K% H  D5 c2 h
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
" Y; ~4 S  |6 F$ K* qMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
$ p: d; m" q' Z( J  l- x+ JMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
3 q0 Z. p: ]7 p3 ~8 P9 yMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
. V. b: I' r$ K4 A/ O9 k) i4 R9 ?McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,$ Y- j: N( P- `: O! @" P/ C
MCASP_RX_MODE_DMA);
: n6 Q# K8 o* K% K  v& d- h) f' XMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
/ |/ m2 w% {8 X! ]MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */0 q# S/ |* L2 c! y0 p
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, ) f0 A; M( ?& F6 S# r& x
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
. v2 N1 ?3 O8 H6 R# Q  XMcASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, / _/ `' P% j0 @+ [  n2 u+ j( J
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
: U0 }( d  F6 q1 V/ @/ GMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
- `2 {/ z5 c  NMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); - v( h! K# L9 g2 x' M! x# r2 g
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,1 U: F& t9 A* v9 w& ~
0x00, 0xFF);
/* configure the clock for transmitter */) g  Y; b! |8 N* S. L
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
$ |' f( n* A( P" ?' Y: ]& G* uMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 6 B( j6 h( `& }* k' K
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,( w! c( d3 l" ?
0x00, 0xFF);
4 ^2 x$ w7 X/ j) }
2 F$ ]* A! _$ t/* Enable synchronization of RX and TX sections */ 3 v' V2 [- `) w6 ]7 b5 b+ {0 I. g
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
" K3 P" O  W" d: u) V& D9 K, IMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
$ f/ F- D" _0 e2 WMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
/ @. y) L) A  _: m( [; N5 @$ v** Set the serializers, Currently only one serializer is set as/ E* |. {" e$ V5 O+ ~
** transmitter and one serializer as receiver.+ ^7 h7 R1 b! S
*/
; p1 v' ]/ |' \+ x' Y0 kMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
3 d# D. b* u: yMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
: Y, t$ r# y0 _& y& V1 V' P; q' p** Configure the McASP pins
% z9 R7 c' U, A# n0 l** Input - Frame Sync, Clock and Serializer Rx+ T1 Q7 S6 G6 _% p! c2 _- T3 e' n
** Output - Serializer Tx is connected to the input of the codec
/ T$ q3 V; N" k# r*/% ]9 V8 [9 o* b& O
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);( z5 P7 y- K, a0 G8 R
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));5 {: E# w& u1 w8 X* j: n. u3 T3 l
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
# ]# v* n: X: N. e+ W| MCASP_PIN_ACLKX2 E6 j' T2 F6 B  i
| MCASP_PIN_AHCLKX
! U# u- h6 X2 H" B" p& F. V% o| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */1 C1 [2 @: p" m' h4 s0 O
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
: J9 G% s& I1 s* K6 l7 S+ h' N* Z| MCASP_TX_CLKFAIL
" a% J+ X# E* L9 \( H* Y| MCASP_TX_SYNCERROR3 I  C5 ?  i' W
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
) \, P' f' d+ v, a8 w% O| MCASP_RX_CLKFAIL
" J, h8 j+ e  e7 Y+ H1 w" A" {| MCASP_RX_SYNCERROR
# I* f5 n# [8 ^% @. ~4 u. t| MCASP_RX_OVERRUN);5 q- C0 k7 |- e$ q
}
static void I2SDataTxRxActivate(void)
( b! T4 g* B3 o; o5 l# b: K7 F{0 F" k3 N) ^8 G# {/ [6 }
/* Start the clocks */( L% [$ u3 k2 s: F+ f; L
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);$ j" S7 T/ @* G3 Z7 q* Q0 u0 ^0 `% E
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */5 Z$ Z4 h; Z( d, f" @" Q
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,# h1 ]! C" p( L& H0 S: y
EDMA3_TRIG_MODE_EVENT);7 K( m4 f) Z! W0 V+ L& G. b0 C& [% A
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, " f3 o/ S6 y+ f$ |4 Z0 ^
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
6 m  r! W/ S4 ^* X5 M( xMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
! z2 }" a1 Y  S7 DMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
+ d+ i6 a2 r1 u5 jwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
( T$ y& S1 D8 ?1 Z0 F/ uMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
6 `! K0 ~$ B# O  `  J; FMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);
% v' K# a( R& h. x: p5 N$ T}
% k% l% _1 |' U; k2 ]- E0 s
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

+ c# ^, x0 i/ K* K
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-20 07:26 , Processed in 0.040770 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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