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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
) }5 e6 f- l- W& A* i     你好,我是保定炜达电力的
' T' J$ I) S5 G* N, ?: G     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
- ]! U7 M9 O; d" m* ^; `
  Y, l' W9 s7 o' _# M! h7 Yvoid UPPPinMuxSetup(void)5 s: l3 x# P) F6 D# _8 `
{0 ~( o4 a  p  F( ^, ]
unsigned int savePinmux13 = 0;
9 ?# Z& U; T5 {6 Q* i/ c( S unsigned int savePinmux14 = 0;& ?5 o, o8 r" d6 `! f1 O
unsigned int savePinmux15 = 0;' V; w# y0 l' g
unsigned int savePinmux16 = 0;
8 r2 ^0 T* q% ^: E6 l4 e) R" E+ M unsigned int savePinmux17 = 0;
) Q1 w, d& p9 b( p! o6 Q$ P unsigned int savePinmux18 = 0;
3 P( r: b' U4 |% d /* all pins (channel A, channel B, DATA, and XDATA)*/
, K+ I# {8 ?3 \! W- |! j savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
; _  z$ A7 ~& ~, s9 M8 Y, D savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);  t& m) p  X. H  [
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
4 N, t8 I! ~- I. |9 h savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);4 p: p+ A: H+ o
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);9 {& Y/ m) Y2 P$ s  l& i) F7 D! ?8 c
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);' }3 ~4 y8 w# \6 I0 C
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);! H# d* G9 ^! V/ k. L
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);6 p5 `/ |* ^2 Y, h- E; r
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);4 T7 V# L, L. ^: F" V" ?
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);* ~% ]  f) M2 \; i6 ~% w1 v0 P
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
- r  q! v' ?% G/ S2 S3 W$ ^ //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);, f& g' z0 B$ k0 h
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);, |6 Q, g2 o* ~# z" s6 U" Y
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
* ?2 V+ j. A7 F}# g4 }1 c% ]: m6 d8 h; t& ?
0 V1 C/ N/ M( I& D
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 : I/ d+ t" L7 l; f& y
! L: ?+ E  f5 m; L' G+ r

0 V8 z6 z5 P' A- l" ]
" u4 T% R1 h; _0 a9 f$ J9 j8 Y
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
; \7 a* p# x6 l' ]1)CCS连接ARM核心
# K  q: [% a1 P5 n( L, L% m2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
+ N4 h+ _9 l5 z* D1 A3)连接DSP核,然后调试仿真  / p% M4 M8 v# }. Z" ~; }
( t3 }) d) _( x# K( a
初步联合调试,按照贵司方法如下:4 n2 a2 s( J6 |7 d6 U6 ~% ^
1)启动OMAPL138  linux系统4 ^6 Q; o/ @& P
2)进入系统后
9 X* \) r2 l- k# {/ r) Ginsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1) O) I/ f6 k& a. w1 \) ~' z
3)然后再次连接CCS ,连接DSP核心! C) Z% y: \% }
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。* b3 U+ X7 o6 t. J; H4 |, A5 u
- @8 n. n* O( r) e% a' R1 N! F* `
+ F6 j7 W6 b  G- w& P' |. t  r& v
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
, F; ~! [# b6 D* f( nsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000002 V: S2 [$ x  T% q& o5 N
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
0 N- s! y- Y& T/ z6 R
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
4 n) d9 P0 I6 X/ C& h问题解决了,原来内核文件要用旧的

. D: K# ?0 Q8 d0 z. @, l不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:273 _" Y8 `( E4 h2 H( y" r
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
+ ?5 b+ C5 ]: U6 i( \6 L- [0 i“TI C64x+ DSP CACH ...
+ |  ~! w" }/ t* u  n- H
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:389 t! R' x7 S: }) B) y9 y2 I/ R/ v
DDR存储使用的是缓存~~~
% ?+ D+ l2 j. `6 B9 |7 S+ ~$ h
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 19:50 , Processed in 0.042528 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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