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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
6 T- ?7 ~7 Z4 N     你好,我是保定炜达电力的0 I# l% O5 g9 g) z" d2 t$ F
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
: Y/ C' n7 l8 B7 Y. V5 J
/ E3 M, p" K3 [( fvoid UPPPinMuxSetup(void)
& v& O5 R6 j7 o1 @/ i{  a! w) b; [  s. }/ L2 |
unsigned int savePinmux13 = 0;. {0 `6 ~9 g0 ]% n/ Y( p, S, \
unsigned int savePinmux14 = 0;3 X2 U( T) {! E* L+ w' J! z( ]- R9 w
unsigned int savePinmux15 = 0;! m! e& }4 Z6 Z4 q
unsigned int savePinmux16 = 0;
3 }4 g. x* k0 D; t  V1 _ unsigned int savePinmux17 = 0;4 s6 ^% S& w& H3 Q$ h2 A
unsigned int savePinmux18 = 0;8 J6 Z0 n4 ^4 x: f" `( v4 ~
/* all pins (channel A, channel B, DATA, and XDATA)*/2 u- c8 ~5 z6 K: A
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
: ^+ R- b$ C/ F savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);( u+ {. ^* i3 H
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
: x' }" g0 l% n. m4 [ savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);1 R1 e, U4 P3 |" u) w8 X7 A  {
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);( u! H& d( V* X- m
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
# [. O$ c& Y$ P' w) {% R, Z; @ //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);' l! P( R. y9 Z  _1 V- D
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);2 U$ D1 f. n! ~4 a0 C- z
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);) `6 w  N  M& }- f( C
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
$ n8 J. L9 d! i4 M5 {7 o# o HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);0 w+ E. U) E4 I9 x8 t' W
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);! S9 p# R2 {5 @+ x9 j; Y
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
( O- l6 h7 V& F7 g8 @5 q2 D0 ` //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
) z  W9 D" M: K) l% M}# d0 ?$ f) g& v" w  b4 I$ z
$ R: ^% ]' t' ]2 S3 k8 u+ p
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 3 W6 a8 ?& M% m+ s9 M
# [( G" M2 V0 J; G: W

, L( e& F4 V5 _: w3 p  a% C; L* n; a" J
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
0 s; \9 P; ?1 ?1)CCS连接ARM核心
, x" D2 q# D# Z2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
2 E" ]! |2 i, g1 f5 A9 J6 `, B; S3 V( `3)连接DSP核,然后调试仿真  0 O3 R& }( {8 o" B
5 a$ T& z. y8 f9 h: B
初步联合调试,按照贵司方法如下:6 R) Q+ l. b* }
1)启动OMAPL138  linux系统
4 o7 g8 w3 k% o7 Z0 `& ?, s' g- l2)进入系统后9 L! k: J/ [' u: d
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1, B8 n  v8 P4 p* U( b7 ]
3)然后再次连接CCS ,连接DSP核心" _2 x3 G1 N: A/ S/ P; }" V
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。+ f, B3 Y5 n2 {4 c8 E! X0 s

0 i2 S+ C3 b5 P/ Y) G) r
$ m4 u9 x; m* w6 s1 h
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突7 O- q* B# z0 K& g0 V4 i
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000006 X; G8 @& x- s0 b" i/ J
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
' S& B! `  a/ |
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14$ B0 N4 I6 ]$ C/ r3 w' ?
问题解决了,原来内核文件要用旧的
" V/ X4 ?! ]- e
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
7 m- s( ^2 M; P/ b5 @  O当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
7 b8 d& k3 N8 e- D& l! [“TI C64x+ DSP CACH ...
% H: D6 ^9 m+ r; K8 P
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:388 k$ }+ V! V" w6 N% O
DDR存储使用的是缓存~~~
9 P  d7 B9 M1 O7 @( n4 L0 B
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-15 23:45 , Processed in 0.045631 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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