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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
5 T5 Q# c7 Z- r( U$ U     你好,我是保定炜达电力的' z2 U" Z+ b. @! t1 y! ?0 {
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
; ]6 g1 u! z7 M& p
+ g1 p  A) a1 N% p- x1 nvoid UPPPinMuxSetup(void)
/ C8 [9 a. j- o" c) j/ W1 r, e{- p, L6 h- U) P' j% Y4 L; H: E
unsigned int savePinmux13 = 0;# X- K$ k8 `1 g' r  g
unsigned int savePinmux14 = 0;/ O( o' f- V8 ^; x
unsigned int savePinmux15 = 0;, ]$ X( p6 q: ?7 u
unsigned int savePinmux16 = 0;
3 ^9 j" |: P+ n; N unsigned int savePinmux17 = 0;
, V8 O) ^$ M7 M unsigned int savePinmux18 = 0;
% s- J* C* |: R+ W* ~+ H /* all pins (channel A, channel B, DATA, and XDATA)*/4 u# G- u. I* ~& E) z+ U+ v8 R
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F( z4 R* Q, Y. e  E# g
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
" J1 b/ z. l5 T5 u! W9 f9 ]; ^ savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 U3 S/ x( c& Z
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
8 A, W; r# I% E" d //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);$ v& w" S, ?, I$ U: u3 x. t
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
+ g2 d, f1 [8 g9 v8 i //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
$ w+ S% O0 P0 O- j4 I HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
( ~* N% ]# i! x% G7 m HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);5 x9 T: L8 j. S8 g: ]- S- I/ z* g/ L
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
9 J+ a* L; G; y* Z$ Z9 e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);! R+ w. C2 x$ O( g$ Y
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);# R- _2 m( Y/ B
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
2 q1 q9 a( {! Z3 ?8 X: T //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
0 ^% v5 I0 v! c1 ]' j}
; o$ b% c5 h( _" S$ p; m1 y( C6 T: R" e9 J/ X
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
, P$ _8 f5 n: m3 M9 a) Y
8 y: V0 U* S" m1 N4 u* }; l, u7 I
* @5 B: W' q( {& q& U
) y5 N) i# F6 z: I1 R& v
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
1 K$ G/ v) R, @3 k0 }1)CCS连接ARM核心5 Y* z! Y  I4 m1 t
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心) ?# H! K  @  o3 ~- N9 b; @4 Q: w
3)连接DSP核,然后调试仿真  
! ?& L- h( E  r$ e: t
+ E7 H7 K, w# r初步联合调试,按照贵司方法如下:
9 m2 |( T: [' j6 {3 e  P! N1)启动OMAPL138  linux系统- A4 [6 m  b* k4 }8 D" @0 A
2)进入系统后
( j# U9 ~6 ~/ S$ w9 ?, A: ninsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
" z4 A) n7 U; |2 h# A3)然后再次连接CCS ,连接DSP核心; t1 E7 o* l- T3 y6 F% k: f+ ]
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。! X+ }  D( j9 q. n

: s  y) {& F  o% x1 x& d( e. G( @3 A  K# T6 m  o
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突: S- n& \3 Q; t. v) {, n$ j' A
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000* e$ g/ L  _/ g! q
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
& i3 a. i4 R9 c( o
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14( q/ j/ z$ D, p: l; H) h
问题解决了,原来内核文件要用旧的

" t" ^0 d) @/ v- l- k不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:277 O, `! L. d7 {/ k
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
1 \. _" y' d3 N2 j“TI C64x+ DSP CACH ...

1 d$ x- H. Y! T, a我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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+ h% u  t3 M3 N: n9 {: D; f* v
DDR存储使用的是缓存~~~
* k- V; V. ~2 ~3 I/ [
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-17 02:32 , Processed in 0.044510 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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