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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1212

积分

金牌会员

Rank: 6Rank: 6

积分
1212
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,& g, ?1 R3 N6 S4 e7 Z
input mcasp_ahclkx,
4 O' y, T% h4 o( _, R, f5 B/ `input mcasp_aclkx,
' a5 P/ [9 i3 G& y, z% R% E1 Cinput axr0,
* k8 p6 ?' P" H( U9 J0 \& z0 [& |( X% D, p. w
output mcasp_afsr,
4 ?9 D5 R3 h& D) [2 C" |output mcasp_ahclkr,
' `' i" B1 t! x  Youtput mcasp_aclkr,, \5 {* y" F$ r& D' y* _) q
output axr1,2 T: v7 ^" O' W6 B; k% m+ \" P9 F
assign mcasp_afsr = mcasp_afsx;
9 _( s6 b5 y" ~9 L" r$ Tassign mcasp_aclkr = mcasp_aclkx;
% i7 f, d& ^3 ]8 q9 \+ M4 Eassign mcasp_ahclkr = mcasp_ahclkx;* i' _+ \- U) c
assign axr1 = axr0;
/ ?% O4 n  T: y8 u1 S. }

4 E2 {4 ~; z  L0 i/ J
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

0 w2 s8 R2 P6 J( P& x: r
static void McASPI2SConfigure(void)7 o3 a( F+ i" q5 m' H; t  u
{/ s8 l0 Y9 c" r- h/ @  F& v
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
% M8 e( c0 U# X  EMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
: q. k6 C" L$ I( ^! ~McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);3 \# C/ q! Q7 W% f
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */' d, `% l% u6 u" |
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
0 z6 i6 m! q) R2 ]; rMCASP_RX_MODE_DMA);6 A: X. _' j6 s) N% r' y6 T
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
2 c# m4 x% I0 b; mMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */2 e4 g% }) T& K/ U5 G/ q
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, 2 S9 \$ x# K) C0 l5 Z
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);/ Y7 M" i( w. k. y+ i
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, 4 U6 n6 Z. ^' o9 v0 j2 Z
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
: O9 M: o2 |7 \& mMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
" W0 M5 l: d' J3 q  s. i, `McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); 7 s# `! a( _0 i, D& V- v
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,9 Q" f+ ^( s! @# d6 Y5 S
0x00, 0xFF);
/* configure the clock for transmitter */5 @' H  u# ?) R* A( z# m; Q/ a. q
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
8 X: f# b; ~' b! W; DMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); + u; D) Z4 ]% h6 z
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
' E2 k9 ?+ x% ?4 \# }! _/ N0x00, 0xFF);# j: w+ Y8 j% h. x) J! j# z
- k  f$ v- z/ g6 Z) ~4 t( u
/* Enable synchronization of RX and TX sections */ ' ^' I2 `6 \! P
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
5 Z% }" b1 K4 w; AMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
4 k3 z: n9 y% ~  o: ^( \% Q* XMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
* t0 ^$ K: z; i& W( h: D4 ~0 Z) i** Set the serializers, Currently only one serializer is set as; C5 g* _2 `5 v; v' O8 j
** transmitter and one serializer as receiver.
  l7 _) K& B& Z, ^) @% Z5 v4 O*/9 [( m% b' e: p. I
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
3 E. V4 J+ n& y: m6 g% S. FMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*3 ~% R2 K( {" t' S, W; l% I
** Configure the McASP pins
# v, y' |/ u0 E0 G** Input - Frame Sync, Clock and Serializer Rx
( ?; i5 K- b8 z; O. W** Output - Serializer Tx is connected to the input of the codec
6 Q2 _1 B* x, Y( ^) v8 r6 M*/
  k7 E) l9 i' P; d( c2 lMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
0 P4 P5 c. X  z5 Q- tMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));& _. ?, f* S) x; U. v3 o! G5 N
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX, B7 v7 @, }/ j9 I  a9 W% Z  a
| MCASP_PIN_ACLKX, n/ v% a$ A' }' T# D" {. s( T* C
| MCASP_PIN_AHCLKX
8 {1 r9 ]& U- M8 e, m. q$ B( J| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
& k- M5 X8 g6 |5 V; EMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR 9 B4 ?3 O4 m* I9 |+ p4 }
| MCASP_TX_CLKFAIL
  w" V7 Z% K- v| MCASP_TX_SYNCERROR
0 Y3 K' T; h+ C. |6 V| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
& ]$ U3 W7 L6 l6 k6 P3 ~| MCASP_RX_CLKFAIL9 c+ ]8 n+ J5 T  |
| MCASP_RX_SYNCERROR
4 W8 L4 f- U2 }; t% ]- A) O/ B| MCASP_RX_OVERRUN);
+ O1 E/ ^: D: B- f' }9 i+ I}
static void I2SDataTxRxActivate(void)
3 N- x, A9 j  `" P2 e+ [{9 N# _6 |: f- Q! A1 t3 i( O& @
/* Start the clocks */2 d3 Y2 v& u) j
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);6 @& @5 X7 J, g3 C
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
$ i# x9 t" U1 z9 @  q& p5 B2 x9 zEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,1 X* B3 w9 G5 @! Z. i4 y0 O9 K
EDMA3_TRIG_MODE_EVENT);) b9 x% I" q9 k( Q4 a
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 4 g) d. A0 p! z+ e! w# _
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
1 f: p" b6 \, j: y) o* {McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
' r1 V! X# ]; j/ w; p% `8 d2 PMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
* n0 b1 W! Y# fwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
' b( {" z  F8 M! `6 |8 h8 CMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
: m8 B' L( O7 |9 M( s, zMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);7 m2 [1 h' y7 |. e
}
/ Z: @9 z+ k7 a  i: E) ~& ?5 Y) M" ~
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
" Q- L2 o1 l+ W3 C8 M( {) V
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-8 11:36 , Processed in 0.040029 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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