McASP无法通过McASPSeriActivate(); 请帮忙看看问题所在? - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9366|回复: 6
打印 上一主题 下一主题

[已解决] McASP无法通过McASPSeriActivate(); 请帮忙看看问题所在?

[复制链接]

1

主题

5

帖子

1027

积分

金牌会员

Rank: 6Rank: 6

积分
1027
跳转到指定楼层
楼主
发表于 2015-10-29 09:47:24 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我的McASP配置分别如下:1 r; n( I' v! N3 c$ G: {
管脚的复用设置是:- L* U' X( w3 p: {2 c8 y
void McASPPinMuxSetup(void)
4 t% _2 q% m& l1 J5 }: o4 ]. s{
  G& f" T8 ]0 r5 z2 G/ _9 g    unsigned int savePinMux = 0;
. o0 P) f4 n0 a, J+ j    savePinMux = HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(0)) & \
; D3 ]0 L9 }  l# A- R                       ~(SYSCFG_PINMUX0_PINMUX0_27_24 | \; T6 S& S6 ^7 X" b" M- u
                         SYSCFG_PINMUX0_PINMUX0_23_20 | \5 k; P$ U. V! ~) L& v6 i
                         SYSCFG_PINMUX0_PINMUX0_19_16 | \% H0 k6 |5 ]( c
                         SYSCFG_PINMUX0_PINMUX0_15_12 | \
7 ?6 y7 ~& o1 R5 |" J                         SYSCFG_PINMUX0_PINMUX0_11_8 | \
$ C# X4 {9 h) h5 |; ?3 u                         SYSCFG_PINMUX0_PINMUX0_7_4 | \
8 w9 ]# d  Y  i# s; }2 F- C                         SYSCFG_PINMUX0_PINMUX0_3_0);2 Z: T2 t# y, d, D% X
    HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(0)) = \' D3 y2 i' v* _) w7 C
         (PINMUX0_MCASP0_AMUTE_ENABLE | PINMUX0_MCASP0_AHCLKX_ENABLE | \$ ]  w6 L; o+ I# Q, l+ X
          PINMUX0_MCASP0_AHCLKR_ENABLE | PINMUX0_MCASP0_AFSX_ENABLE | \
: f" s; {+ _; L* U          PINMUX0_MCASP0_AFSR_ENABLE | PINMUX0_MCASP0_ACLKX_ENABLE | \0 `# k8 T- n2 G$ _$ Y, ^
          PINMUX0_MCASP0_ACLKR_ENABLE | savePinMux);* Y9 H/ T  E1 s- f7 E8 Y; s; [- q
    savePinMux = HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(1)) & \
; U$ Q( d* M6 o3 I) {, ~5 I                       ~(SYSCFG_PINMUX1_PINMUX1_19_16 | \
$ D9 }# u2 o1 l                         SYSCFG_PINMUX1_PINMUX1_15_12 | \
9 q$ R- M, B: s                         SYSCFG_PINMUX1_PINMUX1_11_8  | \
# L+ C5 E" d$ Y/ _4 r# j0 F! G# V                         SYSCFG_PINMUX1_PINMUX1_7_4   | \! e7 r; Q$ N% n
                         SYSCFG_PINMUX1_PINMUX1_23_20 | \
+ J: P5 f( U/ e' i7 L- U3 S                         SYSCFG_PINMUX1_PINMUX1_27_24 | \. K+ y, z. r$ `) U! M4 A
                         SYSCFG_PINMUX1_PINMUX1_31_28+ P5 b* N4 Z& X) F
                         );7 M% v. \! ~% g& i" f/ t2 y7 J+ N
    HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(1)) = \& T  S5 J' }7 X: N: ^$ L% l1 j; U
         (PINMUX1_MCASP0_AXR11_ENABLE | \5 p7 `/ T9 v8 t7 `
          PINMUX1_MCASP0_AXR12_ENABLE | \
" Y- l$ u! |& Z3 B          PINMUX1_MCASP0_AXR13_ENABLE | \
( f) L, Q8 y# `/ `- x* e          PINMUX1_MCASP0_AXR14_ENABLE | \; e( Z& \$ [6 G
          PINMUX1_MCASP0_AXR8_ENABLE  | \4 q3 L; |1 H" s! K" K. l
          PINMUX1_MCASP0_AXR9_ENABLE  | \
2 _6 \" n3 p+ `* b2 g          PINMUX1_MCASP0_AXR10_ENABLE | \
/ `# }2 K( f4 i7 x. j1 A0 ?% J! J          savePinMux);
; b0 A, B, t7 O& D' {! n4 v" Y}
9 a' z# }0 s$ L7 Z7 V3 x# q! [
1.McASPI2SConfigure(); McASP的配置程序如下:1 v4 y& \1 o9 X) H! k  B
static void McASPI2SConfigure(void)
% ~7 ?- m  r- k  r& V{
/ q  z! D# a1 C* ~' u    McASPRxReset(SOC_MCASP_0_CTRL_REGS);( `8 f% ^3 M) J; }! L. v
    McASPTxReset(SOC_MCASP_0_CTRL_REGS);
$ I# D! q5 i$ I1 W
+ k9 f* J* p7 t+ f: v    /* Enable the FIFOs for DMA transfer */
7 u) P: W$ q# `1 u4 ]//    McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 6, 1);
2 `0 e9 C4 s. c//    McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
1 S0 S( e: i) k( p
" S0 L1 f' v. O: F! |% P! E0 {    /* Set I2S format in the transmitter/receiver format units */
: I- A3 B6 Q- W9 u    McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,) m3 q, B+ f  e6 Y4 P' \( B4 o) n6 m
      MCASP_RX_MODE_NON_DMA);
- H# w! Y( [' `: C    McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
. Q! m9 V; |1 R; p& w      MCASP_TX_MODE_NON_DMA);' ^/ i# S4 N' I5 m/ h8 T7 V
: }- E! o' S3 a5 B$ b
    /* Configure the frame sync. I2S shall work in TDM format with 2 slots */
. L$ ^! s7 s: W% Z% H    McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, ( U3 K, n- Q) N) h  l- Q
                        MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);8 W$ k8 b9 s" f# ]9 |
    McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
: z& o1 \+ [9 Y7 F1 a. q+ t0 e                        MCASP_TX_FS_EXT_BEGIN_ON_RIS_EDGE);
4 I% m( w: \$ Q8 g) K4 w4 W6 a
& m; h! O0 V  L% a0 @    /* configure the clock for receiver */4 O" v' z$ V2 ~9 ~# [7 u
//    McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_INTERNAL, 16u, 16u);
* Z" o8 `2 x% O  ^+ ]0 ]8 N    McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
- x, k+ |0 }/ X    McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);, E1 Z6 K3 g* V
    McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
0 Q' X2 I) z5 {0 S+ @/ P  ~" z                          0x00, 0xFF);/ E( {0 ?+ r5 n4 F% U
0 @  H! {. {& w
    /* configure the clock for transmitter */6 {0 U7 u8 [+ |  u+ W4 f
//    HWREG(0x01D000A0) = (0x00001F00);9 u' u6 y* J, r7 s& D- P
//    McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 16u, 16u);- Q4 z/ A3 I# @5 ?! i
    McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_EXTERNAL, 0, 0);
, l9 {+ f1 n$ m9 f8 k& o    McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);1 Y9 N" f7 i- s0 x- r3 {* J
    McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,& F2 j3 R) _& q2 z; P
                            0x00, 0xFF);
, c8 H$ M4 ]$ R' c: q
/ ?7 e2 P6 x$ ^    /* Enable synchronization of RX and TX sections  */  - Y  ?# B! ]$ z$ p
    McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);- b/ k0 b3 |, p: Q, u! Z: {

7 b7 d8 k* N7 F/ E# t- O2 X6 g+ T: i    /* Enable the transmitter/receiver slots. I2S uses 2 slots */+ p) }% @* l5 n& x0 @
    McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
2 n; Y. d# R' @& a% C    McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);0 T* l2 S8 O; s: v' q

* n  z; S( @* L( d0 e+ r, K    /*
) r- T+ p% s9 ?' w, r; |# u3 U    ** Set the serializers, Currently only one serializer is set as. N+ X* X1 f& R  o
    ** transmitter and one serializer as receiver.
' P( ^* i4 I3 W$ S    */, {: |% o* `9 h' _* W: F$ q
    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);1 l1 t( m+ t9 ^8 d
    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, 13u);
- M% V: `) L3 L. k# b1 T    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, 14u);; t: q2 g" E' m% r
    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, 8u);+ W8 G  T9 ^1 h2 h8 r  L
    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, 10u);
+ p+ ], ]. {' B    McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, 11u);! Y1 v* v7 r$ A2 i9 |$ v* B

9 g9 Y9 M" A  b. N( O    McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
* @) q: A" E- k8 N( H7 p) S
9 O* v; W  i5 q; O+ a$ ]! w! i& Y    /*
7 K5 K8 y8 v6 A% H% F  ^6 ~( W- `6 q    ** Configure the McASP pins
' V% Q, d: N+ l: s2 h; c) r$ c6 B' @    ** Input - Frame Sync, Clock and Serializer Rx; z- B+ z  ^9 d8 `+ s5 X
    ** Output - Serializer Tx is connected to the input of the codec
& a8 P0 o6 Y2 ?, i" f/ u" D. V8 t    */7 ~/ Y1 [/ _( {- S- X
    McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);/ _  {0 F& ^* N1 O5 z5 r
    McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,) [8 f2 K# X" N4 L
                                           MCASP_PIN_AXR(MCASP_XSER_TX)
4 k# i# m9 u. V                                         | MCASP_PIN_AMUTE
9 I0 N+ m  k% \8 Q8 B, n; \                                         );
. B' [, b8 Z9 U$ t    McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS,
/ L7 Y2 m6 x, T, \                                           MCASP_PIN_AFSX8 @0 z; Q1 ~% ~5 X2 `
                                   | MCASP_PIN_AFSR& r/ S' K  G9 W( [6 D3 X5 ~
                 | MCASP_PIN_AHCLKX
3 P; X* L6 a# l& j6 @3 D) P                       | MCASP_PIN_AHCLKR
1 L: t; F/ ~# H5 u0 [+ M7 `$ z                       | MCASP_PIN_ACLKX- G, Q0 s, w) v2 P$ f
                       | MCASP_PIN_ACLKR
: x# g; z) ~  ~0 B, f- _3 o                                               | MCASP_PIN_AXR(MCASP_XSER_RX)
2 c8 Z5 U! [! N: `3 r. X3 n) G2 }                                               | MCASP_PIN_AXR(1u<<(13u))
# a% ]/ g8 M5 y. F! j2 C8 Z& ^                                               | MCASP_PIN_AXR(1u<<(14u))
7 }; u6 t, }: C                                               | MCASP_PIN_AXR(1u<<(8u))
7 I( A; s$ W( b$ ^3 X                                               | MCASP_PIN_AXR(1u<<(10u)): Y+ i& o4 n0 D2 l* c2 w* J( m
                                               | MCASP_PIN_AXR(1u<<(11u))
1 P, q, M% F  `4 E7 @                                               );* b& w  K  A  s2 v
8 w# }  K  {% s+ i$ f
    /* Enable error interrupts for McASP */
8 Q9 E. M1 h$ Y5 |, R; T' Z: T    McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS,
/ ]9 t3 p$ K0 ~( V                                        MCASP_TX_DATAREADY
" H( q( {7 E4 W& Y$ L9 e                                            | MCASP_TX_CLKFAIL 6 V! R0 E2 ^# K
                                            | MCASP_TX_SYNCERROR6 N% i- {8 R( g- M2 z$ Z! p
                                            | MCASP_TX_UNDERRUN);6 z) E* s8 ]% L" h4 E" C

5 @. B$ v  k; I; y1 |  }9 o; U    McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS,
" ?1 `* b) h" x- X) V. v                                        MCASP_RX_DATAREADY
: {1 Q- h4 {2 O& R$ e& v7 z                                            | MCASP_RX_CLKFAIL6 P0 h8 Z. }5 ?" \$ |! F
                                            | MCASP_RX_SYNCERROR 1 g# e/ h/ u( m5 Q3 T" s( Z
                                            | MCASP_RX_OVERRUN);
7 C+ v) P, m: R- t3 F//MCASP_RX_DMAERROR MCASP_TX_DMAERROR
3 i; f# j, B) F" L) ]; U
! V; c+ }/ Z4 S  U}
( k9 ~, [0 F4 J' k$ j, b0 r$ U) N+ K, E. v
2.运行完上述配置后激活发送接受I2SDataTxRxActivate(); 遇到这个问题:程序无法跳出红色部分的语句) J5 d5 w- {* j0 @- p  x8 {
static void I2SDataTxRxActivate(void)
- W* U* O4 D  U/ G4 |{
6 k  E( j' S1 B    /* Start the clocks */
& J  [5 |7 W- _! P4 q7 f    McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
% P1 L" Y  {% l$ @+ s    McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_EXTERNAL);% v! \$ u+ n& a# }8 L6 m

* t0 ~4 x, q. S: a3 u0 J# H0 o7 x    /* Enable EDMA for the transfer */
; I6 V8 q6 C* M  C3 Z/ z0 p0 S+ B  D3 y! n//    EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
3 j0 E  |) M! N6 m$ T//                        EDMA3_TRIG_MODE_EVENT);
. F% l9 J1 B. w4 H+ |1 n( j* b//    EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
1 W% X, I/ M; h5 ]7 I4 E# X//                        EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
; z  H  A( k4 n: x) u0 g: s9 {    /* Activate the  serializers */
7 f' H& U- r4 L0 S    McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);
8 |# W0 ]8 t5 f, h' P1 v' o: Q    McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/ o4 ?8 N: d' B; c9 Y) D0 y2 t
    /* make sure that the XDATA bit is cleared to zero */: h4 t  h7 t# Q) D! Z6 `
    while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);/ I2 a4 [9 }( F" {0 n. A
    /* Activate the state machines */
4 v% ^2 g2 u; E7 T" W# v    McASPRxEnable(SOC_MCASP_0_CTRL_REGS);
6 {2 ?9 }3 K1 d& s& T( ?    McASPTxEnable(SOC_MCASP_0_CTRL_REGS);. }* E  V$ q' x& q% g9 ~& P  o. c8 C
    McASPTxBufWrite(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX, 0);
( S& o0 _3 S  q5 M9 g$ j: H4 N}1 J4 X0 \' o8 M* z2 @

8 g6 ?9 m' W6 }
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖
回复

使用道具 举报

0

主题

184

帖子

1137

积分

QQ游客

积分
1137
沙发
发表于 2015-10-29 17:26:10 | 只看该作者
音频例程的McASP的所有时钟都由外部芯片提供:* c. h) O: |) x$ E
在音频例程里,# G4 g! w+ C1 d- g
McASP_AHCKLX 外部输入24.576M的时钟,
  r6 |. X6 C  `4 V% nMcASP_CLKX由外部输入1.536M的时钟,
+ q! e6 c0 l7 {7 K% x+ ?McASP_AFSX有外部输入48k时钟。
! p' X! A2 O! L& \+ I. k+ h不能激活McASP是由于McASP_CLKX没有时钟输入,在此引脚提供任意时钟即可通过激活函数。
回复 支持 反对

使用道具 举报

1

主题

5

帖子

1027

积分

金牌会员

Rank: 6Rank: 6

积分
1027
板凳
 楼主| 发表于 2015-10-31 11:40:34 | 只看该作者
Lewis 发表于 2015-10-29 17:26
& u  {  D, y9 B8 E+ h音频例程的McASP的所有时钟都由外部芯片提供:' H; l* a; d/ p/ ]2 R; P
在音频例程里,7 s. o/ V6 E- T/ z* `
McASP_AHCKLX 外部输入24.576M的时钟,
: Z5 }& `$ w6 x) ?  {
谢谢啊,应该是你说的原因。我接上外部时钟,激活是通过了。现在到了判断XSTAT里面的状态那里,一直在死循环判断。没法通过,这又是什么原因?
回复 支持 反对

使用道具 举报

1

主题

5

帖子

1027

积分

金牌会员

Rank: 6Rank: 6

积分
1027
地板
 楼主| 发表于 2015-10-31 11:41:37 | 只看该作者
Ming 发表于 2015-10-31 11:40( c& n+ n0 H* s
谢谢啊,应该是你说的原因。我接上外部时钟,激活是通过了。现在到了判断XSTAT里面的状态那里,一直在死 ...
% {! S1 G8 i: e( h: q6 W+ V  N
就是这一句while( !(McASPRxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_RX_STAT_DATAREADY));
回复 支持 反对

使用道具 举报

1

主题

5

帖子

1027

积分

金牌会员

Rank: 6Rank: 6

积分
1027
5#
 楼主| 发表于 2015-10-31 11:42:09 | 只看该作者
Lewis 发表于 2015-10-29 17:26
& F3 r$ ^; B; @" n9 i2 s音频例程的McASP的所有时钟都由外部芯片提供:- N; B7 a. j: P  N0 M; \% c1 i0 K
在音频例程里,+ |) z) z) \! v1 C3 Z. _& I
McASP_AHCKLX 外部输入24.576M的时钟,
5 a8 o( c- Q; g
就是这一句while( !(McASPRxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_RX_STAT_DATAREADY));无法通过
回复 支持 反对

使用道具 举报

1

主题

5

帖子

1027

积分

金牌会员

Rank: 6Rank: 6

积分
1027
6#
 楼主| 发表于 2015-10-31 11:42:50 | 只看该作者
Lewis 发表于 2015-10-29 17:26
! S+ t) Z" ~- [; A5 u( n音频例程的McASP的所有时钟都由外部芯片提供:
  i: [9 v' n8 H% c6 g在音频例程里,
1 d! m! G" E- A6 \1 ~McASP_AHCKLX 外部输入24.576M的时钟,

: U5 W; a. H% U6 p* R0 f这句while( !(McASPRxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_RX_STAT_DATAREADY));无法通过
回复 支持 反对

使用道具 举报

0

主题

184

帖子

1137

积分

QQ游客

积分
1137
7#
发表于 2015-10-31 21:13:29 | 只看该作者
1、
# p% k9 y+ t' _( @, pMcASP_CLKX 和 McASP_AFSX的时钟倍数要正确
4 M# e% a+ e# s: B5 x7 L2、McASP不支持仿真停止信号,如果加上了软件中断,则后面不能通过此函数。/ t$ p0 S/ G6 P5 w( V. K
; w" G: t8 ~$ A% T

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-6 06:08 , Processed in 0.042763 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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