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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:  _  e* [% H3 x
     你好,我是保定炜达电力的# R# `3 I$ A! u
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
) @- a5 ~$ B9 Q' ~+ [) r$ B: n5 K0 e# f; \' u
void UPPPinMuxSetup(void)
$ C+ D1 T8 c5 Y  P  }" J5 j) R{
- S# }3 C# d8 n& [4 k5 h) t unsigned int savePinmux13 = 0;" C+ D, j9 n9 `$ l3 `0 d; X# _4 v4 W" R! V
unsigned int savePinmux14 = 0;
$ J+ s4 a2 r  m unsigned int savePinmux15 = 0;
3 [) B) Y/ Q: n* g$ Y unsigned int savePinmux16 = 0;( B0 k% o1 a. x6 I
unsigned int savePinmux17 = 0;: ]6 [$ Z3 U; ^* C8 q
unsigned int savePinmux18 = 0;, f# k5 W# ~$ |# B* O0 a$ |
/* all pins (channel A, channel B, DATA, and XDATA)*/4 ]! P) L( d8 y; ~# C# o
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F: b, z2 j" G( J) n( G7 s: O
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);# U: ^% f3 z! R$ w
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
4 K6 V) t8 p, p2 V7 Q' V+ V savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
! M+ }  Y1 [9 M+ b: S( p+ w- I //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
* ?. V) ~. J* K6 I9 n$ } //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
4 Q3 g. g7 g% B( s //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
# X) X( l- v7 \) k' A: G HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);9 L4 d/ h5 O( O
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);" H9 Q6 A/ w8 V( Q2 ]3 C1 ?1 V
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
2 D# r* x5 e9 H, h; i$ ` HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
! W: t$ R( ^: R8 b/ s" x //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
1 N' b) k, ?/ N2 c" V8 D( n1 R //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);& Y  h$ E  ?& D1 c
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);( N& ]3 p% h) X( Z8 V- c& G
}
3 z; }/ c% n0 u- b+ m, a# Q0 {4 B  T' I* T4 R7 _# P' S
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 2 B8 A! a, Z. }7 a1 t
0 U  E& D6 s% _  k3 G

, `: n, s* a* S, H6 V6 ?2 e/ }) y4 l/ U# i1 S& N1 v& W& R
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:7 ]9 w( {9 n4 g4 f! y
1)CCS连接ARM核心
# ^# e* r0 b+ U  @2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心2 e% P6 E# M- T4 a, x
3)连接DSP核,然后调试仿真  
& m8 G$ N' \7 n" R; p3 b: C6 @- X+ s$ `; C
初步联合调试,按照贵司方法如下:
3 J9 g3 r0 e, `2 n4 D$ o% k1)启动OMAPL138  linux系统
# N3 X9 X, W" s' o; v7 k2)进入系统后( F( V1 `- j; w6 z' d; P
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1  |' i: O( P8 H; i; q  {2 l5 g
3)然后再次连接CCS ,连接DSP核心. Y5 g; ]$ q: Q0 C4 R
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
, }- j7 e! T' j
5 w* c7 h. ]! D/ h, o) s! y2 J4 l; B% }+ s- Z
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
' l# y3 q* j6 M4 F9 {" S" Jsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000( \- k8 G/ I: W$ ~+ `# v
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的3 a6 s1 R0 d& E0 ]) H, S
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14: F: a; x! D! H
问题解决了,原来内核文件要用旧的

( G6 A" I. g* s3 w0 _, p0 u3 U% b不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27- W# v6 {( `) O6 E1 q4 m- |
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~  \' }2 f$ x) ?0 ]3 }
“TI C64x+ DSP CACH ...
" ~2 M" A6 j4 E3 V
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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& P( [# c3 Z) W; V- p
DDR存储使用的是缓存~~~

4 f, K6 P0 t: I/ R哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 19:52 , Processed in 0.046737 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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