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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:0 a2 W4 z4 X3 D; L! z
     你好,我是保定炜达电力的
4 r8 R  v6 T; v     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)& R( @  X) U, i8 l5 S
! P2 O* A& t" L8 U! F) B  X% H
void UPPPinMuxSetup(void)
+ ~: `2 ^5 O) d. @. e+ u1 `- s! j{
2 T/ h' o: ~9 l. B unsigned int savePinmux13 = 0;
3 T7 t5 u3 r0 q. h) q9 r: i8 F6 \ unsigned int savePinmux14 = 0;
4 j! p- A1 `" _" [  w unsigned int savePinmux15 = 0;
- \2 F) A) W3 O8 d8 |4 D. s0 c  s unsigned int savePinmux16 = 0;1 T% G6 d, h9 K4 ~/ m7 N9 O
unsigned int savePinmux17 = 0;' a3 S/ T) ~( A+ B' c+ z
unsigned int savePinmux18 = 0;& {. L1 x3 l4 _+ B+ w
/* all pins (channel A, channel B, DATA, and XDATA)*/$ S0 X  H8 h4 A4 K8 ^
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
( L, n' V! u8 p2 V  v# ~1 O" P" j4 D" b6 U savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
0 z5 O' v  ?/ m3 P savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);( H1 O7 t  i' o- K
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);8 M2 g7 i, B4 K6 f8 |
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
5 y. Z1 q) G7 S$ t4 F //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
. U& G# \. J1 u6 z' t4 X6 U //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
: p1 V# N# U4 s HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);& w7 \) Y% ?% b5 Q; ?$ K' F* E9 H
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);" S( J, m/ _0 c+ E8 _, W. A
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
& @  \( |2 |* B0 T HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
! F* x9 h" K) M3 l2 D- {# F+ n //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);- w0 q8 e  L) V0 G5 {
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);. q2 k1 I, k: N$ R! R
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);! H* u. ~# L+ a
}" O2 \, m9 L) ?! c* U7 a
4 B6 L- @( c7 r2 Q$ q' w
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 - J; `% u5 z  Q8 U% p' k1 x: E" r
+ W# j: a3 z# w
2 P& O) `6 P+ i2 `- s+ o" S

( W, I2 k# i' U8 c: G4 a
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
, X) x/ a2 \/ J7 Y# ?% b1)CCS连接ARM核心
; E. @# X$ O) n7 n2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心$ R+ N, p7 ?' s) m
3)连接DSP核,然后调试仿真  
! G/ ^0 q% f' F6 m8 l- _7 e5 p
* X# \& y/ `; e0 y( @+ G初步联合调试,按照贵司方法如下:
: u: o" G( `5 s  F$ Y" y& K" [1)启动OMAPL138  linux系统
& _, S0 v/ ?% ^0 m4 D- G- L2)进入系统后* j  _/ b/ n( Z
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1* F- D3 Q8 E, M8 Z& a# o2 V
3)然后再次连接CCS ,连接DSP核心0 j* p9 L1 Q( ^! k, F
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。0 S* q9 @! ?- q1 C, ]* N

( O8 A$ }. b* c/ H/ e* I9 t6 V7 N, B! E
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
: d6 r$ l8 \  {3 ysetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
! h! j0 z0 |- C1 E! \' L, @( j' W
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的0 W9 t+ ]1 M1 m/ i  K5 F
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

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

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

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:277 a) Y* w4 r% w. {
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
9 ]) g4 N( s& F% p" t) @* s( ]“TI C64x+ DSP CACH ...
. X( k8 a% |& ~  f; s$ D7 d2 S: ]
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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$ U5 N, s+ r9 V
DDR存储使用的是缓存~~~

4 l: I3 U6 w, I哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-15 18:00 , Processed in 0.039676 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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