嵌入式开发者社区
标题:
FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这...
[打印本页]
作者:
kevinjoyo
时间:
2017-6-26 14:26
标题:
FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这...
FPGA和Omapl138的dsp核使用upp通信,总是出现uor错误中断,这时为什么?
+ G+ V1 s6 H+ e0 y' v
dsp使用i发送到fpga,fpga使用q发送数据到dsp,dsp的发送中断间隔是40us左右,经常收到uori错误,不知道是什么原因。示波器看每次upp发送时间都是很少的。
upp中断服务程序如下:
4 b! U1 N" T; k" R' H+ S- K% N" o
u32 UPP_Isr()
! s; N" n! N3 b' A
{
( T: [) _$ [2 ^1 U0 x8 m# d
Uint32 intr_status = upp_reg_hdl->UPIER;
" s) {: C# W2 @6 o( q) C! n, V& o$ S
upp_reg_hdl->UPIER = intr_status;//clear
7 k+ p H7 l! T" @/ l& J+ t% [
// Log_print0(Diags_ENTRY | Diags_INFO, "--> UPP_Isr:");
! w! W* J6 e) }9 C
u32 ret=0;
- z1 M3 n! A& L2 W/ d5 O D8 e" b z# s
% l6 N% a5 J, S
// inline functions
6 [. [7 P) p$ b$ n' o
while (intr_status != 0)
8 L' \8 @2 o2 `+ f: V
{
4 M! X' P8 m4 }) P/ g
if (intr_status & CSL_UPP_UPISR_EOLI_MASK)//Line结束事件
5 s" K3 I/ A0 R5 R
{
. u# Z- ?( ~/ s; w u6 M6 N
// Log_print0(Diags_INFO,"eoli.\n");
h2 D' d" K. s/ |
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOLI_MASK);
1 @2 t, \8 X! G6 \
}
) f# K U: ^- t1 F/ N; z
( S' O+ f; ]# a
if (intr_status & CSL_UPP_UPISR_EOWI_MASK)//Window结束事件
' }4 ^% p" k( H' Y0 Y2 ^) y2 s( U
{
' g/ J9 f0 S- h1 y& s7 a/ _
Log_print0(Diags_INFO,"eowi.\n");
8 j0 o7 _+ w# t' ^$ G6 r4 j/ V% [
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOWI_MASK);
. T# W$ J8 ?: g: B- B4 K
upp_interrupt_count++;
+ U& u- U0 i: ?0 |! e9 l
upp_interrupt_eowi_count++;
6 }, H+ M+ b6 I5 d
, ^1 S% K8 {( k- J3 L9 U+ N
#if UPP_DIR_QI==0
/ r2 I0 }# n/ `
upp_dma_receivestart();
1 u( ~! H' D* t4 p, v9 b* j
ret=1;
3 f4 Q6 o$ a! M" W9 W3 f. j
#endif
: \2 R, z/ S1 c, T
}
" j# c, b4 |: W* c2 [
' U2 t: A) E: E; O
if (intr_status & CSL_UPP_UPISR_ERRI_MASK)//内部总线错误事件
2 [* x$ J$ D& F$ J1 {
{
" `3 n0 k; o* d0 y" ^& H8 Z1 z6 y
Log_print0(Diags_INFO,"erri.\n");
" ^1 a( Q; b* u8 w
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_ERRI_MASK);
9 X3 R6 m8 o1 ^% J: D* F8 C( p3 _$ n
upp_error_count++;
/ s% u S ]4 r, y5 }( n% p
}
% S6 t- B; |4 P- p6 [9 R
; l( [0 b8 s; n; J; H8 A
if (intr_status & CSL_UPP_UPISR_UORI_MASK)//欠载或溢出事件
' O' I! @- ?4 j/ V4 ?' G$ L& W
{
) C- X/ v6 t, h! [7 i4 q% x' w& `
Log_print0(Diags_INFO,"uori.\n");
1 b. g: N: ^0 U9 c9 a8 l
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_UORI_MASK);
1 }3 }6 ~( s, e+ `
upp_error_count++;
) e @4 M A! m I0 ?
}
/ a' q# K1 Y. u) J3 y5 J) w
4 k$ u) s: B2 y+ K M
if (intr_status & CSL_UPP_UPISR_DPEI_MASK)//DMA编程错误事件
% G/ o2 o! b* w- H; r- Q
{
# e1 A; R4 w0 N' }0 R
Log_print0(Diags_INFO,"dpei.\n");
# D7 Z5 R6 E' V8 {
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_DPEI_MASK);
' h) M6 W/ w9 O$ x* v/ S
upp_error_count++;
# L0 t! H! j5 {: q9 n7 n9 Q- v
}
6 X/ V5 Z/ \7 B6 P5 I% V$ d: t# j% o
2 G6 X$ ? M; }6 p2 d. q8 Z
if (intr_status & CSL_UPP_UPISR_EOLQ_MASK)
: i0 q. y- d: c |
{
5 g# t7 o4 f5 g: d
// Log_print0(Diags_INFO,"eolq.\n");
7 }0 O" s$ M, e! G$ q# e$ F& v+ I; L
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOLQ_MASK);
6 f& `, e& K* X, o/ U3 W z
}
- Z# y4 x9 n5 z
Q6 G: n& }8 F, s) d
if (intr_status & CSL_UPP_UPISR_EOWQ_MASK)
! K7 r. T; v) Y/ W9 q3 S1 v$ l$ `
{
" ^( p- |% U, T6 r
// Log_print0(Diags_INFO,"eowq.\n");
9 Y- \+ \* y+ R+ t& V: m
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_EOWQ_MASK);
1 u$ Q' F1 J) {/ E4 r
upp_interrupt_count++;
, A W, A7 e1 @/ |- F# X. D" d
#if UPP_DIR_QI==1
2 F# O6 B2 h; _2 @: E5 D6 g8 k' T
upp_dma_receivestart();
* X" H1 ?; ]% B/ f0 x( f
ret=1;
. A5 q5 M a* x& Q+ `2 B+ {; u
#endif
- D3 N5 g5 G- R; r, W# K- ~
}
8 Q2 i5 z% S, T; b3 ?$ q
2 I7 ]. u& E. K j! [8 _
if (intr_status & CSL_UPP_UPISR_ERRQ_MASK)
* n7 D4 g5 i1 t$ I a! S
{
- l9 k8 R h7 J# f! _; j u
Log_print0(Diags_INFO,"errq.\n");
9 E: g7 `& f) j: X* |; b0 v0 R
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_ERRQ_MASK);
* Q0 I+ p9 x; b: t! K7 p7 @/ s6 P
upp_error_count++;
! }* u) C8 z# x) l9 \$ h% l' |
}
+ j" L6 _& [ t. P, p
2 ?7 o. x/ ^, ~3 t U+ o+ w+ t- a
if (intr_status & CSL_UPP_UPISR_UORQ_MASK)
0 E+ V8 ^. t9 R2 S" _) p( H; H
{
! \: G* Q; n [
Log_print0(Diags_INFO,"uorq.\n");
/ w! K/ P0 J" e* I* {
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_UORQ_MASK);
7 C5 v- b5 \) f! m9 f; Z [
upp_error_count++;
0 N$ @1 \+ A7 e7 M" g. M
}
8 ^3 S( ?6 ]2 [
E. R/ i$ x7 F# }7 |3 T- V$ y0 _
if (intr_status & CSL_UPP_UPISR_DPEQ_MASK)
) C; U- C$ a1 n: }: ]# w# G& k
{
) H! l& M5 Q; p8 v8 i% F& D% c
Log_print0(Diags_INFO,"dpeq.\n");
1 a. ~% d: L9 [0 H/ @4 B( I
upp_reg_hdl->UPIER = (CSL_UPP_UPISR_DPEQ_MASK);
; [3 B6 t! w( V7 U7 |0 j
upp_error_count++;
0 s7 u3 j+ h. ~
}
2 z2 p% D7 m4 u$ S6 j, Z% W4 g
: c" F7 [( k' y3 b; b" R
// make sure all interrupts are handled
5 A9 ^1 u2 b2 ^3 |# [# w
intr_status = upp_reg_hdl->UPIER;
2 f" n/ t' B1 o8 d$ `
}
+ P ?5 n9 R( K1 S' q
$ F8 R4 E! c5 ?
// finally: write 0 to EOI register
7 o0 B. _! r# y8 w# S& F) y
upp_reg_hdl->UPEOI = 0;
' M. h# C( w0 @0 C/ ^
return ret;
) g' V- t% W- c4 V9 r
}
7 t0 Q* r# e+ c5 m4 h; D
dsp发送区大小为512字节,发送txsize设置为256字节。使用的是单行,win窗口是512发送方式。发送调用upp_dma_sendstartQI(I):
' D! k4 y; |3 j# X) {1 Q& d
#define upp_dma_sendstartQI(x) {\
N" d- n2 |5 S
Wait_upp_SendReadyQI(x); \
+ I$ X! n! J5 g# q% V# E0 O
upp_reg_hdl->UP##x##D0 = (u32)&g_uPPSend; \
; x, v- c$ U- U+ \2 z) |" v
upp_reg_hdl->UP##x##D1 = ((u32)upp_line_count_s << 16) | (u32)upp_line_size_s*sizeof(s32); \
8 j ]' u2 X0 f- Z) G1 P
upp_reg_hdl->UP##x##D2 = (u32)upp_line_offset_s * sizeof(s32);\
M+ @0 f( u9 V
}
; ~2 S1 Y9 Y! g' u# d+ }# ]- n; m7 Z
. g) _0 _4 R- j+ e. E1 ]$ z: ?
8 C$ F6 ~- _6 W. R
#define upp_dma_sendstart() upp_dma_sendstartQI(I)
w! @! Q8 k! c- R5 r
& [2 _. H* b1 s+ c
( N r* D: |3 F4 ? X$ C
想知道uori错误是在什么情况下面出现的,好做出修改。
/ @5 J2 A, z! J0 d9 {
8 U% y7 l' Z7 s7 k2 I
3 p8 j* ?9 w# b: H
作者:
human
时间:
2017-6-26 21:47
明天发你例程参考一下。
作者:
kevinjoyo
时间:
2017-6-30 15:14
不好意思,我没看出有什么区别,或者哪里设置错误了。不知道您的这个工程有没有试过dsp端40us周期性发送512字节数据给fpga,fpga不定时发送128字节给dsp,会不会出现uor这个错误。
作者:
kevinjoyo
时间:
2017-7-28 12:00
1、dsp初始化upp设备后,在没有发送数据的情况下,dsp使用的upp的发送端start、enable信号一直是高电平,这是不正常的,应该是低电平才对。
n5 K* J/ U T" D/ w; i7 n9 O
( M% G4 \$ ^: W
2、在启动uppdma输出后,start信号的高电平有点长(如发间隔为50us,start的高电平达到45us,低电平才5us;start信号不应该是比较短的吗?看手册画的start信号是一个很短的高电平),而且enable信号一直是高从来没低过(数据传输完成,不应该降为低电平吗?),这是什么原因?
作者:
Lewis
时间:
2017-7-28 16:38
出现uor错误,操作UPP过于频繁或者系统负载过大,可以尝试降低upp速率,或者加大upp的数据缓冲,降低upp操作频率
作者:
kevinjoyo
时间:
2017-8-1 17:36
重新对着例程重新初始化upp设备,目前start、enable信号是正常的。目前是:发送数据有1*512Byte字节,每40us传输一次,接收为1*128Byte不定时FPGA检测硬件状态后上传。想问一下,TXSIZEA(B),RDSIZEI(Q),要怎样设置。试了各种组合,甚至将单速率传输由37.5Mhz降到25Mhz,upp的uori(q)错误一直都有发生(发送端)[attach]2647[/attach]
作者:
kevinjoyo
时间:
2017-8-23 09:10
在网上找到关于uor错误的说明:
https://support.criticallink.com ... sign_Considerations
作者:
kevinjoyo
时间:
2017-8-23 09:28
当我们按照这个文档修改了uPP的发送时钟(syscfg0.syschip3修改为0,0使用pll0_sysclk2)[attach]2735[/attach],这时uPP就不会有uor错误;但是由此又产生了其他错误,因为使用async3_clksrc时钟源的设备都出错了,如图:[attach]2736[/attach],影响了timer2/3、uart1/2等设备。我们整个系统里面使用到了uart1/2、spi1,其他设备除了timer2/3都用做普通IO脚或其他设备去了。
& M0 ?* F. P+ d, r n
! a- \- Q6 _! G+ \. I3 e9 p
+ z5 y" p+ d' d* S
作者:
kevinjoyo
时间:
2017-8-23 09:50
然后我们就想自己软件层面根据SYS_CLK_CALC_OMAP-L138_C674X_AM18X_v1p3.xls,把我们系统的时钟计算了一遍之后,根据我们实际使用的时钟,在设置upp的发送时钟源时同时设置uart1/2(修改DLH、DLL)、spi1(修改spi_fmt4的prescale)设备的寄存器,这时这些设备都表现好像是正常的。修改代码在dsp端执行:
9 G* O2 L* y) h) m- i' v
# k$ g1 b! X6 I% ]6 ~0 n" x
1、如果在程序启动前使用SecureCRT.exe这个连接了系统的uart2,这时候输入是乱码的,需要断开重新连接才表现正常。
7 M& O8 V' y% T/ `- u/ ]/ p
2、如果此时重新初始化uart1、spi1等设备时,这时候uart1的DLL/DLH寄存器就会按之前的时钟源重设了,spi1的prescale也被重设。
1 Z4 K$ ?! d3 a' M U: E
, s) c& I6 _- X T3 b: J0 t( `1 b
所以,软件层面修改是不行的。现在希望就是linux系统启动的时候,自动将upp的发送时钟源设置(async3_clksrc)为pll0_sysclk2,同时将跟async3_clksrc相关设备使用的时钟源的频率值修正为与选择的一致,这样避免重新初始化这些外设时由于使用错误的频率值造成系统初始化对应寄存器为错误值。
作者:
kevinjoyo
时间:
2017-8-23 10:00
dsp端修改时钟代码:
. _1 d7 @$ g9 G# I+ C
/ ~9 I3 C* L: y; T- o1 F4 {
//设置upp外设时钟源 pll0_clock2
6 B. h# E y! N7 E( H
u32 temp_reg = HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_CFGCHIP3);
" P2 O0 K4 A+ d" ^* L
//uPP时钟源不对
) F, j. `5 k3 \& G9 C: ^+ ^0 p
// if(temp_reg &(SYSCFG_CFGCHIP3_UPP_TX_CLKSRC | SYSCFG_CFGCHIP3_ASYNC3_CLKSRC))
9 X; B3 q4 Q! l5 m& ^
{
3 `4 b+ t! P& T ` T9 W" x* i
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_CFGCHIP3) = (temp_reg & ~(SYSCFG_CFGCHIP3_UPP_TX_CLKSRC | SYSCFG_CFGCHIP3_ASYNC3_CLKSRC));
. M8 K3 I$ B. y# ?. c/ ]1 v3 v
//影响spi1,uart1/2,timer1/2等设备,重新配置
* h9 B5 b+ h, t- B, w/ x
//uart1,TS211的通信接口,使用38400,重设分频寄存器
; g0 _4 s, v: K* y8 q
HWREG(SOC_UART_1_REGS + UART_DLH) = 0x01;
3 a4 y; _ \! V
HWREG(SOC_UART_1_REGS + UART_DLL) = 0x73+1;
2 u9 C* d) W" P* ^. _$ V5 M
//uart2,linux的通信接口,使用115200,重设分频寄存器
/ Y- d$ R/ d& J4 _/ G! H
HWREG(SOC_UART_2_REGS + UART_DLL) = (0x7B+1);
, d4 r1 b$ h% e) q9 ?7 E1 q
//spi1,arm与fpga通信使用
) n" A1 L' Q! B% L) @2 h! Z/ P
temp_reg = HWREG(SOC_SPI_1_REGS + SPI_SPIFMT(0)) & ~SPI_SPIFMT_PRESCALE;
' o+ m, p! `6 W2 K' {6 u
HWREG(SOC_SPI_1_REGS + SPI_SPIFMT(0)) = (temp_reg | (SPI_SPIFMT_PRESCALE & ((27)<<SPI_SPIFMT_PRESCALE_SHIFT)));
8 X3 J' Q; b/ X9 K
}
% ?$ @8 L& k: h; f+ A T
/ ^6 N2 q6 I9 m6 m+ } \) i+ ~
uart1/2时钟图(分频值需要+1之后分高低字节填入DLL/DLH):
+ a" I! U! A+ y2 c
[attach]2738[/attach][attach]2739[/attach]
" W( f; n. R& ^+ y
spi图:
4 C' ]1 U% S4 s3 A4 D3 C+ l7 L: }
[attach]2740[/attach]
& y! y2 X8 B: b8 |
欢迎光临 嵌入式开发者社区 (https://www.51ele.net/)
Powered by Discuz! X3.4