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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
3 d% ^2 f7 q  h: Z     你好,我是保定炜达电力的6 Z/ e4 A; z+ K
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
8 \- o8 S8 x6 \. B/ S2 {! c
" P$ N$ C6 i+ ^) e3 u& pvoid UPPPinMuxSetup(void)
% a! E! b  k! B- P' c{
7 V% {2 \1 `4 ~4 o/ b2 c6 Z# T: a unsigned int savePinmux13 = 0;1 d. o. C) F" c# R$ _, p. L
unsigned int savePinmux14 = 0;3 m. z$ H  A, w  I) _, q, N
unsigned int savePinmux15 = 0;- g. u% L' T3 v7 [. [" L
unsigned int savePinmux16 = 0;
( D" n5 ^7 o8 H% }/ X unsigned int savePinmux17 = 0;
! w% ?0 _5 _) g* z, G) I unsigned int savePinmux18 = 0;. H! p/ D4 J! }5 M' F, ]. [$ q
/* all pins (channel A, channel B, DATA, and XDATA)*/% m8 r, z& ~4 x
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
- p9 S2 @. Z( s4 K! l9 |% m, l  K savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
! I  v( X3 P: O" T. G savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);/ E, {! G: ~3 w, n4 R8 u
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
4 C" a9 `* r5 {+ X$ | //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);+ ?! X2 I! [5 }  e) h8 B. ?
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
. x) Z( d) `8 j5 [0 M //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);0 u. p3 N1 K& E% H8 J1 a; l
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
( e/ \9 X( _) ?& r HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
* P* j( q( {* a HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
4 x7 l5 L' C) S2 p; k/ Q HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
4 @5 j, M( V; S. Q6 C$ K% E //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
# l3 ~+ R  g& Q7 N2 N //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
6 P5 I% i2 [' t //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);: j0 ]6 @+ \0 E0 T8 I! J% d7 g! k
}
8 D: l, w: ?6 t6 g3 c2 s% j
$ w  i0 K% W3 C* `+ W0 G     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 7 v+ _3 O& G  ^" m  z. y" r
2 _8 a/ e' \/ K1 S: S1 A
( u, c9 }, q( @8 X! ~7 I

: b5 G9 E% U7 B1 X) ~2 ?0 @( e! Z
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
+ c, {% V$ H" E$ w1)CCS连接ARM核心
& e' ~! L* I9 p+ O, k2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心8 S) \; c9 Q; x) O7 z* u
3)连接DSP核,然后调试仿真  
6 l, o0 Z  s  s2 C3 M" H4 O2 F  C5 \0 N0 ~3 @1 e
初步联合调试,按照贵司方法如下:
4 G' o0 O- y! T# S( b# D" I1)启动OMAPL138  linux系统
' V$ y) k5 R) l8 X2)进入系统后6 l+ ^/ S& u4 A) I
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1# S& Y8 y- r  B* c, U" m
3)然后再次连接CCS ,连接DSP核心
7 d0 _8 E' f4 S# \1 K1 y再次在线仿真,就发现UPP不工作了,其他功能仿真正常。- j+ j% ~; n0 {3 ~# n$ Z

) K# E) C$ ?' g9 W" q& G4 e. f# Y6 b+ V. u8 t
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突' ?. d1 l* @4 O% X% T
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
' T' \; m! T8 p
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
" a- r8 _  V6 m7 G6 n$ r
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
% R( S0 j- h$ k" p9 ^) U& ~问题解决了,原来内核文件要用旧的

' u2 b* @; ]- @不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
; t) F; B! A/ H7 ~( j当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
8 v- ~3 R1 }( |+ y4 S1 u! S$ t+ B: e“TI C64x+ DSP CACH ...

* B8 |$ E( @. [3 i我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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) `* G9 q" ?  I6 P+ p8 D. v
DDR存储使用的是缓存~~~

  Q4 y; r( s: \. l( o哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-30 22:24 , Processed in 0.044618 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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