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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 8701|回复: 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,9 ~( n1 e; @6 N( B( |. `; v) m3 {6 r
input mcasp_ahclkx,
9 d( ^/ H/ ~+ ^" Sinput mcasp_aclkx,
: a/ o9 N/ Q6 n. b" `% y0 k, Zinput axr0,  o, p5 W# w" l6 m! J
0 p* V% X( `9 g9 f
output mcasp_afsr,
) w  Y7 u, z( X7 Q  V$ Boutput mcasp_ahclkr,) |$ b3 _( B/ E. x
output mcasp_aclkr,
6 R6 g7 f/ v" e/ i# Soutput axr1,# K: q' K3 J$ l) l& p: _# C% S
assign mcasp_afsr = mcasp_afsx;
1 B; D3 @5 F$ q8 Q' s. Qassign mcasp_aclkr = mcasp_aclkx;
1 ~5 ?: O. b5 _" O3 t' b( o. passign mcasp_ahclkr = mcasp_ahclkx;4 z/ A% g& Q! u- s
assign axr1 = axr0;

' i8 {0 H: d2 \; o2 J; M$ D2 L" E6 a+ Q! j$ e
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
5 W% u" A2 ~1 b6 O3 R5 G
static void McASPI2SConfigure(void)  ?. \* I  I( M5 t
{- ^7 X' {; j- c' X" m
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
  a  O! h5 v6 v( w' uMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
) B6 }9 b! y& n# EMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);* {  ?& O- W# X5 a. V0 b
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
3 ~2 S9 A4 n, t2 q" ?+ e) W( S' R0 bMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,& _$ [. `3 e6 s" ]
MCASP_RX_MODE_DMA);
, B' }0 ]+ M0 t5 ~0 Q6 c$ p# Z( HMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
- N* z; h' V+ e! O3 ]- I9 W" GMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
/ g, L( X, y! _9 U# T( ^McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
' o: I  b& }& NMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
7 ]$ ^8 U+ a9 ~/ F, CMcASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
( z8 k, @" Z& U; L, yMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
0 B' U& M" u4 ]McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);' c9 r  X: c4 Y+ a% W  _
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
3 M8 @* H* \: u0 ?6 e7 L) `+ W4 EMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
0 e/ ~- P5 j) z0x00, 0xFF);
/* configure the clock for transmitter */
6 K$ _) v6 L" hMcASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
9 _7 b5 t9 |8 {$ ZMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); + J4 z* w4 ]6 O; l( E+ Q9 {
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,! }, ~4 c* |3 M% a3 F
0x00, 0xFF);& Z0 z. h% x0 a! l; |# k7 a

  Y6 q- a: |* F) Q* h$ {/* Enable synchronization of RX and TX sections */
  _' M9 R5 R* j2 TMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
+ d2 B  o/ q9 W0 z/ X3 OMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);4 D5 b1 V( \6 Q5 o6 A# Q$ U8 x: T& t
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
6 |! M: N3 o$ E5 P$ l** Set the serializers, Currently only one serializer is set as+ M  O' U  u( _, n6 k
** transmitter and one serializer as receiver.
; T9 A6 j. G. s, x9 ~2 A/ C! c*/
/ z- W* V% }5 j; z) s# ?McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);+ P) ~3 K) H8 C% y8 b; w' l& l1 G2 Z9 o
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
0 Q9 k, }$ L4 D  b- D, K** Configure the McASP pins 5 {* o+ j8 m7 M! X# F$ @9 c) f
** Input - Frame Sync, Clock and Serializer Rx+ y1 T6 e& P0 T. D, m
** Output - Serializer Tx is connected to the input of the codec
, F  h- a/ E, v9 p) i5 G- L; o*/6 L$ G, v5 Z2 p
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);9 R/ y+ K; O, b6 P! G6 i
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
& |0 v1 I( j$ Z% \' q& l, E* eMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX8 B" V9 J9 H% R1 [/ j/ a9 k
| MCASP_PIN_ACLKX
. R+ U, S- D" y) Z3 Q| MCASP_PIN_AHCLKX: X  v3 Y7 v/ ^7 m& k! L# @
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */' P# @# ?" p$ E8 _2 ^
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
9 _) ?: t" n9 P* [8 D' ^; c| MCASP_TX_CLKFAIL * ^# Z5 b7 L  J$ O* Z& a
| MCASP_TX_SYNCERROR$ b# [' T. @2 z. {( z' N) a$ o
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR + f  e; d( a, Z/ T& G( w
| MCASP_RX_CLKFAIL1 N* t9 A% a' {' R& \2 v0 q
| MCASP_RX_SYNCERROR
; e$ p8 Y, }$ Y0 J7 V| MCASP_RX_OVERRUN);( e. c" J9 }8 G+ |! Z
}
static void I2SDataTxRxActivate(void)
  H  V- b* d  Q9 i2 P' X" D{$ [3 s0 o' y6 i1 ]4 M
/* Start the clocks */# l, y8 ]- Y6 r- {  K
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
  j6 B% l( D$ ?9 UMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
, k' f. C  p; uEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,! h+ A  ?8 y* e' [  }
EDMA3_TRIG_MODE_EVENT);* A# ?  _- L  a
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
4 k) e# C' d+ |2 x9 l* X5 [EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */: s/ [: U  o  H/ L6 ~8 `
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);# `; o5 Z5 K( M! v! N7 T8 D
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
  U$ X' C0 i" d# ]9 Pwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
9 [% _& x1 Z8 W3 }2 XMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);# S( l0 ~0 L6 R) G2 g, C6 \8 ~
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
! k& q1 ?( y& F2 g}
/ n- z; e* l; r! p. z
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
1 T5 K. p; ]- W$ W% g
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-2 13:31 , Processed in 0.038709 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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