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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
$ z( n4 X* R) u3 s     你好,我是保定炜达电力的* A! ?% n: b5 X8 s7 z& r+ S; w% W
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
! k$ @. `! ?/ t* e- A9 g* v7 O9 w5 _1 s% ]
void UPPPinMuxSetup(void)7 g4 D3 X4 p. o7 H
{: W& G7 k% g/ Y% P5 _" n  c' c$ u
unsigned int savePinmux13 = 0;( w( a7 k* t8 e
unsigned int savePinmux14 = 0;
0 s! s+ K8 f* v% P- }4 Q% W unsigned int savePinmux15 = 0;* r" d% M5 E% k1 x; V6 w
unsigned int savePinmux16 = 0;. Q( s9 v2 R2 y& K9 S" z3 q
unsigned int savePinmux17 = 0;; N" p+ b8 p, a, @! J' I) M
unsigned int savePinmux18 = 0;: d7 }4 P& g$ }3 k
/* all pins (channel A, channel B, DATA, and XDATA)*/
- p# ?5 i; l$ U* [ savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
" ~* c# R! H( a) l savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
0 y) s( ^2 K+ C% m& U  [ savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);0 G, z/ d5 I( a2 b/ J- D; w
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
4 n1 J- g# @& s //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);9 |! ^$ {, s) c$ R3 v. f
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);9 {, c! H" P; d
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
7 [- E7 T7 K2 I HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);9 m0 H- R) E. L9 [3 O- j5 Z
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
6 p' K, k7 z* {6 Y$ I HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
, I, ~) |* z$ A+ y+ Y0 e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
# K& H2 d8 W3 g9 D7 Q //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);; F/ r$ I/ v$ T, ?7 i+ k
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
& `* h0 x7 `3 a( w  y' q //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);2 c: ~- [% |+ o' J; q0 ~8 Z; ~
}) A6 P" g/ E7 ]) N
! F/ R4 H1 E8 I% ?# ]9 g
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 1 j+ \) n1 I- R
- B& j( _; s& I% |/ Z

4 r* ~& s8 Y4 |! k7 n
. L/ i: a* m1 s4 n3 o/ I
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:4 k: _; q8 X5 Q& G' l; x9 d5 h
1)CCS连接ARM核心  r: t* I. p" y# M- }, n+ \: ^
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心+ ^7 ]! d) C, E7 d! x# U
3)连接DSP核,然后调试仿真  
/ p: b+ Q# \, H* U/ H! e) I( q6 u3 y; }0 r' x
初步联合调试,按照贵司方法如下:
  ?$ ]# x; ?  w6 X  H1 N1)启动OMAPL138  linux系统% t% `# P$ D. c0 e# g- R+ G) w3 Y
2)进入系统后! A: I0 S+ Q8 J8 L" q3 i# [  E9 B
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
- Y9 f  `" ?' E! Z$ P1 L4 {9 T3)然后再次连接CCS ,连接DSP核心
" t" q, g$ f8 d, h! A' k再次在线仿真,就发现UPP不工作了,其他功能仿真正常。4 E& ^; M. n1 y9 Z! c8 h# P5 n7 d

, `4 B! s6 A. m) ~8 Y. F
% G) s/ E* W( `
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
2 X, e, V. [+ ?) S1 T! V/ H6 bsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000' K4 X0 |7 Y- N, R; D9 u
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
  E8 r5 N4 f+ G* c. z7 |
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
+ \4 I1 y- Q2 Y. w$ k" M: E* c6 U问题解决了,原来内核文件要用旧的
7 _, u' O* Y1 O) ]
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
% c3 T0 ?- ~. B( S: x! O当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
2 E7 q2 O0 }; V0 u* D“TI C64x+ DSP CACH ...
9 R% ]8 E7 P9 G- L
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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' [; {9 @$ g6 [2 A& Q7 P
DDR存储使用的是缓存~~~
& K; v2 d$ [  l3 C& j
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-28 06:46 , Processed in 0.041557 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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