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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
' U- F: f( t+ ~. u" D: {, P     你好,我是保定炜达电力的
( I% ?1 c" \+ k4 K# \. e1 H     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
9 _9 {. _' F% s& F
3 E2 W7 U! g$ g. d4 mvoid UPPPinMuxSetup(void)
5 ~5 d- v0 n8 G9 N1 s{- n7 i) D" C. K2 A& j
unsigned int savePinmux13 = 0;
" W! z7 r2 }: b' e" {. P( d8 u unsigned int savePinmux14 = 0;
/ K  m( i" N2 {+ S% t unsigned int savePinmux15 = 0;# w/ M, a4 X( x- ~" ^, u
unsigned int savePinmux16 = 0;  b1 W4 u! n4 n% i" \
unsigned int savePinmux17 = 0;3 k' K7 [$ d. _+ S
unsigned int savePinmux18 = 0;3 b1 |7 |- L9 ?& m
/* all pins (channel A, channel B, DATA, and XDATA)*/
$ b# q, R0 A% K% O0 X savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F0 f2 U6 ~2 O6 r2 }* n( a9 o- H( {
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
' k5 R4 o3 W* s& ^3 e+ Q savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
8 o& z: S- Z$ w* x5 U1 i3 _0 T savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);9 A' @) d2 v  `
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
! M7 h* p" i$ W- P# t; @ //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);8 _4 ~3 S& J0 w" g0 Q8 f/ L' o* ~
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
* |+ `" D1 ?( Z' T HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);& S# m+ J* a* [: M. N8 N
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
: g; T0 r* x0 E! `! B. W: r" K HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
; x. g7 m/ B- s8 l$ s3 q* O HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);+ H+ E2 I6 e, `3 E. [( e4 r4 K& T* V
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
( y8 ^* l) A, W8 R& w5 i: i( l //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
) `8 a+ K0 F# B% S  L //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);3 ^  K# K: R4 P) l  o8 t4 Z
}* |  l. A' N- b% z; k1 }
& y: R8 k5 e. b: u; b/ d! ~
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
4 J6 F( d* c* u# v+ P
! J" U% {) \; [

+ E& e$ o# j- f1 l. Y! u; e4 I" b$ g. k, F
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
6 e* c( n. \4 w' J, X1)CCS连接ARM核心
, Q2 _8 b! u0 o2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
. q1 f9 Q. K; M' a3)连接DSP核,然后调试仿真  $ a( D1 w: ]' q* b
( K1 }% _' e4 [
初步联合调试,按照贵司方法如下:
, b1 Z! G' n- `1)启动OMAPL138  linux系统
. R' o. y9 G2 w2)进入系统后( N) _+ M& U9 z/ `2 R
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
: j2 y$ b1 ^! g  n3 a6 O3)然后再次连接CCS ,连接DSP核心- ^. _* e  f$ q1 [& @$ h9 e
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。- v$ h0 x1 x. _8 u9 F: r! a

" ?0 D4 D+ I! y& U2 P2 Q7 a( l6 `1 i7 i; r8 F
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
2 R7 ?) T: d9 Bsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
% }% s0 u+ }8 i: Q* Q) K" v
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的6 ^; |! n/ \7 M0 w0 k
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
% J. D4 A6 Q' }6 j" y问题解决了,原来内核文件要用旧的

# ?$ N1 m6 |  S+ U0 R; c# A不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27( t- p: o7 x- ]; x
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
2 ?; |$ l  r3 g6 v$ i% }% ^. S“TI C64x+ DSP CACH ...
3 B* S: _; P/ v# d4 `
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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) e& Q6 E1 \  @) j" B9 s3 q
DDR存储使用的是缓存~~~

- E* U3 u/ a4 T, A哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-2 19:34 , Processed in 0.039407 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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