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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:* k4 g8 E; J9 Y6 B1 G$ }
     你好,我是保定炜达电力的6 b/ }8 }6 S8 R8 F* M$ P
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
: y5 T, s9 A! v- f% D& p
, R6 Y& _5 Z- r) vvoid UPPPinMuxSetup(void)
! |, m1 P9 m" a' ^  l2 G9 a! t{' m" D: ?2 k3 R
unsigned int savePinmux13 = 0;% t( {2 J; B& s4 G
unsigned int savePinmux14 = 0;% w, L; O4 m; b& U+ V) \
unsigned int savePinmux15 = 0;
1 X4 ?2 ?' X! R  ]7 H unsigned int savePinmux16 = 0;
  |/ u8 f2 o* \, |( P unsigned int savePinmux17 = 0;/ Y9 k8 @) w$ X
unsigned int savePinmux18 = 0;
' J/ A- y  s; Q /* all pins (channel A, channel B, DATA, and XDATA)*/
  }$ W( t5 J- N7 y# ?. L6 T savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F/ Y+ `/ U* D" n( J& n  c& I* g
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);0 p; O7 S' O  u) q5 G* _. _
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);! T! `' P. S2 X& [# R. k* O# H: z
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);; z; Q) _% p: {. H" d3 w# x) ]
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);" s% r, g$ p8 v
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);" i: c; c& Y9 y+ h: k
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);1 j. D. |0 E0 n8 M
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);5 k1 d4 W! L% {' Q0 v
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
7 k) ^2 g* m8 @ HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
+ b' o: ^! ?7 H& L HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
" g- |" H% g. W$ H0 V //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);* k6 z% o* Y- B9 u: L
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);& ^, w2 p' @6 a+ F
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
1 U2 V! c( {% B}
& J( E; h2 P; x" P8 r& x# B$ v1 K* `& L
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 . f+ n; U. ?, W% Y/ J

6 m) p. j* P( k; ?* p. V3 c+ x2 f- e' C9 _" m- N# b- |3 E- V7 u

& c# f( c9 M! m. C6 ^' \$ T
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
* Y7 b/ M" o5 F* n  L  g8 i2 T+ {1)CCS连接ARM核心
5 |% v3 @  c1 A; _2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心2 I5 l5 ~" v8 s5 X0 G
3)连接DSP核,然后调试仿真  ; F) p8 z3 V! S' C$ ^8 L
+ S0 K9 A7 H+ M& I  O: t
初步联合调试,按照贵司方法如下:
/ e" C! M% W6 T3 T2 E" l1)启动OMAPL138  linux系统) o* f* |0 {7 p+ T' m1 j
2)进入系统后
8 Q, |. S4 C& D5 q, r, @! Y3 Oinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
) [& P  d$ t& W2 T3)然后再次连接CCS ,连接DSP核心
# m% d3 R1 q# h再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
* h& J* V6 c: h+ f' Y* w
3 m! q2 \+ H& `" P
- @# Y( l2 _) q% ^
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突- s" [; L6 ]3 d
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
/ P* p5 W* F) W. S
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
; b1 \$ [" J& W8 y
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
3 }9 q1 t' {% I问题解决了,原来内核文件要用旧的

( T1 X. r0 i2 C! E: V不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
* ^: u- d9 L) P4 G0 s# @0 @“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
/ l# |3 y* L+ D6 ^- w当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~) ?7 W1 P$ z) u" q9 N$ w% f
“TI C64x+ DSP CACH ...
# l% E! Z7 D& z- E. u
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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; [" g) ~* S! j  Z8 P4 N
DDR存储使用的是缓存~~~

3 E1 z) q, p" s. B* B) C9 w6 }哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 17:32 , Processed in 0.041538 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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