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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 10115|回复: 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," o7 v5 ^3 I, S
input mcasp_ahclkx,' ]! x, l% ~" D, k* J5 r6 U
input mcasp_aclkx,, W1 h2 D  T1 X- b* i2 k
input axr0,
1 |5 M# b9 K# p4 _
0 v; i5 _, l- P. D8 Z! Xoutput mcasp_afsr,
  Q( A, E! E7 z; Noutput mcasp_ahclkr,) q3 Z3 T% R2 z1 R  R5 u
output mcasp_aclkr,
! m- s/ A; x0 g/ R; Q! B2 A( z' h: joutput axr1,
% I0 @! X/ n: H* K
assign mcasp_afsr = mcasp_afsx;6 a- `9 g" r! Y
assign mcasp_aclkr = mcasp_aclkx;% m. Z' u6 E: a
assign mcasp_ahclkr = mcasp_ahclkx;
9 t/ q: n6 i, o9 k+ C# Q9 e, f' H$ c2 bassign axr1 = axr0;

3 w/ H# |* u9 S1 @5 j. z8 f7 d6 G8 i1 A
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
- h/ s+ t" E6 p/ J
static void McASPI2SConfigure(void)4 u4 ^' D/ r8 {' _  h9 L$ t0 |
{
8 z6 m8 L! t  {2 X! S1 GMcASPRxReset(SOC_MCASP_0_CTRL_REGS);$ B/ [8 Q6 k! ~9 B4 ^/ D" F2 O0 v
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */* u0 x  k: g, K! g9 C
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);: F9 p  b6 E4 r% e
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */8 ^8 c' ]" ]1 |+ h* Z* x% y. q( ~
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,  c! B+ r  c, _% ?( n6 H
MCASP_RX_MODE_DMA);
& ^$ F+ l* c9 Z* o4 y- G3 w$ b- r" tMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
; i; o/ s% ]; ^, KMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */2 Q$ _6 Q5 x$ ~1 R' G% E
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
/ j  R+ N# e  i; Q5 _) QMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);; x' _9 J7 B, @6 K0 f6 V$ h! F, K
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, : V' C  A4 q4 B3 |
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */. @) w; g0 h# r4 O
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
. U  [* I1 e& ?  Z6 S- dMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
1 u% Q1 Y7 e  S" N+ SMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
6 n, f9 i, }3 l% D: Y% n3 ]$ q0x00, 0xFF);
/* configure the clock for transmitter */
# [$ b4 I5 r. I) c. l1 L/ \- yMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);5 Y* f; B- ?: B
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 1 u4 n& A' X& U* ~' d2 k# h5 i
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
0 s6 p8 U& g7 {% \  [0x00, 0xFF);
: E; o' Q3 ^/ W8 C+ ?- h/ X' R6 y. y- v& @0 V; H( ?, C
/* Enable synchronization of RX and TX sections */ $ r4 o! e5 B; t6 y
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */- ~% P& z7 i/ V- A; O2 n5 d9 a
McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);/ j' o8 C! ~3 M" e
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
' I8 A- U; }  }: r! x1 _' a** Set the serializers, Currently only one serializer is set as
( E. e1 n- E5 D# F" q1 d" v** transmitter and one serializer as receiver.- g  K: p) }! o3 v+ A; Q: [) a. Y
*/  c; }% z+ h4 H  E% ~( |
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
! o) J+ u! d+ YMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*+ ]% k6 z0 ~: @% X8 z. F$ D/ v+ t
** Configure the McASP pins 2 n8 Q$ T. F* L7 `9 p
** Input - Frame Sync, Clock and Serializer Rx
7 ?$ [+ ?9 W- ^# E) K** Output - Serializer Tx is connected to the input of the codec ; @7 ]: v5 z) e" Z: l
*/
6 i# J* f1 p. k4 v! j9 cMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);& U( Y/ B! D! l% p9 o$ I; m/ }  @3 b
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));( s$ g  W0 b6 x
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
  K7 Y5 e+ O4 F| MCASP_PIN_ACLKX
+ ]& H) z$ G* }6 P, E| MCASP_PIN_AHCLKX
3 e- q2 ~1 l3 [2 O$ q| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
5 ]4 K+ O7 Q( X9 U0 p# fMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
4 p% o$ |9 |7 T$ h+ s: ~) E/ K- T| MCASP_TX_CLKFAIL ! u# U3 c0 K$ p: {
| MCASP_TX_SYNCERROR
# \. @: _5 C6 h8 B( ?. b7 ?, Q9 E| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR - Z+ e$ w: I  A9 y9 e/ f' U
| MCASP_RX_CLKFAIL7 [3 Z* C4 }- X# B0 ]' _: Z
| MCASP_RX_SYNCERROR * \% O; h8 L$ R
| MCASP_RX_OVERRUN);% g3 J, R, @# g0 Q+ z
}
static void I2SDataTxRxActivate(void)
9 y- T' y. N# ?) X: ~' \* h. W{- V" p! `% \1 a! A
/* Start the clocks */! ~0 P! p* T8 C, e
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);. \4 p+ n$ Y8 a2 D9 c
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
5 y9 o3 j0 y" R6 QEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,. X# z% y6 n4 l: j7 {' p
EDMA3_TRIG_MODE_EVENT);
  Z8 S+ X  Z5 ?EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
- a5 F5 f* @0 F9 gEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
" {5 O2 ]9 Z5 p4 YMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
  C5 M4 X2 t9 l3 C5 `5 Q! k: lMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
. n( K1 |$ t8 l% ]while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */# w% Y7 O+ @4 S1 [: d
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);' I9 }1 n1 ~; W& @8 X# _# K
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
/ _; O0 M/ D" [- h: H9 W}

7 G1 A2 x& b! I& D' r. @! G$ w
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

0 F7 H8 `1 L! J  I
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-29 05:49 , Processed in 0.040017 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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