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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:$ E& P( p3 ]% a8 r0 b; X
     你好,我是保定炜达电力的; a' o9 k6 f% U
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
  ^- b- M- i! w1 R
! B! r  X+ ^# z- i1 B8 ^9 vvoid UPPPinMuxSetup(void)8 N% D  Y. P0 Q" z$ o4 i
{9 I/ U2 h/ v! h7 O6 ?  l7 V
unsigned int savePinmux13 = 0;. D' A& F0 e6 A* `
unsigned int savePinmux14 = 0;
( o* K  K5 U0 a1 E5 e6 n unsigned int savePinmux15 = 0;% }! t7 @; B$ o* j& I+ g
unsigned int savePinmux16 = 0;
. z! g. u2 Z2 r4 J unsigned int savePinmux17 = 0;5 u' a7 o1 z/ Q& u. y8 I
unsigned int savePinmux18 = 0;# n8 W8 ~' R5 h
/* all pins (channel A, channel B, DATA, and XDATA)*/6 c  v: z: ?- X
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F  E; {7 F2 C: X  [8 M7 s  ~2 ^' H
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);! r8 G* u  b5 H: P8 T  R3 x; V
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);- m, f; X1 G% ], D0 a. z
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);& t/ q  t" X( O- ~0 A3 x& G! L
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
5 H2 R: {" G- v7 a% J //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
; V6 h9 I$ p& O9 T( n$ @2 Y; E //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);6 x/ n5 R1 N4 K8 A# x% ?  D) ~) [9 X
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);5 \/ ]' A! [6 J, A+ O  g: J. Z% V
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);7 T; a( z( R: ]
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
. a* R, A3 ^+ L' d0 i# H HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
) g2 \& y+ d, b8 k* `! k" j; L/ I //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
0 ^8 J$ {) m+ z //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);9 ^! d5 O/ L* d. j5 ?
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
7 M! V  g, }' o5 R* _- a# I}* z3 M2 p7 h. Y' t
% P; Q$ d4 r3 ?, |9 _! `6 a, j
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
+ s  o/ n9 w3 {. E; x

- Z% }+ t% a+ x7 h- W. q
8 B+ I: A- [- Q
: ^+ M- n( G% s" U  q
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
- [+ a6 Y0 T/ ?, c5 u8 J1)CCS连接ARM核心( q0 B' x1 z/ e" ^
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心) K  j* L0 \# ~; F, b7 @  p; i
3)连接DSP核,然后调试仿真  
* g; q/ @$ p; {$ B# V7 P  f; O
. x2 q6 B4 A/ I+ m  q; s" o1 e初步联合调试,按照贵司方法如下:3 |- P% I& ]" C* I# u$ Y! T* ~! X
1)启动OMAPL138  linux系统
1 M; q) f# m7 Z$ Y2)进入系统后: I0 V: b6 F$ h9 u) B
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
5 l& Z* o& Q. z/ N. E/ r8 F1 r! ^3)然后再次连接CCS ,连接DSP核心* o% _- R8 A+ P# R8 ~! H
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
- T  K! i2 T8 M2 U" }' G" I& G7 u! G6 h" N- q
' l7 Q4 ~$ s4 r4 j2 v
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突( {) B# ]% P) G# ?9 f
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000/ j* u; l: [1 {2 \8 g# J
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的5 a$ D4 Z) `6 a: \
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
5 r) x$ W, }% K% j8 `问题解决了,原来内核文件要用旧的
7 o* K7 h8 Q+ e
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~- [7 m8 {* s: T% l& y9 O" E
“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27: k  {+ B1 o6 H  i  ?* Z  T
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~+ Z, O8 L- J+ R8 k) a1 B
“TI C64x+ DSP CACH ...

( C1 M0 x* R# g. n* 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( t: y& r- W* S* ?) q- }
DDR存储使用的是缓存~~~

3 e& t" f) H0 O( y哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-15 07:49 , Processed in 0.040576 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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