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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
. J5 O# q* v# q7 x. {& S     你好,我是保定炜达电力的1 i) n7 d# U6 a! g8 e4 l+ c1 k' ]
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)& O7 X3 K- V0 a) C' X' _" @
  f2 L+ q1 F( r+ _8 r
void UPPPinMuxSetup(void)+ ]2 s; x- h3 S+ C
{
3 n9 g) X9 N6 X& s* q& G unsigned int savePinmux13 = 0;
2 H# N; ?/ X! f1 {; T% K; ^ unsigned int savePinmux14 = 0;: ?( t8 w; C' g  D! r5 [
unsigned int savePinmux15 = 0;) t. d  b1 h7 D
unsigned int savePinmux16 = 0;" b- V: ]" ?1 ?# I
unsigned int savePinmux17 = 0;+ F5 S1 i2 U- Q+ L
unsigned int savePinmux18 = 0;
% K) r3 S% V' f6 P9 `$ T /* all pins (channel A, channel B, DATA, and XDATA)*/) E  _- G$ V% J2 v
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F0 s9 k. P1 B+ L6 s- ~
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);9 P. _" B' L- D0 _
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);1 T$ u; m& f+ F. v2 U, Z
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);* d$ U  I8 }$ Z% b2 H% v, @$ H
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
' x6 b5 ?# o& y/ u+ T //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
0 @9 U. |$ l  C0 g, n //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
2 O* d3 d9 p$ n1 U HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
, J. @  i& [5 }6 d1 y+ G4 v- A; P HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
- R+ e! T% J9 ~, M+ s HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);: C) j7 X' x6 B6 i! B
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
7 G, _4 J2 P+ O! k! C; ~ //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);  C7 s8 x6 r2 r+ S/ B) w3 f7 L
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
% c3 h$ p& X& H$ C //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
; ]7 G# h8 E/ h}
5 t1 d' R( X2 h, g, x3 Q8 @# v
* R# Z) k. A# o) c: s- L     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 4 E! K+ d. Y$ L% P3 X
9 ?+ r% @1 d& S. G  b
0 }% R, L3 |) @, M, w+ S

" V. H$ n6 A- Q1 ]4 A9 c% I1 ], R$ j
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:" A% x: H; ~, P7 s( y1 d
1)CCS连接ARM核心) X0 B% P0 T+ j8 O' w, |
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
" g- I# z, X5 ^# D3)连接DSP核,然后调试仿真  3 d- [" a1 X( ~: f4 h

# l+ h# L( N9 j. M& X初步联合调试,按照贵司方法如下:
1 ?3 b6 c( J# v2 i1)启动OMAPL138  linux系统
  O1 }2 z$ p4 V. p1 J# f* r( E% v& W2)进入系统后7 @+ {! o+ L, u+ D) b
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1: ?) k6 H6 y# [5 J' ~
3)然后再次连接CCS ,连接DSP核心
- i" Y. k* A. K" d4 \再次在线仿真,就发现UPP不工作了,其他功能仿真正常。  o# ]4 @0 j/ ~. O8 N2 Y
! Y0 @( @- X. S/ v* r; s# V5 ~

* d) N+ D: D$ p: J' v" c1 Y( V
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突% `- r+ H  M/ R. i, Q/ j
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
9 d6 K% x- G9 p. }. z
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的' y: t  w& g  i: n- X1 k& r2 ^
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
) b2 @. Q% ^; Q8 o$ A3 D6 D问题解决了,原来内核文件要用旧的
/ M# Q: _% E& j, e7 N
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
5 Z' r/ f) g$ W; U1 ~! g当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~& m2 b, Y) m  C& K: k6 S
“TI C64x+ DSP CACH ...

! _4 y) n) b/ Z" y& O我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:382 [+ u* f( @- c8 s
DDR存储使用的是缓存~~~

! X( R" o, L9 M2 t0 c' m/ v  X哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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