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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1215

积分

金牌会员

Rank: 6Rank: 6

积分
1215
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,- Y  P- |( N2 N1 A6 X5 h: T
input mcasp_ahclkx,
9 O" j1 y6 U4 O8 }4 y; xinput mcasp_aclkx,
4 L( j" `' @& X# |input axr0,
/ j+ `0 z4 v! e. ?- U- [2 d2 L5 @/ \% a0 J- r8 d
output mcasp_afsr,
0 n  A8 s" z% C" P% D, H/ x% Routput mcasp_ahclkr,
: Z" O$ A$ c; F1 T+ I& T# f1 d7 n% toutput mcasp_aclkr,$ {# k% g3 f; _  z# X& X6 \
output axr1,
  h% X7 m* C! t2 D, j. ]
assign mcasp_afsr = mcasp_afsx;
4 M. V9 p9 ^( s$ C) Wassign mcasp_aclkr = mcasp_aclkx;0 j5 Q. q# U" M
assign mcasp_ahclkr = mcasp_ahclkx;" @4 J, V. d' i8 j/ ]
assign axr1 = axr0;

. y3 v7 I$ ?1 L2 f1 P
4 m0 g, \, ^/ o
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。

: o3 F0 f( f/ D. k
static void McASPI2SConfigure(void)$ G/ y1 i% Z% F. {& @
{
) Z- B' x' ^% S9 ^6 P6 MMcASPRxReset(SOC_MCASP_0_CTRL_REGS);* @$ h9 p# |0 x0 h5 v& \3 N: L
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */! P) @- {5 A% Q) z
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);* |- b* ?5 w; Q  d- K3 _5 V
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */1 E' S+ K1 |9 W" P
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,/ I2 K1 @" e) ?2 ?! D3 t
MCASP_RX_MODE_DMA);/ ]6 \) j1 Z3 v: {# R* E7 ]
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
5 P/ Y+ d5 n% q7 p2 x7 R2 l0 E2 V# mMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
  b7 i! Q( ^, D) j- ]8 w4 XMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, + g1 v0 J; G7 d: u6 L6 I
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);  }- R) Y; |0 U1 e1 E& z
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, ) R$ M% L( x# t* R& E; ]7 b% l  O
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
! D0 w& P9 G& u. G9 Q; GMcASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);& o+ w. I2 S  C! _
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
- }* K, u; c! ]: s- [& w8 jMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
& F0 o. ~$ Q% B- r" x8 O8 M0x00, 0xFF);
/* configure the clock for transmitter */% e1 a& _* c' ^' O- U; s$ N2 @
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
5 p/ D3 r5 X4 [2 [6 rMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); # f; _9 m, s% ]
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,5 N3 ]( I/ k& I# R: \7 j
0x00, 0xFF);' Q' G+ v0 J" D' u
7 J1 l% h6 M' p3 P
/* Enable synchronization of RX and TX sections */ - I& G8 }0 f2 h( X
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
5 M# _- f) }  K/ n9 M6 YMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
( h0 h( n: L% ^- s$ g* c! M. DMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
; Z9 }7 r+ W3 q7 l) X& m# C) I** Set the serializers, Currently only one serializer is set as& C3 \! S+ ^9 b- n
** transmitter and one serializer as receiver.
  v. x8 u6 T+ d( x*/4 s! h. t; m. {) q* _& F
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
: E0 a: }; L9 ~) M. g& rMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*& u4 b- E/ z9 R$ o) b, N6 ]
** Configure the McASP pins 2 C' e* a# X4 E/ K$ _
** Input - Frame Sync, Clock and Serializer Rx
8 r* d, f- ?( \0 V9 L** Output - Serializer Tx is connected to the input of the codec   L; p9 i/ y# M7 m
*/- d0 |' r# ~5 R& v& b2 m
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);/ l& \  ~; r0 \0 m9 C
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));- q4 Z8 T' m, w0 k. F  D
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
( C- e" @& e1 Y| MCASP_PIN_ACLKX
/ h% T% W% p1 F2 g$ I| MCASP_PIN_AHCLKX8 X1 S4 X" q- g( r5 n$ `/ ?
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
% k& ]" f; |/ a' u6 f" l, k6 IMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR ' t( k  i9 Z- \) E! Y  a
| MCASP_TX_CLKFAIL 2 W+ R! ?  ]& S6 t. h
| MCASP_TX_SYNCERROR
! k2 s1 o+ Y( F3 y| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR $ W# u6 H! t$ M* @% O* u/ k
| MCASP_RX_CLKFAIL
7 O* I, G" \5 S0 k& a| MCASP_RX_SYNCERROR ( \2 t+ R1 u! }3 [
| MCASP_RX_OVERRUN);4 O0 {- }& ?. g5 r# q  v
}
static void I2SDataTxRxActivate(void). @/ N  N, l8 P1 d7 U; I. k
{( f& t# m: p  `% c9 q. W
/* Start the clocks */
$ M# o+ P; @7 eMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
1 W" z1 W$ h+ F3 j. M# ~, I" d( V' cMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
, [2 q6 ?( p8 f# W, ]EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
2 B' G8 K1 Q: T+ HEDMA3_TRIG_MODE_EVENT);" _* U+ X9 |0 ]( n# V& t# D- [3 B0 {
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 7 X! A  x" d8 q+ c
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */) ^5 z- b$ e# b. w: |
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
( e1 w3 L$ t, ?2 F" AMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
7 r1 y' k3 j. k  Twhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */5 }4 k: K- ?6 n: ~- `7 @0 t# O
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);* @1 }' J4 h. c
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
# r) R) C2 d% q! t5 \, k9 Q4 c8 Z}
+ E, A( Z3 q1 O6 \, t
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

, O2 _5 ?% h4 n
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-15 15:04 , Processed in 0.039368 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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