FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这... - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9510|回复: 9
打印 上一主题 下一主题

[未解决] FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这...

[复制链接]

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
跳转到指定楼层
楼主
发表于 2017-6-26 14:26:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这时为什么?$ X. M3 t' ?$ [7 f: c
dsp使用i发送到fpga,fpga使用q发送数据到dsp,dsp的发送中断间隔是40us左右,经常收到uori错误,不知道是什么原因。示波器看每次upp发送时间都是很少的。upp中断服务程序如下:
) y9 Z, ~0 r+ P$ i* Mu32 UPP_Isr()5 m8 ~- f( j/ B, M+ o& Q. @
{- Q, R8 v/ y/ ?  Z; S2 |
    Uint32 intr_status = upp_reg_hdl->UPIER;/ Q- q6 @4 n0 |% O6 W
    upp_reg_hdl->UPIER = intr_status;//clear" _- I3 |4 `: Q( R/ ~
//    Log_print0(Diags_ENTRY | Diags_INFO, "--> UPP_Isr:");: Q6 L- ]; e7 P
    u32 ret=0;
3 B+ c) C# K9 U1 n: Z, y
$ `3 z; E: _3 ]    // inline functions5 g) s6 K4 B% K1 G& [3 ~) x2 s
    while (intr_status != 0)
6 f% b- k" ]+ O& U    {9 k% X0 w* }5 g% o. t
        if (intr_status & CSL_UPP_UPISR_EOLI_MASK)//Line结束事件
; g3 q, ~* v( F/ C) u3 t        {) A0 B; d7 r* R2 s. ^8 k1 W
//            Log_print0(Diags_INFO,"eoli.\n");
/ a% K' n( o( ~. T& a- T            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOLI_MASK);3 j6 E9 R: @9 v% E. v7 ~% H
        }
/ a& ~; E. H$ J8 o' b1 E# B4 N) c- {2 E2 f0 ?, A
        if (intr_status & CSL_UPP_UPISR_EOWI_MASK)//Window结束事件
3 i+ C* I7 I) L6 K8 g3 ~  _        {& r0 }7 j+ F1 ~. R3 X9 Z. w% B" R
            Log_print0(Diags_INFO,"eowi.\n");# t# J: O. ~6 w: K# k8 g
            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOWI_MASK);+ t. g, ?$ n$ }4 J
            upp_interrupt_count++;: j. G1 ]9 W. y. y/ u
            upp_interrupt_eowi_count++;
2 d' F' h9 e- O3 |, Y
# P) ^6 K7 t5 O0 S& d& R& L- x#if UPP_DIR_QI==04 I% ^5 R* x. V2 m
            upp_dma_receivestart();
, U- K9 |6 R. S& \$ f            ret=1;
& Z! U9 u% V' I* z#endif
. y  I+ \  P1 f% |' L        }/ M+ s8 Z  J( D8 v7 P; c
8 D  g3 j2 y# ~* Y9 \" @, ]3 o
        if (intr_status & CSL_UPP_UPISR_ERRI_MASK)//内部总线错误事件
# O) Y( C4 I5 R( a# s" d        {
2 V  q! {& W5 i3 M2 N; ?3 a' j+ k            Log_print0(Diags_INFO,"erri.\n");+ U: _" ]; `1 e3 r, W) Q0 [
            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_ERRI_MASK);' s0 Y2 r& h! O' t4 l# S" W" {
            upp_error_count++;
0 x7 O3 a0 o& L! J6 i: k% F        }& |8 @% t! T! p" r4 G' B

9 L$ A2 h4 T! j" U0 R; ~9 r6 q: }        if (intr_status & CSL_UPP_UPISR_UORI_MASK)//欠载或溢出事件
  Y4 z) o! W, i+ d2 z        {# g$ }- O. W$ v6 ]2 X
            Log_print0(Diags_INFO,"uori.\n");
" m5 v/ N8 ]7 v6 j- \3 h8 [- t            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_UORI_MASK);
0 |* C) N$ A: C: h+ K7 H5 e0 {            upp_error_count++;8 w8 L. s" f# [& z
        }' M4 L5 V+ o& U0 i: b; J, j0 w3 C

7 t" e" X# C2 ?! v  N1 z        if (intr_status & CSL_UPP_UPISR_DPEI_MASK)//DMA编程错误事件
  Q+ p" C3 x/ m3 |$ W1 |        {
0 R3 V0 a- W$ p" L- S# z  b            Log_print0(Diags_INFO,"dpei.\n");: c& T- h4 D3 |
            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_DPEI_MASK);
% p; U! V0 d( J8 f6 |6 i            upp_error_count++;
6 v' e1 O7 ]. b        }
' n7 f# c# c& }7 n3 U7 d4 W1 i: P6 d6 |4 E9 I' Z/ \0 U& k, @+ l
        if (intr_status & CSL_UPP_UPISR_EOLQ_MASK)* G" g% ?: W1 d) l' j& n* u
        {) }. q) K8 E3 \+ [0 \
//            Log_print0(Diags_INFO,"eolq.\n");
/ c# Q; e9 `, h1 T: Y3 [: a            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOLQ_MASK);
) A" P: G, F) }0 o  l5 s+ K3 L) }        }
$ y0 S1 H9 M0 u; }0 K$ o5 ^9 N, B/ `: g! K# D% ~
        if (intr_status & CSL_UPP_UPISR_EOWQ_MASK)
+ \- x! [0 v* w- ^( A        {3 p& ?. Q; y6 y3 G+ E0 U/ l# K
//            Log_print0(Diags_INFO,"eowq.\n");
  O' x! C- D* G& y7 K& w            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOWQ_MASK);
: A; l8 F8 K/ L* Y7 F% v0 C3 z# K            upp_interrupt_count++;1 X( v  X, ~" g- d* d, ~
#if UPP_DIR_QI==18 O) Z$ c  I+ F2 w  c+ f5 ^. G
            upp_dma_receivestart();
" A3 g% b5 C! w/ ^3 u, L% t            ret=1;
& ^; b$ @, |/ w: f8 P% x5 G#endif3 V1 F3 Z- X5 y( e$ V7 y
        }
  X; F, A! _( M6 f4 T$ p0 j2 T2 g8 f' r$ A8 y) h. Y9 {
        if (intr_status & CSL_UPP_UPISR_ERRQ_MASK)! j8 x" @( n0 ^& \' {
        {+ x8 Z# ~# `: B4 U; Q% l- y6 c
            Log_print0(Diags_INFO,"errq.\n");
1 V1 Z9 f2 I* W: B2 M3 x" k( G            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_ERRQ_MASK);
/ L$ I! h5 |( y& ]0 D) p; O9 ^            upp_error_count++;
4 R  d% A- R" l5 v" O9 l* V% O        }
  y) U2 D, {, Z2 T+ I7 {. t) s  z, H3 B9 p
        if (intr_status & CSL_UPP_UPISR_UORQ_MASK)
) i. w! {! E, W9 R  i& r        {3 ~, c" N. q( x, v
            Log_print0(Diags_INFO,"uorq.\n");0 w) B6 p1 `& Z
            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_UORQ_MASK);
, x; w2 P* \+ _5 {+ |  K6 D/ y            upp_error_count++;1 c& `4 Q9 W4 W5 _0 Z
        }
$ B9 x- O4 Z3 r0 |" @  C$ |0 w5 X' _* ]0 |% i# K
        if (intr_status & CSL_UPP_UPISR_DPEQ_MASK)
+ a0 i  J: t  V$ n0 K        {# d" [5 w* J: X3 K0 H6 `9 D3 F" |
            Log_print0(Diags_INFO,"dpeq.\n");1 @; k# P$ E' x% E. P
            upp_reg_hdl->UPIER = (CSL_UPP_UPISR_DPEQ_MASK);
$ a1 W3 |( O  X* X/ \. O2 w            upp_error_count++;
9 W' {2 N0 P( z4 V# L% p2 `        }
$ e7 {( k% T. M8 p# M/ W/ K- Y8 g! O' j1 D+ R$ ]2 X+ \
        // make sure all interrupts are handled
, W0 ~9 T  ?; [5 g! H8 ]7 ?4 _        intr_status = upp_reg_hdl->UPIER;9 q2 r3 k7 J$ Y6 Y, S( B
    }
% L5 }% e" l2 [$ V
0 Q' M- I' b5 `    // finally: write 0 to EOI register
8 V8 n! n6 J" c- t: z1 g    upp_reg_hdl->UPEOI = 0;
7 E- \7 X) z0 K. @$ y5 I8 [    return ret;  `4 ^3 n6 p/ K$ G1 Z
}
( p, S- A5 Z! `" g/ |dsp发送区大小为512字节,发送txsize设置为256字节。使用的是单行,win窗口是512发送方式。发送调用upp_dma_sendstartQI(I):7 {6 j5 Z2 |$ v6 f9 Q
#define upp_dma_sendstartQI(x)     {\3 i- ~! }& x/ G
    Wait_upp_SendReadyQI(x);    \: W' o5 t8 a8 M; y5 K/ R+ \
    upp_reg_hdl->UP##x##D0 = (u32)&g_uPPSend;      \
* f' }# X  i7 ]' {    upp_reg_hdl->UP##x##D1 = ((u32)upp_line_count_s << 16) | (u32)upp_line_size_s*sizeof(s32);   \5 O  ^; V( L$ w% i1 I7 f
    upp_reg_hdl->UP##x##D2 = (u32)upp_line_offset_s * sizeof(s32);\# z1 g, r) }( b" O. ?
    }
7 Z5 h0 k( h2 ^7 V( [* z7 b. _! L; t# V# f

: d- \" T: m  ^#define upp_dma_sendstart()     upp_dma_sendstartQI(I)
# i: H# w! K9 Q4 w, k: ]2 K
' k- a. A" A; o' E0 p. r
. i4 c0 M% L4 g; N( }
想知道uori错误是在什么情况下面出现的,好做出修改。
1 d4 A) t2 S& E$ S& s
" I1 x# A) T6 i. a7 T
+ U8 E6 {; ^7 S& s, u" j
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

3

主题

852

帖子

3538

积分

创龙

Rank: 8Rank: 8

积分
3538
沙发
发表于 2017-6-26 21:47:42 | 只看该作者
明天发你例程参考一下。
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
板凳
 楼主| 发表于 2017-6-30 15:14:51 | 只看该作者
不好意思,我没看出有什么区别,或者哪里设置错误了。不知道您的这个工程有没有试过dsp端40us周期性发送512字节数据给fpga,fpga不定时发送128字节给dsp,会不会出现uor这个错误。
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
地板
 楼主| 发表于 2017-7-28 12:00:14 | 只看该作者
1、dsp初始化upp设备后,在没有发送数据的情况下,dsp使用的upp的发送端start、enable信号一直是高电平,这是不正常的,应该是低电平才对。
" ]. F& P; l& h) M7 v9 t: t  r- R% b0 l6 U4 ?! g) [
2、在启动uppdma输出后,start信号的高电平有点长(如发间隔为50us,start的高电平达到45us,低电平才5us;start信号不应该是比较短的吗?看手册画的start信号是一个很短的高电平),而且enable信号一直是高从来没低过(数据传输完成,不应该降为低电平吗?),这是什么原因?
回复 支持 反对

使用道具 举报

0

主题

184

帖子

1137

积分

QQ游客

积分
1137
5#
发表于 2017-7-28 16:38:03 | 只看该作者
出现uor错误,操作UPP过于频繁或者系统负载过大,可以尝试降低upp速率,或者加大upp的数据缓冲,降低upp操作频率
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
6#
 楼主| 发表于 2017-8-1 17:36:17 | 只看该作者
重新对着例程重新初始化upp设备,目前start、enable信号是正常的。目前是:发送数据有1*512Byte字节,每40us传输一次,接收为1*128Byte不定时FPGA检测硬件状态后上传。想问一下,TXSIZEA(B),RDSIZEI(Q),要怎样设置。试了各种组合,甚至将单速率传输由37.5Mhz降到25Mhz,upp的uori(q)错误一直都有发生(发送端)

本帖子中包含更多资源

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

x
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
7#
 楼主| 发表于 2017-8-23 09:10:04 | 只看该作者
在网上找到关于uor错误的说明:https://support.criticallink.com ... sign_Considerations
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
8#
 楼主| 发表于 2017-8-23 09:28:20 | 只看该作者
当我们按照这个文档修改了uPP的发送时钟(syscfg0.syschip3修改为0,0使用pll0_sysclk2),这时uPP就不会有uor错误;但是由此又产生了其他错误,因为使用async3_clksrc时钟源的设备都出错了,如图:,影响了timer2/3、uart1/2等设备。我们整个系统里面使用到了uart1/2、spi1,其他设备除了timer2/3都用做普通IO脚或其他设备去了。( F' y  @0 M  H2 l! c' N% @
) B* M  e4 p) N& x* r
, c2 R3 Y( C: H0 s: J0 n0 ?% i* U

本帖子中包含更多资源

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

x
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
9#
 楼主| 发表于 2017-8-23 09:50:12 | 只看该作者
然后我们就想自己软件层面根据SYS_CLK_CALC_OMAP-L138_C674X_AM18X_v1p3.xls,把我们系统的时钟计算了一遍之后,根据我们实际使用的时钟,在设置upp的发送时钟源时同时设置uart1/2(修改DLH、DLL)、spi1(修改spi_fmt4的prescale)设备的寄存器,这时这些设备都表现好像是正常的。修改代码在dsp端执行:
1 y2 q% v% Y5 v$ R, m8 y. o9 B: d' U1 D. d* y5 q
1、如果在程序启动前使用SecureCRT.exe这个连接了系统的uart2,这时候输入是乱码的,需要断开重新连接才表现正常。
% s) b: F- H3 Y" S0 }6 C2、如果此时重新初始化uart1、spi1等设备时,这时候uart1的DLL/DLH寄存器就会按之前的时钟源重设了,spi1的prescale也被重设。# @" @( G5 J' \1 ^. E

3 [% C. C) B5 a$ O; H1 X+ T所以,软件层面修改是不行的。现在希望就是linux系统启动的时候,自动将upp的发送时钟源设置(async3_clksrc)为pll0_sysclk2,同时将跟async3_clksrc相关设备使用的时钟源的频率值修正为与选择的一致,这样避免重新初始化这些外设时由于使用错误的频率值造成系统初始化对应寄存器为错误值。

本帖子中包含更多资源

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

x
回复 支持 反对

使用道具 举报

9

主题

35

帖子

155

积分

注册会员

Rank: 2

积分
155
10#
 楼主| 发表于 2017-8-23 10:00:32 | 只看该作者
dsp端修改时钟代码:
. d. o' `: [/ W3 y" D, p1 o" L' C- i$ j3 O  @7 I
    //设置upp外设时钟源 pll0_clock28 s; d; t1 M7 T% U
    u32 temp_reg  = HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_CFGCHIP3);
# s/ k' i" y) H( ]( s/ D    //uPP时钟源不对
! ^* u5 G1 t% `( J- f1 ~//    if(temp_reg &(SYSCFG_CFGCHIP3_UPP_TX_CLKSRC | SYSCFG_CFGCHIP3_ASYNC3_CLKSRC))
" v8 g& N3 o0 s/ e- P    {
( [6 {8 Q' J" o. G. j        HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_CFGCHIP3) = (temp_reg & ~(SYSCFG_CFGCHIP3_UPP_TX_CLKSRC | SYSCFG_CFGCHIP3_ASYNC3_CLKSRC));  s, |1 l( L8 Z$ {$ v
        //影响spi1,uart1/2,timer1/2等设备,重新配置
9 [; r* Z( T0 X) `0 I+ k, H7 o& B        //uart1,TS211的通信接口,使用38400,重设分频寄存器/ p7 w5 C4 f7 m, r+ l
        HWREG(SOC_UART_1_REGS + UART_DLH) = 0x01;* Q8 V  B. b6 m! c! z3 K) A
        HWREG(SOC_UART_1_REGS + UART_DLL) = 0x73+1;
* p# v2 n- S* Z; S5 K) S7 o& ?        //uart2,linux的通信接口,使用115200,重设分频寄存器
/ S3 v+ U1 N1 ~# q% r- |        HWREG(SOC_UART_2_REGS + UART_DLL) = (0x7B+1);  b( e  H  U7 I7 o6 G0 b0 Y' ~
        //spi1,arm与fpga通信使用* I+ X2 i4 V$ D2 p3 W- j
        temp_reg  = HWREG(SOC_SPI_1_REGS + SPI_SPIFMT(0)) & ~SPI_SPIFMT_PRESCALE;7 I- B3 l. |7 j. p
        HWREG(SOC_SPI_1_REGS + SPI_SPIFMT(0)) = (temp_reg | (SPI_SPIFMT_PRESCALE & ((27)<<SPI_SPIFMT_PRESCALE_SHIFT)));
/ Q6 R, k* t  x! J# Q    }
1 S6 P2 @7 x# F4 {; N, @; B% T5 U" P# |
uart1/2时钟图(分频值需要+1之后分高低字节填入DLL/DLH):3 Q" Q  s" l- o$ n, E

4 t: z% m1 D7 x" A, N+ q; c8 Sspi图:( t" d3 o, F  q6 f
/ q' l- x6 a0 i% c) N2 w) X

本帖子中包含更多资源

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

x
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-2-14 04:40 , Processed in 0.049520 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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