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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
* j: |2 }9 d2 g* }6 |. Y     你好,我是保定炜达电力的
( t% f9 X6 F* N9 V5 c6 i: \     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改): e: d! m& Y) ?# B3 u& p

% ?% ~/ b! G, A; |! Ivoid UPPPinMuxSetup(void)- [( b# m; }5 {- K) |
{: h! H- }' B: J2 b
unsigned int savePinmux13 = 0;7 e% T& m8 Y6 e1 [5 u. ]0 g
unsigned int savePinmux14 = 0;
5 o0 }$ C; ]( Q3 ]  S unsigned int savePinmux15 = 0;
% _! g' `7 ^9 U) d1 n& { unsigned int savePinmux16 = 0;
1 n& n6 Z- L2 B* O unsigned int savePinmux17 = 0;
; U& h. }9 K7 ~0 l unsigned int savePinmux18 = 0;
, |1 A2 }& ?/ l% D& t, n" M /* all pins (channel A, channel B, DATA, and XDATA)*/! u5 _8 o+ c3 g( F- C
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F- R. ]  b, L# x' a  ?1 q
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
. [, ^% B" a: ^, D  l- o savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
  Q  n8 ~0 h7 a; C9 N6 t7 z5 w savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);5 I7 Q# G3 c4 S: |% C0 b% `
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
. i8 W  K: R* m) F //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);- _9 T4 L/ W6 \0 s/ S8 e
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
) g$ h% @% B' |9 R( H& {- W3 Z HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);  l3 O0 ]1 _) j4 o
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
% ~  Q# Y9 P- l/ p$ b) ? HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);: j: a  w1 P+ f: l
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
  f, d, r/ h3 m. H" U5 C1 m //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
) f" W: b& J, x* q. ~ //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);5 |: Z& Y* Z0 F. z7 a. u) P
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
1 S0 a8 c% Z' c3 ]. l. w}
' H  h! e1 P, O: e' c
% `6 Y/ a0 E9 H) z/ _5 `& f     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
, m. g/ N/ `& r' ]) h1 k

; Q' x5 ?4 z6 f& R
7 T* B8 d( [& o2 @) x2 U
  Q) c; M4 j) a5 K
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
: I/ \9 D  N/ \. @1)CCS连接ARM核心
3 {. P- J. Q) L; t2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
2 r* c, K7 D3 c. o3)连接DSP核,然后调试仿真  # D. n5 `1 m1 j% y, R9 V! m, i
$ k/ r+ e. @: s/ U$ e# F
初步联合调试,按照贵司方法如下:1 G6 [4 D! A! F: J# e9 O
1)启动OMAPL138  linux系统3 ^  r9 A& R3 J6 R
2)进入系统后
5 s6 u5 p- N8 L5 k8 s( Pinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1, c1 Q. y0 V4 C& f2 R/ W
3)然后再次连接CCS ,连接DSP核心
+ m. _+ u' v$ M再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
; L- e8 z  ^" y4 ?4 n6 U# x9 S  e" Z5 @% |" n1 G! s3 c

; b; _' v" N8 s$ V; j% w+ w  A
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
, G- a! a$ w# _4 ^# ksetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
: b1 r5 ?5 e# w) _
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的" o. l. p4 k+ ^1 u/ f
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14! t4 `8 O6 h; r" L3 s
问题解决了,原来内核文件要用旧的
) I2 Z  o0 v8 H- k$ S+ |
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27+ x! }0 W: O7 n+ g- ?8 ]
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~+ L/ Y2 {- w4 F4 h; X. e1 G. o  r3 S
“TI C64x+ DSP CACH ...

  F4 n% ?4 A1 k  {, G我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
) Z1 t4 r% A+ N6 jDDR存储使用的是缓存~~~
9 v+ N2 D9 M9 ^5 J7 |6 Q
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-14 18:37 , Processed in 0.040420 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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