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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 10984|回复: 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,$ ?4 `! n* c5 i- {9 k/ R3 C
input mcasp_ahclkx,$ c$ E; X) K6 h; h" E( @- |
input mcasp_aclkx,* `4 A$ {. p! ~/ h
input axr0,
+ ]/ E( M" T3 D2 S2 f9 L/ p, M! N0 ^* L, w
output mcasp_afsr,7 }2 Z$ i- B! H# O
output mcasp_ahclkr,/ N, Y9 Y: v! z3 X
output mcasp_aclkr,$ S; v* ?, G2 w5 d
output axr1,
* b- i  u! u1 H' E0 `) j& {1 k& g
assign mcasp_afsr = mcasp_afsx;
& U' K' v: h7 R; p4 vassign mcasp_aclkr = mcasp_aclkx;
: @$ u+ d) D; G/ v6 ?. ~assign mcasp_ahclkr = mcasp_ahclkx;
* ^8 {. g' N7 b3 ^5 ~assign axr1 = axr0;
5 Y7 |9 W- Q- W7 C6 D6 p% x
5 H, D# j; r. G. P9 X: I% M
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
* u) [1 A3 S8 e' p" Q
static void McASPI2SConfigure(void)
1 p$ b" V3 m: A& l& d' G{
9 I6 j) X; m1 o6 r8 U9 vMcASPRxReset(SOC_MCASP_0_CTRL_REGS);3 f9 z6 a9 ^( R
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */( o7 G/ l* j0 l. w2 M- m) E. ~
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
) ~; n; {" U7 L1 \& |9 L# ~McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units *// j( ~( q$ K; s  M( p( L5 r
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,7 r" Y0 p. s! B9 F/ g
MCASP_RX_MODE_DMA);. `9 Y3 z  \' n5 ]* V, W
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
7 k( X# E, B5 i  }5 _; O/ _1 XMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */8 p& s( J- F, ~3 y' R
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
: O" n! V) V! a5 GMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);; g; c) ~! h' y# m: ^% j- a
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
- P: B" W. C! F+ K- d: K6 X% y- I: \MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */! P# T$ a7 K  B) |
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
: K; H% t8 R/ o# N  [, [) [McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); 1 ^7 }/ y) V$ n4 d" f) a% P
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
- Z* q/ t( ~  N; c$ I% F8 ~$ e0x00, 0xFF);
/* configure the clock for transmitter */; K$ t4 w: j" |2 x
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);  P7 u9 @3 t) G. w
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
+ R. _+ ?2 v, a/ {McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
0 S" p- F+ b+ i/ B0x00, 0xFF);, y4 q7 y6 e) i0 a' Z6 ]

; H& H# [% T2 \! S# r/* Enable synchronization of RX and TX sections */ ) s, n7 U/ h# }% p. o+ P; @
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
/ A; @, i5 \, L3 J' k7 eMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
* U+ x5 P, u5 s2 [+ g3 }McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*7 m& c5 y% D' L# z0 E* N  P- Q+ U
** Set the serializers, Currently only one serializer is set as- T$ ], \+ ?- p$ F4 T% [
** transmitter and one serializer as receiver.( ]4 H( ~1 O) h& W4 Y# g! k) L6 O
*/
) x/ a. T0 @' ?  G/ o. n5 l/ MMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);/ N% I9 t& B* W
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*1 ^# `6 Y8 u7 l* h6 j6 Z
** Configure the McASP pins / L$ k9 w9 j9 G: f. n4 S+ u( `
** Input - Frame Sync, Clock and Serializer Rx
3 T6 U) ?, D7 S# V" j$ {* Z2 k** Output - Serializer Tx is connected to the input of the codec $ x4 j" q& z0 U( b2 s) C( s
*/
5 Y- t0 e! {$ A. \McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);3 f/ w! @1 j$ m) b
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
2 U: P: F+ x1 Y5 s) R2 O- dMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX. p6 z. f! a* F  e: N
| MCASP_PIN_ACLKX
) f1 y: C5 z) z# c| MCASP_PIN_AHCLKX
' O  s5 G, |) p) Q8 r4 M| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */8 ^4 [- Q5 |$ A$ j7 [
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
6 E3 K/ C% \2 m: ?| MCASP_TX_CLKFAIL 9 L/ F( z& q* o) K( |& D* m
| MCASP_TX_SYNCERROR! h  |  V) n8 l* d  \
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR " n/ S# d' l! m0 U
| MCASP_RX_CLKFAIL. _5 |/ I! n: c& {9 K. o7 B0 d! [
| MCASP_RX_SYNCERROR
# t5 ?9 O% f: \| MCASP_RX_OVERRUN);' ]5 ~% J5 b: x
}
static void I2SDataTxRxActivate(void)
3 K0 E# i4 O9 o$ X5 \4 o1 j{
3 J+ m! o# B: c- O, E( h4 J/* Start the clocks */" r9 g8 c. \: _" }6 p; I* y. p
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);9 s! q& d# l: J1 L
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
) R- k8 F& k7 a$ oEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,5 n1 y3 j8 ?3 O6 W% L# V8 \1 U
EDMA3_TRIG_MODE_EVENT);
$ W; o+ I* N9 d- Z% ]% k& uEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 8 P9 C$ ~2 ]& ^+ V
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
$ s8 Q7 @/ P* ^% P/ A, UMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
/ I# Y' H! e* L$ FMcASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */' n3 N, k2 z1 L* Z( o) y
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */( B$ f! n( e9 @( \4 ~2 L
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);4 X3 ?7 L3 t" w* t. _+ [
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);! O/ ]: k2 Q2 k1 Q
}
5 e5 Z) G# C) m' f  }; w
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
- V# ?' I* s. F' [! K
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-2-21 07:06 , Processed in 0.047784 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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