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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1193

积分

金牌会员

Rank: 6Rank: 6

积分
1193
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,; F* ~; n: U3 H& v+ b
input mcasp_ahclkx,0 [7 N# N. ^: m( }( Q
input mcasp_aclkx,7 P& b' \7 E) g& Y/ _4 a, Z; H
input axr0,
* T7 Q4 n" _/ K: _  u' e+ }7 O/ V" a9 P% F! n$ `
output mcasp_afsr,
0 L: d: k# A0 U: H$ V- O/ Y  r( m; x! moutput mcasp_ahclkr," |; Y1 r$ G2 f! M$ q
output mcasp_aclkr,  ?% u" l3 S/ e$ k5 J
output axr1,  U* C# a0 d1 m- d# a% [
assign mcasp_afsr = mcasp_afsx;
9 \/ A+ ]  r: w) q% Kassign mcasp_aclkr = mcasp_aclkx;/ N( u5 u2 {( N- Y+ W/ q) G' k
assign mcasp_ahclkr = mcasp_ahclkx;! K" u7 p3 E+ z5 z2 }! G
assign axr1 = axr0;

6 f$ y8 l0 w& J1 o6 C
) s9 j. p' ?/ `, K  s
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

7 C7 O0 Q) j7 f* d7 Z, b/ O
static void McASPI2SConfigure(void)9 P6 ^4 C0 S: z
{, b: c2 t4 I; D
McASPRxReset(SOC_MCASP_0_CTRL_REGS);. r* T/ m4 c' P2 j8 s6 f
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
- W* {' P/ h0 K6 {  pMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
. u4 E1 P0 ^* p7 oMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
4 T, B% B4 o$ }1 Y/ k, L9 ]* B) SMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
- a1 G( G/ o+ U: s' S* B. D; s& `MCASP_RX_MODE_DMA);
" ~- S  H) D; s+ p+ d/ E6 u" H4 I9 PMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,; ?, U' R) i% X$ B9 K) q8 ^4 T
MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
- w* v- \! D! pMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, 4 J) p$ @2 c4 E" k
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);# x" p. U5 c% @) W, X: e& M
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
6 [1 Z" g1 j2 I, o; F/ U9 lMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */8 Y  L! x6 T9 O5 p/ g3 d
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
2 u' a! \+ K9 R; T* z3 yMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
$ N5 g0 O' |2 Y$ b; E2 o/ P+ ^McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,6 D* T6 f' b  s' x- q( V
0x00, 0xFF);
/* configure the clock for transmitter */
2 G2 h7 q. U- X$ Y8 r/ d3 h6 a. J& s7 fMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);+ \# r" k, N- C6 I$ M2 p5 z
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 2 ?, U1 x6 Q% Z0 Z8 F# t% @' C
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,! V& m" o% b' c, T% T) @# f. @
0x00, 0xFF);; L9 e$ H& i+ J  f; T0 t# R
, Z- h# }, I$ h4 j
/* Enable synchronization of RX and TX sections */ : z4 R2 o: ~9 `
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
, ]4 ]; y! E$ X8 f0 v1 J9 w0 `McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);$ r* Z* o5 u5 p3 U
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*- X- q: b- C5 [( ^% n/ F; g
** Set the serializers, Currently only one serializer is set as
8 c; S- D, D4 t/ T( E7 @& X* {0 ^# |** transmitter and one serializer as receiver.
  a' a( ?& n! s& b*/. j4 K7 I5 i8 b9 r9 G4 o
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
4 T4 W& z* `+ aMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*" O0 f8 O6 P+ X# S
** Configure the McASP pins
" A) W- L6 ~1 g) S2 N( L" `** Input - Frame Sync, Clock and Serializer Rx7 m( r4 [0 g* {9 T0 x- }8 C
** Output - Serializer Tx is connected to the input of the codec 3 E  q  `% ]1 l8 r$ D( V
*/
4 l. x" F" C$ y  i7 G3 p" p+ e2 AMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);2 Y: D' D$ t" u
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));  ^; q- t- [6 j. H. t6 i
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
4 w7 m6 P4 @0 P| MCASP_PIN_ACLKX
4 h6 ]6 z. D+ w| MCASP_PIN_AHCLKX
+ {0 c: l) S1 j# U9 y/ R6 l| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
7 ?# V( g% A! C9 W% d: d  U' AMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
9 C0 D* m" G$ B| MCASP_TX_CLKFAIL
8 u0 V) W7 z. {| MCASP_TX_SYNCERROR, C- M/ K) t# R) N% W: X
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR 2 @' w# m2 ?" g) R3 `
| MCASP_RX_CLKFAIL5 i" X$ \2 ?3 S+ t
| MCASP_RX_SYNCERROR
, @" ^( i; \* N' z| MCASP_RX_OVERRUN);
0 W0 l; P3 J& q" ~}
static void I2SDataTxRxActivate(void)
8 }1 x( D) E! ^3 t) Y% y/ S{
" X% h. Q  [- K$ k0 B9 C1 g/* Start the clocks */$ W. O9 n( U4 C
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);& p  _! X1 y4 d. O
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
* h' J' ~5 L& ^1 b6 r1 k. NEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
. h/ ?" ?9 o" g# @+ i$ uEDMA3_TRIG_MODE_EVENT);
+ O* v8 e6 u5 MEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 8 z$ W: g$ ~3 t: i3 w- z" U
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */; \6 A) M5 u+ x/ N0 s: H+ }1 Z/ ?8 t
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);- A9 R9 `/ y  S6 Z# v7 u& L  C/ h* E( ^
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */1 ]- K) K# V6 }# L+ @
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */5 ^9 c/ c" c: v4 ]9 ?2 ]
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);! m5 A8 v; C, z
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);6 Z$ S: A2 n. S$ k* W8 \
}

! o4 K  s) T+ J9 d; E1 e
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
9 H# {/ C: d' f6 b! I- S
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-28 16:23 , Processed in 0.037332 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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