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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
$ S1 L9 N' x+ R! ?* c3 }3 @     你好,我是保定炜达电力的
- ^5 o7 \' p$ S6 q! F" P     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)* a+ a8 X4 b3 X. u
9 H/ T- U/ p, W; U$ C8 ?
void UPPPinMuxSetup(void)5 i. p7 H! u5 v
{$ b$ }: M7 w. h$ X
unsigned int savePinmux13 = 0;
3 w( K+ V4 X8 i4 }% R unsigned int savePinmux14 = 0;
' f2 {; ?1 y  j7 z* z unsigned int savePinmux15 = 0;5 g2 ~) C; d) s, t
unsigned int savePinmux16 = 0;
' i6 T  H. U9 x' Z% g4 s! @ unsigned int savePinmux17 = 0;
0 i# `5 A7 Z; J, f unsigned int savePinmux18 = 0;$ Z, x5 d7 H5 }" z
/* all pins (channel A, channel B, DATA, and XDATA)*/- z! r% }& r2 s, g
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F1 |2 z! o6 R: ^% J% u. o0 I. m
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);1 I- E+ l# Z( D  e: C' a: t, t7 D
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
& T; m2 _$ @" |: a0 E7 A savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
4 D7 q$ H! |8 p7 m. w //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
* V/ O/ X0 G* \: v- M3 M //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);/ y% X; K7 X  t# N* P1 i
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);7 e& c: s9 x* [% X$ N0 [: K6 a
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
) \- @) x. X  t+ C HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
. i3 g5 ]( o, r; w! u) N HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
8 O5 Y, K$ I) Y' N, b' a% c HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
4 d7 _' q- \# s" p //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
9 N/ Y6 T6 W5 q, k- X2 E2 N& p //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
$ [- X  S- b2 }' c //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
2 ^5 _6 K, y/ B}
: W) V2 S9 z% E1 o. g% e8 S! ~$ ~7 S, ], P% l
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 , \2 G+ k: [6 b2 Q) L% \
( s/ [7 Z( p' p1 T% S& ]& o
; C" F! c% j! ~/ b% u
9 O5 O" y# a; V# _; Y
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:2 z- d. T$ Q1 [  z2 w
1)CCS连接ARM核心0 R/ Y+ U/ H; ?8 B& }
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心1 m7 p+ W' v" L
3)连接DSP核,然后调试仿真  7 ], x. w, A0 P2 n3 V

0 y& v/ V1 |1 B" J% ?/ C! W& d# k* ?) ^初步联合调试,按照贵司方法如下:( W- O1 @# @! Q8 R8 `
1)启动OMAPL138  linux系统
+ ^' }- O5 h6 w6 h2)进入系统后! J% I. H( `  F* _% D8 b
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=13 A2 ?2 Z" b4 D3 U
3)然后再次连接CCS ,连接DSP核心2 n% X3 P9 c) K5 ~0 b5 ~% o
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。$ j8 r  b3 [# |7 N5 I6 S" y

% D) O/ _  e- A3 k4 Z1 E
. h5 ?( w  }) n" Q
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突# a% {9 M( v4 v5 t% A. [/ W
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000002 w: }  Q9 p7 ^6 t$ T2 C# ^9 g+ M' K. V/ e
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的5 ]4 A/ `5 |3 J2 w9 P6 n
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14; `) P* @( E( x5 X5 n' Y
问题解决了,原来内核文件要用旧的

9 f  d% [- }9 i1 C8 A不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27, I- U/ f1 G4 o
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
4 Q$ x* _' F0 c" \$ [& m“TI C64x+ DSP CACH ...

6 D$ Q2 x" g8 j+ ]$ Z  x我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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 ?7 x1 B5 ^$ F0 `. u) l+ t
DDR存储使用的是缓存~~~
0 F: w/ D  {, H4 I
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 03:15 , Processed in 0.042986 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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