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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[未解决] MCASP自环配置。

[复制链接]

6

主题

12

帖子

1213

积分

金牌会员

Rank: 6Rank: 6

积分
1213
跳转到指定楼层
楼主
发表于 2018-11-7 13:28:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
$ `; C0 w- `7 n2 e3 n* F' @6 [: @input mcasp_ahclkx,3 j, w3 G8 F3 J7 c
input mcasp_aclkx,
# m  z9 b. }# O: jinput axr0,3 \0 g% i5 [, e( P9 N+ E; C
/ C9 l' v" A: E' Z
output mcasp_afsr,
" q/ H/ ^3 H  L" s: `& ~1 Z& R' Toutput mcasp_ahclkr,
- i. i3 |8 x+ U1 U+ g& joutput mcasp_aclkr,7 G1 k+ n* ^8 K+ E5 q
output axr1,/ G& l6 u, A2 l  B3 f
assign mcasp_afsr = mcasp_afsx;" M% B7 V1 |. X8 l
assign mcasp_aclkr = mcasp_aclkx;
# e9 p$ U+ P0 ]assign mcasp_ahclkr = mcasp_ahclkx;
$ N0 ^' K' C) h/ Z7 [0 Y' Jassign axr1 = axr0;
6 ?2 _& i0 u" a; B- H* h
3 i8 @4 Q, A) |" ]* I3 V. p; }) C
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
4 \5 G" [+ G' k; X" G( ]0 g$ X
static void McASPI2SConfigure(void)4 C4 ^6 [( f/ F
{
8 q3 Z2 m' Y/ a; w$ W/ ~; V7 hMcASPRxReset(SOC_MCASP_0_CTRL_REGS);
: V4 h8 P. D5 ^' w) E' YMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
+ J: P  m+ J4 V- mMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);* Y: r" Y! F# U8 v/ k6 k
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
6 Y$ J6 O* D2 ~4 J8 X6 WMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
  e- R. ^0 H1 l' R. U# B0 MMCASP_RX_MODE_DMA);( A, U# x+ j# k
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
8 k1 q' W+ [' `% EMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
( P8 m1 q7 G, O, pMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
" j) Y: U" n- I) |& P7 PMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);  y+ R3 f( |0 S
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, ' ^- d( T0 m6 L% J( S
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */; M; S3 ^$ Y& M; O0 Z( I' e9 D; s& l
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
' ]5 s7 |+ o6 rMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); - z9 ~+ S4 X0 h) ~) Y. A  J
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,( \$ k+ p' j3 R# A& G
0x00, 0xFF);
/* configure the clock for transmitter */
" ~( X' d+ }! Y6 e. r/ N2 _) u# ]McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);6 \* t- r2 ~  V$ N
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); , v# ~1 [4 S4 }1 w
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,4 s% M1 o: [5 ]5 l
0x00, 0xFF);( j' a/ O" k/ ^

6 y4 q+ ^, Z# K/* Enable synchronization of RX and TX sections */ 3 K  e8 W. }# S) i4 d  t
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
" ~7 ^( J: d" {. }McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);0 |' a0 V! {- ?' V
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
) c$ b% i9 n" i* V( ?** Set the serializers, Currently only one serializer is set as
4 l. D! C! H  N3 D8 h** transmitter and one serializer as receiver.
1 d. c7 A9 O4 t7 X*/
. V* Q: |* c! o6 U: H3 e" aMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
! [. L  `8 k; u) U' ?7 Q6 c$ bMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
- |. L$ i$ b3 W, r+ o** Configure the McASP pins / U1 ?+ Z5 Q  N, G" L6 E
** Input - Frame Sync, Clock and Serializer Rx
% D0 ?8 [9 l) C: J- w** Output - Serializer Tx is connected to the input of the codec 9 v9 {  \! ^4 q. D
*// x3 H% i6 P: X2 k+ z* l
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);" ?, E# v% Z/ ]% e( b6 K
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));* ^* A) E: `8 L5 h( p9 S
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
  D* y1 K- T( S: @& g7 S$ e| MCASP_PIN_ACLKX
7 c% T* y9 K4 ^" E' || MCASP_PIN_AHCLKX* v3 e7 f4 k0 [% g2 N
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */+ i* _5 L* Z3 ]' k8 `6 g( p
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
- o% c) a0 W2 O5 ^) h* M| MCASP_TX_CLKFAIL 8 w  R% c: @/ O& U) _
| MCASP_TX_SYNCERROR
) J9 ~: `# x" ?| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR % E7 C5 y, h2 W  P& l
| MCASP_RX_CLKFAIL; r% V/ Z+ Q+ r
| MCASP_RX_SYNCERROR ; D$ ^8 h: K# p! V6 M+ Z/ y; `% t/ w
| MCASP_RX_OVERRUN);; ^5 H5 U* ^- Y' \- W0 c: c
}
static void I2SDataTxRxActivate(void)0 Z/ Q' a) @$ n* x6 {' m3 F7 s* Y& k
{
6 \1 }' q/ ^# w3 K: t9 W2 a$ F) r/* Start the clocks */
$ s/ \! ]: U& _/ P8 hMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);# ~/ n8 _0 C  A' y* v
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */1 n# n. Y' K" D5 K- S* \7 g
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,+ `( o1 c+ K& R2 Y6 h6 U
EDMA3_TRIG_MODE_EVENT);9 i) z' a; l3 A- f- a( z7 \
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
6 p& w  P! b& B' ^5 B* DEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
/ c- f7 J% S* C1 |) b# hMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);( L: ?/ z) N* F
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */
! q: i" U3 F% g! n, s4 pwhile(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
( ?7 |+ Y4 b; P/ AMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);
) h1 H7 q. \9 }% yMcASPTxEnable(SOC_MCASP_0_CTRL_REGS);/ u' p  X* G. V
}
6 X5 F9 x- J# c: L  n5 i
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

$ \$ h% S6 W( h* x4 S- T! x8 h2 n/ t
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-31 17:12 , Processed in 0.039036 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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