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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
1 Z% O/ w5 v. y     你好,我是保定炜达电力的- r" u' x, g- f, Y
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改), p' `* A/ D- R8 |% h7 k
+ o; E& X6 o  ?
void UPPPinMuxSetup(void)% w1 c& w. W( R$ [* @8 K$ o
{. x: H' q% K9 K( ?
unsigned int savePinmux13 = 0;
7 s! P9 E8 l! s3 i; }& z2 u+ K unsigned int savePinmux14 = 0;6 E. a# H1 v, h/ `
unsigned int savePinmux15 = 0;
! l- H( O. R8 ?0 {( `# p- H unsigned int savePinmux16 = 0;' f* ~0 @' P: D0 {) @& W, P5 ^4 [( v
unsigned int savePinmux17 = 0;5 t$ {7 _0 f* d
unsigned int savePinmux18 = 0;- [, ^* R* B1 O
/* all pins (channel A, channel B, DATA, and XDATA)*/
# H1 b% Y, p5 q4 Y# @ savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F! l2 }$ i9 T3 t8 a" @* V
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
! S+ \/ V" I1 b0 X* t0 ]+ \! | savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);+ j* q$ J% g0 o4 |7 B, j
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);2 x1 q% o9 i# {  _/ y9 p" a  x
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);. E# G1 x% L4 J- h$ i% o
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
+ _9 O' G# ^3 N9 h' ~* [/ N //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);1 y7 t/ k0 [7 Z0 y& T7 r/ n
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
2 @. S: W. X# @4 |7 d0 H HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
2 t6 `9 L6 }& l* H" A  t3 Q) O, b. i HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);  j. R0 F# T- O: R
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
: o6 C4 p5 ?* C( ^! r* ] //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);. [: R, L% z. `2 |$ c
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
6 s! m" U7 \& x  Y //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);+ r6 j7 I9 a) b' ]$ d7 Y% X2 q6 H
}
+ H2 a' ]8 K& E+ L+ u; [% {( r7 |) E, G: l
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 ) o5 ~, N" u3 W4 W; P

" m' R- y' t- U6 k1 @4 @) g7 W% ]0 O' Z) C5 _- M& i) @

  ?) f( ]& x# }) g- \, v$ F
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
" x! G2 T* p! v1)CCS连接ARM核心
4 M2 R5 F" u1 t5 P# Q+ f) \5 a2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
9 w$ T) P6 t0 `& \* h" M3)连接DSP核,然后调试仿真  
6 y: j  d$ \. Q" h9 `+ |3 R7 c$ B1 Y, Q$ N8 w$ k
初步联合调试,按照贵司方法如下:
7 c4 C* O) ^: v# [. M! b/ S1)启动OMAPL138  linux系统
$ {1 w1 d3 d8 r  ~. i8 F3 n  j& U, m  r+ I2)进入系统后7 Q& R0 A) {5 k2 r# u# O& v
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
, j) m/ Q, q  C: r3 w3)然后再次连接CCS ,连接DSP核心; B7 L3 `; M1 t' K
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。% [  K+ I0 q3 D1 C! S& y

! Q/ \6 Q# N' }# {; L4 x# L! ^& I/ M: Q, I( I% r% n; [  a
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突' [2 A# `, t. R: `0 E( l
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000! G- w) C- V5 s3 V
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的4 K- k0 J% _' g" _6 E
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
3 A) J1 R0 @' U1 ]" \8 M5 K问题解决了,原来内核文件要用旧的

& l; ]% ~& w- y6 ~5 w& a& D5 y; T不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
! W4 `- _* j; }; o1 R当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
9 W% e: c& M* N“TI C64x+ DSP CACH ...
! f+ C) Q& O) k! I
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:387 u6 i2 w# [! L
DDR存储使用的是缓存~~~

" i* A: b5 ~# M7 g3 w9 h4 I哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-30 23:35 , Processed in 0.045368 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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