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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9508|回复: 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,
# [3 n% U4 V% I, M/ Uinput mcasp_ahclkx,( t) h3 b9 m# l5 T+ C, x. ^* Y9 b; ?
input mcasp_aclkx,
  X; {3 U0 Q) Ninput axr0,
, P6 Q7 s' L% e7 a- {
1 e- Q& F6 w/ Xoutput mcasp_afsr,* f/ u7 T' x8 n' k' G  C2 U4 @
output mcasp_ahclkr,
+ ?) W) e) o8 C  _+ Boutput mcasp_aclkr,
% h$ A. e4 e; I  q5 E4 moutput axr1,% V- s! l! ^' I* D- E, ]% D& h
assign mcasp_afsr = mcasp_afsx;
8 Y! z) c. {$ k6 ]assign mcasp_aclkr = mcasp_aclkx;
3 c/ e+ t$ x7 r' ^7 {7 O% h% q! Dassign mcasp_ahclkr = mcasp_ahclkx;: x2 `7 |7 Y" q4 l1 g/ E
assign axr1 = axr0;
7 P$ y2 Z: l" B1 D5 X+ W* s* s) M
6 r; e& [' H3 r( V9 Z- S1 P! n) h
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
/ W! C- O' L( B6 z. }9 v
static void McASPI2SConfigure(void)" [* C3 Z5 X6 Z/ w, g0 {
{7 f, r2 ]  D! M, x
McASPRxReset(SOC_MCASP_0_CTRL_REGS);$ t7 t3 A  ^1 B* x9 b5 ?
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
: G" F. E, V  K5 }McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
% j5 @" ^; t% f$ ?9 S; e% {McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */) R& l, B8 g7 D& X# d
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,( R% d6 _1 O% b- l/ a
MCASP_RX_MODE_DMA);
' ~7 n& z4 ~2 e  a8 Y6 HMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
: C' O1 P. a5 d* a% i! wMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots *// r8 u8 q7 N; `5 I; J
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, # X* x8 C/ q( W, n0 ]
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);- x: O7 X  n8 y# a9 W) U
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, 2 ]4 ]8 c( P9 Q  W# y5 s/ _
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */; U7 ?# D" M% X5 K, S
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);7 Q, t/ @0 a; O0 e/ v, u
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
4 @$ E& n9 V0 A$ JMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,7 x  B! `7 Y% _& F) n
0x00, 0xFF);
/* configure the clock for transmitter */2 {; T; f( I" K. ?+ v8 C) Z
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);' r  |2 Z. H) \  l3 ~; Y
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
5 D, r' p' ~; _/ K5 mMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
$ I. m# L  j* o# @* {1 F0x00, 0xFF);% k' w3 w  b; B

- C: n8 C- h. D/* Enable synchronization of RX and TX sections */ 0 V, Q) J* J6 w
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */6 t' S- V; f: w) I$ T& \
McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);- V& \1 L& W6 m" ~1 i
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
# c+ g9 v6 c' u  o& {7 A: w** Set the serializers, Currently only one serializer is set as
% E9 j" n: C  n" k3 ]7 G** transmitter and one serializer as receiver.
% B! ?) [6 \" p/ b8 e4 ]: ?1 l*/! [& |4 ~1 c7 L  b2 h8 B$ B
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
6 M) b' t' w/ c. U% PMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*$ p6 S7 c! k9 |- K
** Configure the McASP pins
( ~7 w! Z) G/ u/ _8 |** Input - Frame Sync, Clock and Serializer Rx; t3 ~  @9 r, X- u+ P: {% b$ q& X7 K
** Output - Serializer Tx is connected to the input of the codec , ^# P" l" R" C% O
*/
& S. z! O" F# |; J% D  y9 zMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);9 ?$ [6 g( E" P; D9 E9 d) K7 D
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
# r( w3 k, p0 e; O6 e" oMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX. a7 c; x8 L/ o2 t; p: X
| MCASP_PIN_ACLKX' e3 t" Y7 v& s# p' A8 g0 e
| MCASP_PIN_AHCLKX
* H( @  D4 j; Z- g8 X5 m% s/ _| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
; Y* {4 U) s, q1 T6 Z! `+ {McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
% \# t$ {+ ]( h' || MCASP_TX_CLKFAIL ; ]+ c% l/ m3 T$ a1 v4 P* T* G
| MCASP_TX_SYNCERROR
& C! C- ]+ i5 k| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR 5 O: o6 e. G, b5 }
| MCASP_RX_CLKFAIL! O+ @2 U2 h' X. I; C7 d
| MCASP_RX_SYNCERROR
, g" ]/ _' r* [' B5 }" i& C| MCASP_RX_OVERRUN);
/ J, K& v1 F$ g% o8 S1 ~9 n}
static void I2SDataTxRxActivate(void)
, k4 C6 h* q* n! o{7 ?" R2 S- d9 {5 m+ r  W: X
/* Start the clocks */8 `/ h7 v  t; U
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);6 B5 A' C/ v. R* @! [1 M: c* h
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
+ s. d$ }8 ?' m6 P; HEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,! y; M5 ]! \5 g
EDMA3_TRIG_MODE_EVENT);
3 L& w7 R+ v% e% U! f( tEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
7 _' y: E* U2 z9 T& GEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
/ B) `3 g4 w# k% D9 \7 iMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
0 O9 G! T3 z) }+ z4 ?: g. WMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */2 p# p6 @; [7 t" K
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */! x! u4 j' d/ r" Z* p3 ?  v3 S
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);
4 Y/ U1 x$ @8 G2 z+ oMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);9 y8 N  y/ V. f. ]& O
}
  u# Z- X1 @- b4 X0 n0 t. i
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
& @' T$ s! ?! C, S% h  g" u& o# d$ w
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则


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

GMT+8, 2026-1-12 08:56 , Processed in 0.039829 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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