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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
! s( t2 L. |2 {4 j0 ~7 h2 `( N     你好,我是保定炜达电力的
1 Y7 a8 v% o" f0 P* c: H  T     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)* J- q) |5 D* N

7 T& W4 E6 E; T( H) hvoid UPPPinMuxSetup(void)& ~- E" M) ~3 M: K' s2 W) U6 N
{! h6 o5 k) X$ P$ p5 D: ^
unsigned int savePinmux13 = 0;
  I, W3 w( H0 Q* I. Q: S unsigned int savePinmux14 = 0;
+ `0 N% M; l) u) Y3 Z9 `; F unsigned int savePinmux15 = 0;3 D% Y, ~6 U9 K" b8 M
unsigned int savePinmux16 = 0;
) T9 j  m; z- r* G& S* c7 w1 p unsigned int savePinmux17 = 0;5 [. A, q; O& Y& U
unsigned int savePinmux18 = 0;3 x. L8 a; U' h: B; w4 P$ y5 s
/* all pins (channel A, channel B, DATA, and XDATA)*/
2 r4 B2 h# e4 a) n3 t& X: l3 D* P9 d savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
6 n) x" o' \" X0 x8 |' V% u4 X9 ^ savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
+ G( u. ]; j- n5 z% A$ i savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 D/ M6 @. n! F
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
: N" O0 ^* C6 J/ r: c //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
$ b3 Q4 V. X0 g* R  Y //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
4 h* L; J5 J, B2 N* \3 Q# c //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);( n3 A$ n# q3 Z/ V, T* I
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
3 W% o" O% r8 F6 \& J1 B4 a HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
/ L5 S( l; K, s6 d; X+ l& f4 f HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);  K5 b- t* M8 A) d1 r
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);5 h2 ~' k0 x" ^, G& v8 C9 c
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
) y! d9 O3 M) p& z //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
# B% D5 c" p2 a# c9 l# Y0 ?7 b //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);7 m2 Z7 X8 R) T6 r# ]) x) @
}( D& o* D$ b+ a* ]2 N- R9 m

" z5 {6 ?8 b& R; ?  t8 D     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
5 W5 ?9 D+ \$ b
$ o+ G5 \! R0 `- g+ H: x' s+ @% Y
- ^7 l6 j- \# U

  P' E4 D0 V$ y" O! J8 t
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
0 x3 U# P7 [+ W1)CCS连接ARM核心: ]+ v4 B, Q, u1 J8 h
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心: d% n# z  u. D% N1 i6 m4 ^
3)连接DSP核,然后调试仿真  
5 s% _* b# k5 S
( ]4 l2 d5 C% |* \. j初步联合调试,按照贵司方法如下:
" M  B& J$ |# W6 M  |8 l% U2 r1)启动OMAPL138  linux系统" N# }9 |0 S, s: M! \9 d
2)进入系统后
% S( p. V. @1 B/ a8 x, Iinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
) ?3 _4 K$ V: G# f" o1 V+ z% z, L3)然后再次连接CCS ,连接DSP核心  \) c; K( T$ w
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。$ d# z( O: P- }
8 M9 z! \7 n7 d5 x6 j
4 l# [' a0 i. w6 |8 _" }
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突& g: y& c; \' r0 _$ q' r; `- l) k9 o& S
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
7 d% E% r2 `3 m5 `( q+ U1 E
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
( v$ G* L8 [, w* x2 `* Z
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
" @3 j& c; L' S5 l8 i! _. d问题解决了,原来内核文件要用旧的

! F2 U+ e# ]; }9 H7 D9 t# V不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
4 ]2 r( M! u2 ]$ N0 H. D  L" G" I* U' m“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
" Y9 A' t$ v, R! j8 q当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
2 e' n$ Z8 ^$ _! d+ C“TI C64x+ DSP CACH ...
7 s8 `0 b7 Y# S. n
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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. S9 [2 a! p  Q0 l. B3 u
DDR存储使用的是缓存~~~
2 C- s6 c. A: U
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-7 01:23 , Processed in 0.039909 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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