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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:1 L6 I$ ?. o+ n1 d3 K
     你好,我是保定炜达电力的
( ?7 E" J6 ]( e     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
& C! b( f0 Z! K4 E4 R+ V" {3 K3 k+ x' C6 k, A3 m# o
void UPPPinMuxSetup(void)
# j" B3 \$ P0 H; Z' F6 v{
5 Y6 K6 O1 D* C4 @/ c& v unsigned int savePinmux13 = 0;
* f) f' S' H" _6 W unsigned int savePinmux14 = 0;
+ d( Y, |! ~& f1 q& a9 y unsigned int savePinmux15 = 0;: Q3 L1 [# c1 e1 C1 r
unsigned int savePinmux16 = 0;
5 v; I. \! h" K4 T2 {% A8 n unsigned int savePinmux17 = 0;
) ^2 x* S6 W) z4 E unsigned int savePinmux18 = 0;1 ~& L: y+ ~4 q1 z1 W
/* all pins (channel A, channel B, DATA, and XDATA)*/  N% z* j; h7 `$ d1 Z% t
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F6 n) O( t6 C) F' l$ D4 t0 a
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);: S2 `) [8 O0 _* P- T5 O% }) w
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);- w, M; [5 T! L4 B/ O, A& \) p8 X
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
8 Z$ I2 _( F( {# t% B6 n //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
0 L4 F* U3 G& o( {) |9 ]2 j //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
- N& h' Y" Z9 U7 `+ B) T) @5 d8 P //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);2 @5 {! Z& `6 {$ g) c3 y% Y
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
  G% O8 w! a! C  J5 { HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
! r, P% @* ^6 s: [ HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
7 t9 x. A/ `2 u  R+ Z HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
. Y% P* v' C' h) `" g7 k% y8 ^, x //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);+ A3 \# t5 A; Q! K# Z
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);: |3 Z& z& j" H  m. F. n0 n
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
$ d, Z. u7 U( R+ m4 q# ~. j  t}
0 H7 W8 l( m5 x3 K1 [" a" V: o, ^+ z
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 " m: _  o1 q9 P

; }1 @/ w" ^/ }; ?7 k. v8 h/ m4 Q; l0 F9 }

1 P2 d, W4 u) q4 Y, u( y. L. S  e
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
8 Q9 |. x/ t( S! n# K7 b* m" N; O1)CCS连接ARM核心
8 g# `8 [  u% F, q6 [& e2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
+ w3 i2 v9 o! c" @! y, w: ?3)连接DSP核,然后调试仿真  
% L) W& p& D8 d2 y! @. [6 }  `+ |. m) A6 E4 B) P
初步联合调试,按照贵司方法如下:& w5 H! C- @( z1 j/ A
1)启动OMAPL138  linux系统; M6 W" f+ H! W# ~% E8 g
2)进入系统后" J+ M& s5 K# i% I( l
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
4 n6 {, z7 F$ S! V) \$ x- [3)然后再次连接CCS ,连接DSP核心1 z. o1 \% n- y/ j
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
$ i8 }' ]2 c2 v$ P
$ C& J( }$ J, E- C+ X/ X- T# \' C8 W4 N3 E7 f5 q, |0 Z
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
3 I1 U5 H# m: o8 F9 f5 l- tsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000003 U2 ]1 U- N1 v) s7 u  t! U
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
5 _+ u! ^3 M5 f1 _
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
( W1 N4 I1 B8 A" }问题解决了,原来内核文件要用旧的

; N5 r/ h2 M( I% }6 \不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
- G- T# m+ Z- m$ i$ ?$ u当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~0 a, C& r$ S1 I9 v0 i% X
“TI C64x+ DSP CACH ...

8 Q/ ^9 A4 W. e+ 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:380 q. }9 {, O8 L$ j+ v# X7 V
DDR存储使用的是缓存~~~
0 P9 }8 T1 [% D! V* d1 ^, U! k
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 08:58 , Processed in 0.040834 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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