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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
3 T; ~1 b* j2 D     你好,我是保定炜达电力的% l. ]6 \- Z. b+ o
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)# C& Z( y7 j! c/ R6 V
( r+ f3 U- t7 Q8 y0 J
void UPPPinMuxSetup(void)
8 {6 p+ {, |9 p# u0 ~" i& i; ?9 p{
4 c6 |5 @" V( e- w6 M6 y; V6 i unsigned int savePinmux13 = 0;$ f5 ?* v6 r& N) s" ^( z5 j. s
unsigned int savePinmux14 = 0;3 U; W6 ?  |$ M6 @2 Q
unsigned int savePinmux15 = 0;7 Z6 d1 c* a% D2 G- j3 [
unsigned int savePinmux16 = 0;
% b$ j4 Y/ E' G: n" L: n* I. s# m+ y5 z unsigned int savePinmux17 = 0;# V/ A1 E: x  `* c2 D
unsigned int savePinmux18 = 0;
2 l" J7 }# \/ C& X0 l /* all pins (channel A, channel B, DATA, and XDATA)*/1 }- L5 c1 V' C7 k
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
. L! s4 C1 p9 M4 |4 k! l; E savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
' Q/ e! K6 _! H8 Q9 E/ x* z savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 y/ |0 ]4 D! N" ^: B% P4 s
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);# h2 K# x  E3 }0 ]! B: J
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);$ i' `7 A3 ^7 o, R* x+ A( G
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
5 E$ |" n3 v7 N8 H$ B0 P. Q( A) Y //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);" W! k* G$ i  f! A6 |
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
( S7 h6 |7 {# K. ]5 { HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);' B2 q. y- A: h/ o2 @2 `
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);8 f6 L  U+ ]6 Y. `8 I3 O7 A' e2 }7 {8 r
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
. ?3 u9 J6 p) K7 P6 Q% B3 W1 P% ? //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
& f$ O% ^0 V  ^& t0 l //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);) f- o$ f' p% q2 T
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);5 e: c' j, e! y& n2 B1 O* |+ \
}" P6 @& [0 @( I3 t( B: \# c2 F
% }6 C( W9 K8 s- m+ |9 |1 Y
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 % P# G8 ?7 m' D: F. n) U

1 u+ F) ]: Z5 ~; v# G* N9 |- h2 E+ h- d4 u" J: n

, t4 q3 r/ q, D( D7 l- O5 P1 A% |
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
/ W) j8 u- N3 T5 r* {1)CCS连接ARM核心8 a: @- x7 r- U$ I2 w
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心- q. |' u6 f. n2 N8 @  F
3)连接DSP核,然后调试仿真  5 `; n$ X! }; `4 {5 s; K1 n
+ l% B+ W( j1 Q* L8 r& R, f
初步联合调试,按照贵司方法如下:0 r2 r! o9 Q' V# ?. S5 Q" L# z
1)启动OMAPL138  linux系统
2 O) h5 r* |( ?2)进入系统后
! b% Z9 g0 @# Sinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1; P, N! X- G* n! C3 b8 n0 [/ q
3)然后再次连接CCS ,连接DSP核心9 U. ~; g4 [5 {  M3 e! c
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。7 I2 Y2 I* M# w

5 t, |0 \  ~+ Z
* s9 `& i( {  J
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突2 h& }2 B* j; |! W/ G
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000/ p) [+ A" ~7 u3 y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
$ T' p4 c9 N: J) u( z
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14- _8 N5 i, d0 g  x. l) F$ A, h/ w. P9 V
问题解决了,原来内核文件要用旧的

  h( @, D0 ^, m4 Q* R不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27+ s. }, |, H  y6 X9 H6 j* K" x
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
# r8 y) u$ y* Q" `" l1 u“TI C64x+ DSP CACH ...

5 v' ]! G- i6 i% t6 [我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
0 r- r- j/ E( Q7 ?- ^# G8 wDDR存储使用的是缓存~~~
0 p8 e9 h% \" z' a+ @
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-16 09:05 , Processed in 0.040914 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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