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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
6 G8 Q! I8 ^: [8 G     你好,我是保定炜达电力的
, l  z- m2 s. U     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)) d5 I( G$ m) V- }/ B

) }' `/ Y' j( u. R% ?8 N& o8 [+ U* jvoid UPPPinMuxSetup(void)0 e: s4 O4 }; j5 G! z& ^
{
7 q. X  T" u- `0 d3 M9 v unsigned int savePinmux13 = 0;  E5 \1 N* d* k  q7 @$ ~
unsigned int savePinmux14 = 0;6 ^4 d' H. ?* [' W3 \2 W. \
unsigned int savePinmux15 = 0;4 @. ^) V! a! y, v- k' l
unsigned int savePinmux16 = 0;
4 T2 G! D, p* O unsigned int savePinmux17 = 0;
. ]. f" S: S2 i/ [- p unsigned int savePinmux18 = 0;) s5 o: n8 X  i1 m
/* all pins (channel A, channel B, DATA, and XDATA)*/
7 ?% c& D+ K& h savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
2 z; `" `& c& @% p& R savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);2 [* c8 s% r; i, j( ^4 m3 @
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);1 ]0 A8 B2 M& ~7 e- @9 F1 l+ k5 h! B/ Y
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
% H$ u; j, z. t6 m2 O //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);+ ^: ?, G0 ]1 X; h7 T0 b# j
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
- f" t9 V0 u/ F2 N //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);5 e! W6 i# u2 P- `
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);5 J" j# g$ s( V8 E
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
- F6 H7 N, D3 {% Q: Z HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);5 s. M. `( T$ C; S0 i4 j: w/ ~
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
* [4 C6 v! Q. C% f* D //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
* \) j# L5 ~* N //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);; O" ^9 k& ^9 d
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);# o. y+ O" y# s( D  n8 n
}1 W6 ^& L4 u( z1 E! B% W
3 P% J) w( `6 ]3 W( r% D( i
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
% T4 V, x1 x0 c8 _5 y4 I

1 _* W$ o) d" h4 B- ]& I( q' S9 z/ [# f/ ?& `

3 n1 }7 V# o2 L6 ~/ y
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:! Y3 z4 A9 j" O4 G
1)CCS连接ARM核心  M' T* v. V5 t
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
, c9 V" U6 k$ a7 k" a7 L" e9 G3)连接DSP核,然后调试仿真  & K8 f" `' B7 N" t2 B

4 d% ~6 O% b4 Z( m* P) c初步联合调试,按照贵司方法如下:  z4 B# v- n% t$ Y3 c! r
1)启动OMAPL138  linux系统& q0 ?, N4 I+ o2 r" F5 O
2)进入系统后
1 m' y' O0 `2 y- e5 Jinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
/ }  H5 `. }& E  L' P, `3)然后再次连接CCS ,连接DSP核心. g% }% \( Z9 q* N
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
" D# z' B( b* e1 m( t1 ?& }5 Q+ ?: {; W2 y% u

0 F* W/ \) D, U6 a% q
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
  l2 w4 u4 u3 V  @7 L/ y) Psetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
6 C  V7 m; e) I8 |; W
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的) y/ w2 \$ F* o, v* t1 m/ a
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
! y# ]5 C; h' [- |9 p/ y问题解决了,原来内核文件要用旧的

4 [: x5 [% A7 [" ?5 n不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27& O# f7 O) \& x
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
1 t' o# T% s* M. r2 _) m& ?0 s' m“TI C64x+ DSP CACH ...

  M  ^1 q/ t) Z: j/ c7 D我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
$ \- `1 l2 Y/ M: y2 M1 m4 gDDR存储使用的是缓存~~~

9 f$ L$ o. R. ]3 j2 t哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 18:09 , Processed in 0.037627 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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