双核工作下,UPP不工作 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 7814|回复: 10
打印 上一主题 下一主题

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:+ z/ g8 j. i6 J1 [% v2 B' q1 A
     你好,我是保定炜达电力的
5 ?" e- R8 }$ B/ A6 p! {+ Y- x* ^; a     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
/ B/ F( e# t* y$ r+ G7 }0 E- ^& n% ?* Q& q8 Z  s; R( ~4 t
void UPPPinMuxSetup(void)+ O- r. g! G- S7 U
{
9 C% `+ |; Q# U6 ]6 L unsigned int savePinmux13 = 0;
' L4 k" B! P) H& g  g unsigned int savePinmux14 = 0;2 [6 L6 w% d2 H# q: u8 s
unsigned int savePinmux15 = 0;
5 ?- O) E" D2 y! [0 x unsigned int savePinmux16 = 0;
' x# i, n( ^' K* i. A( G# | unsigned int savePinmux17 = 0;
  `, N0 `+ S. y- g4 i/ a* a unsigned int savePinmux18 = 0;
! B4 p4 Y! k( F! h+ I /* all pins (channel A, channel B, DATA, and XDATA)*/. S- t" p- @: P6 Y& u' d. m
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
: s& s4 T8 m  `. M savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);1 e- g1 E' J" [
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);; m9 X* n6 x# ^2 r! n
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
9 f" d: W, w: O' ` //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
$ L0 ^$ X9 b, |5 I: d //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);3 J. y+ ]1 E2 F; S
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);4 t5 }0 x5 R" x; G* Q' i
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);0 H  {( @; s" e& N( \+ @- P
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);' S; _# G2 c2 R6 ]: ~  |) `. s7 w9 d
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
5 y! W1 f) g! W# a6 C HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);. K; ?- l/ P$ ]4 \; F) @! f
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
) J7 F0 u% b( q8 w) K3 k! [* w //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);0 n. Q" Y- R+ i8 n; q
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);  q6 ]9 \! f2 @4 T- V
}
+ H2 y( s$ l/ B8 ?% ^+ L6 ]2 \5 p
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 2 m( A# \& t3 Z. F

" F9 r9 e& p  _2 |- {" [$ Y$ P1 [6 M3 J6 w4 J) H

1 @( v, Z, I- d0 f6 q, q4 P
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
% E2 A, N1 z9 X! b( [1)CCS连接ARM核心3 E" l2 \% R$ _
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
6 f5 ^+ D& `6 c  ]" `  m. {3)连接DSP核,然后调试仿真  
3 ~, o# \( @: q
" R7 \( \5 {& S7 w" T初步联合调试,按照贵司方法如下:* N3 U' a- D& e" S, E
1)启动OMAPL138  linux系统; A6 @, I) d, V" p& S
2)进入系统后5 Y2 @+ B6 A! z6 i9 ^9 ^, J
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
0 ^3 y- U) }9 P% a3)然后再次连接CCS ,连接DSP核心) p2 T3 t  H8 ^- J6 M5 l( v
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
( _" \) g. M- d8 w9 _2 h5 a. p( B9 J) e9 J% A; d3 d# ?3 g- w
* D6 H! F5 [3 q; [( U
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
* w7 Z, W, f) I4 L& Q. ?setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000* c7 `, w" M3 u: B- T' W: y: ?: s
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
, Q; b$ q" o8 _  p. z7 q8 \
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
6 ?3 T  w- u7 L9 l问题解决了,原来内核文件要用旧的
! M5 q' Z% Q, w) y+ B
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~9 k& C1 Z; \2 ?* x/ L$ }+ k- e
“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
& y9 N, _3 Y" ^; T当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~8 J& n7 h$ W% h- W6 `
“TI C64x+ DSP CACH ...

6 b! F' g+ z2 f/ T我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
8#
 楼主| 发表于 2015-8-7 16:38:33 | 只看该作者
我当时是upp定时从FPGA中读取数据,upp存储的数据直接放到DDR上,所以DDR上是存在一致性问题的~~
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
9#
 楼主| 发表于 2015-8-7 16:38:55 | 只看该作者
DDR存储使用的是缓存~~~
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
10#
发表于 2015-8-9 16:54:19 | 只看该作者
tulipyyf 发表于 2015-8-7 16:38
+ }2 J2 l0 R( g2 l- K; b: G0 u7 IDDR存储使用的是缓存~~~
8 e0 `5 A2 L" Z: {- U9 k# J) p! {  |# r
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 19:51 , Processed in 0.041755 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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