双核工作下,UPP不工作 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:$ ?& |# ^! h# O
     你好,我是保定炜达电力的
" R/ b: @+ ^7 k0 H/ W     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
) B% Q. `1 [4 f0 p5 K8 t/ x3 j3 F  q, A' G. d" L& t
void UPPPinMuxSetup(void). M  O* f: x' K8 T+ J$ \( a
{8 Q7 X1 U2 N9 j0 f5 E
unsigned int savePinmux13 = 0;
% l2 c1 j1 A- z! u, i5 s unsigned int savePinmux14 = 0;7 W: Q0 Q. r3 D3 s/ u
unsigned int savePinmux15 = 0;2 l8 P/ u3 t$ s( J4 o) b& Z( W: f7 {7 ^! K
unsigned int savePinmux16 = 0;9 ?$ L9 a7 L6 }6 R% y' k- }
unsigned int savePinmux17 = 0;2 r1 _; T; I6 ?; _, l" d
unsigned int savePinmux18 = 0;3 O# T1 H  @: H5 T5 e% i
/* all pins (channel A, channel B, DATA, and XDATA)*/! o+ K2 B! x$ u+ b: Q
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
; {3 o/ z% i% D) q; @ savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
5 {3 l" _+ y! M- v! Y. i savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);- F7 Q+ r! j" K5 b6 L
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);- c& x$ z# F, M+ J4 Q. V
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);& p5 F# d. h5 c% y
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);' g8 X+ z, y' F( O- u3 x0 ?2 h: Y
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
/ N! C% k2 [. Q2 m, F HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);* p  @2 [/ B9 A
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);5 m8 I' k" b+ p5 z$ i
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);9 E) M4 C5 m0 _1 p6 X
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
" U! P+ c0 v7 v- g$ w( ` //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);6 F+ x& Z: ~4 k* r" s7 L
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
8 G2 ?) ?; W7 L0 S1 Z //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);  Y( J# \3 ^& |% w9 k% U
}
; a! K# w- w& n$ ^- g- I3 l1 P* g: a
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 $ s0 j$ ?9 }$ N3 o" {$ @( Z
- V3 ^) ~: b& j+ K7 m0 U- V

) J8 ~* R: ^# r, T$ G9 S# h  x2 A. G: Y1 h9 \
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
3 T$ Q) Y! P3 g: Y5 D6 y, o1)CCS连接ARM核心+ h% G* O. d5 n& D5 Y& e
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
3 q8 _; V( c# ^6 s2 \- h3)连接DSP核,然后调试仿真  
, J8 M( ?9 g  v3 E' C6 {; Y  e6 e8 r
初步联合调试,按照贵司方法如下:
; T4 }+ r/ ?1 |+ K) q  |& j1)启动OMAPL138  linux系统
5 j/ Q; r8 _8 q" }( D2)进入系统后
, T* M" S- L( J, R& Zinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
- n: ]2 u6 j, ~, E% u& h' i9 H3)然后再次连接CCS ,连接DSP核心% E! D5 B5 M4 |6 a- i. ^
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
8 E; F1 O6 p) z: ]! h
: ]& y* ?, C) g* M8 P2 V+ E. `. D" D
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突( ~  l2 Y# L- z3 N5 p; F
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000003 k% e; u  ]8 H/ ~/ A
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
9 @/ O$ l6 t' d. ~
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:141 q" M% L7 w% s; l
问题解决了,原来内核文件要用旧的

) W6 e$ @3 W6 R不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
8 E- ^: X% P, J1 A, u当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~$ O  b2 s, f  ^; g8 ]5 I
“TI C64x+ DSP CACH ...

( j5 T1 w4 y% Z+ E我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:381 L/ i9 ?: p6 f+ f' s% I2 u0 K# h2 |0 }
DDR存储使用的是缓存~~~
+ H; `1 ^/ E- _/ c3 q
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

点击跳转“创龙科技服务通”

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

GMT+8, 2026-3-17 05:23 , Processed in 0.043297 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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