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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
/ Y! s8 R  k; c: c1 T- Q8 e' s     你好,我是保定炜达电力的4 W: T  P9 G7 K' \
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改); U9 M. A, G6 K" G# ^) n+ v

. X, J& O& Q' T7 k$ G  `) m; Dvoid UPPPinMuxSetup(void)$ L4 m4 _* T0 D( ?( ~$ O; |# V7 W
{, Y# B/ @' ]* C* i& ^
unsigned int savePinmux13 = 0;  h+ s) i+ q) M
unsigned int savePinmux14 = 0;* J& Z' b3 @3 E7 p% G- N+ o
unsigned int savePinmux15 = 0;
8 n' T1 h5 u2 X  B- W+ Q unsigned int savePinmux16 = 0;
5 b2 I; g& e9 w unsigned int savePinmux17 = 0;
$ o! M' |1 j9 k3 o$ }( H) Q& j& X unsigned int savePinmux18 = 0;
+ D4 c0 x$ i: V4 [. u) U0 X /* all pins (channel A, channel B, DATA, and XDATA)*/+ l3 q- V" B, w; D6 n! x
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
+ Y5 A+ J7 l2 g; @2 l savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);6 k4 ]( f/ _9 z  e4 `% M
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
5 t" s$ a$ \" G3 i7 M. k savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
2 s& F' P4 `/ d5 g% V //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);5 W' e7 Z# S2 G4 A
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);4 n* v& U! ]8 [
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);, b) k' \9 r* [1 M1 R$ ~& M7 _
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);/ s0 |. W  r' w" g& k
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
' t* `( F/ s! e% Y; l5 L/ X) A% L HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
8 X/ g: x3 R) {- ]1 X* r$ A. @; ` HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);3 }9 H9 o1 v& J9 W2 P1 u
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);1 G9 {- k! y; |* B! Y$ ]3 H
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
# D2 y! `6 a; W: ]2 v- k- v //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);1 Q* I& P( R; i/ J1 R0 D: f  V
}% I  Z! K% R( l
7 ^4 B6 j( |: U4 X5 y! y" D
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
2 ]( L8 r1 Z. P$ {+ _' c
5 `/ N3 i- i: X

1 h9 B- q/ ^$ L7 n6 G0 K! j7 g7 z' G6 _$ U( U
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:* \  D$ Y% J6 h
1)CCS连接ARM核心5 H& Z6 t1 X1 k+ P
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
  L; \) e/ Z& f4 A3)连接DSP核,然后调试仿真  
& S7 @+ D& \/ L% g2 j1 i
: B  E  G5 v. z初步联合调试,按照贵司方法如下:  v# V, r5 s& v! M- j+ ^6 ?5 t7 B
1)启动OMAPL138  linux系统9 a6 r5 f" @3 K2 N& h: N$ G
2)进入系统后
$ C! D5 H) x) R$ m& b1 pinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
* W# m* d6 o1 ~. ^5 O) M2 ^3)然后再次连接CCS ,连接DSP核心
* M) `: A4 G0 p+ W再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
" R# C# [* }, G* _( u+ s6 Q  t+ Z$ `7 r$ f, \' J- C" ^8 ~; ]& R
3 S$ E) [' B6 r) }+ h
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
! X8 B# {1 M  a4 z' |setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
0 H9 n& y& e$ J6 r7 Y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的6 M/ O8 b5 G) }1 O
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14& o4 `. @6 |  v, \8 X/ o
问题解决了,原来内核文件要用旧的

, j4 M3 E+ I( k不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27- C8 O' b$ B" n# Y/ w9 ?
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~$ {1 j: }& k$ r: b) i6 a6 s" E
“TI C64x+ DSP CACH ...

% n( T: E/ ?# _/ y$ @我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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 S$ V8 H% s8 Q3 _, FDDR存储使用的是缓存~~~
( w7 N, I) |4 ?4 _
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-14 20:50 , Processed in 0.043589 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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