双核工作下,UPP不工作 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:" t2 ?% i0 y' ]; Z% S
     你好,我是保定炜达电力的/ ~$ N9 E3 U1 J
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)0 u. g& _0 {0 H1 }8 f1 O: @

1 X! L! I% a4 g9 R# G2 Qvoid UPPPinMuxSetup(void)
5 `4 {' L5 Y3 ?9 I{: I6 F0 `. r/ L. t% ~" i/ Y$ T6 G( X! a
unsigned int savePinmux13 = 0;  J5 p  b' z9 W# z8 t8 W
unsigned int savePinmux14 = 0;
4 y, E* p  P& R4 `9 h unsigned int savePinmux15 = 0;
2 B3 s: L" a( l+ s, q% t unsigned int savePinmux16 = 0;
( t% A) F- U& z5 M+ x unsigned int savePinmux17 = 0;
" E5 P+ A4 `- h! s' M) p3 n unsigned int savePinmux18 = 0;
% _/ P9 r) z5 I0 o  R+ t8 h /* all pins (channel A, channel B, DATA, and XDATA)*/5 g! V3 t4 X& r+ R; z* R5 N6 n6 k. t
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F. x  q$ U' n8 A( M) z! z
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);5 }/ y5 a; z( t& w( z* W) e
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);; ]1 ?3 y6 [: ]" w* J* i# ~
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
) w/ A: q/ W: }0 y" g$ a# ~ //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);! a; Y+ o6 T' B8 b0 d' j
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
8 B/ S2 t1 ^1 R, Z" H! \* _* O //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
" D; Y$ @; L7 z# F. V HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);1 O9 E! h6 d; M7 p
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);; U8 U" Y0 K, Y  [" }) M
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
2 U* ]; h7 x- m. ?; W, n6 h HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);4 O% `* |  ~% t1 J6 ]; }8 g
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
9 Y9 N9 D. X/ p, H! I //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);' y8 e# A5 a( I$ ?3 K' a
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);7 Y1 w8 n! I5 b  N* C, M+ y( I
}% }4 \3 F" D' K5 m1 f

+ f; D& V; ^1 c0 H9 l+ d     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
+ E" v6 C  C; a# B7 ~* _9 N( W9 i
3 z$ b% L; ]- m5 B
' _, J, p( c! J( }

/ Y' A" E/ R+ M
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:( m" e2 {6 d8 P
1)CCS连接ARM核心# T# J2 O2 i2 ~$ e% N
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心6 B" `, E' V% C/ M, i; V
3)连接DSP核,然后调试仿真  ( i) X. W! z9 H5 B; h3 \

) C8 h) Q8 ^3 W* ^# u初步联合调试,按照贵司方法如下:/ I& W* S: m/ \8 O, J& X
1)启动OMAPL138  linux系统3 V6 T/ Z4 L6 u3 U8 D4 L. W
2)进入系统后
; O, u  i+ `* z( n9 R  ginsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
) |, \7 l# _. A" V% u: e9 W( \$ @3)然后再次连接CCS ,连接DSP核心
. k) i  T$ G) I" A再次在线仿真,就发现UPP不工作了,其他功能仿真正常。4 {4 A9 Z8 N* @
2 ^+ I9 R! j( P; `* M6 p! {. z
$ P, {$ u) \1 s% [/ ^3 d$ l
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突& X9 L2 b% k. i
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000% g) Y2 G+ D! R6 g" N9 ?
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
  N! T7 Z/ z% H  `+ k* K
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
, M0 g. e! [0 ~  ~% i9 M" @问题解决了,原来内核文件要用旧的

, `' |: u* P" m不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27$ c4 |5 t, U- I
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~9 _+ t2 e9 A0 d5 K, ^2 {
“TI C64x+ DSP CACH ...

3 n8 l* p. Z- u' l0 _. i  w8 J! k我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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- }- V( q6 M! _* }7 `
DDR存储使用的是缓存~~~

6 H$ U& a2 U  |( @, m哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

点击跳转“创龙科技服务通”

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

GMT+8, 2026-3-17 05:04 , Processed in 0.042665 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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