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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
, j) i/ \' y0 Z. ~6 ?     你好,我是保定炜达电力的4 G) m: S8 U* O+ c/ @# O5 \2 u0 o
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)* @1 A, s2 c, u2 \$ C- v# \

8 l2 s3 b2 \9 Z2 E! rvoid UPPPinMuxSetup(void)/ z2 J* p- V2 ]2 m
{, e+ n9 b8 t7 E
unsigned int savePinmux13 = 0;9 C3 M3 z4 m& C/ L9 B2 N4 m1 k7 R
unsigned int savePinmux14 = 0;. ]+ {& c0 z: m* r0 _% {0 `
unsigned int savePinmux15 = 0;$ @  C! o, H. Z" Q
unsigned int savePinmux16 = 0;
+ Q) M1 N) h* S* z2 E unsigned int savePinmux17 = 0;  Q' ]' e. T2 b# i# e
unsigned int savePinmux18 = 0;8 Q- c2 `" L4 V# p0 d
/* all pins (channel A, channel B, DATA, and XDATA)*/3 s  @. p  p( Y" L. {( G2 z
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F& G. }& {1 Q; I6 r3 g3 x1 Y% j, |
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);( w" }* W% E. I- \+ w  m
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);8 n9 ]: N. M, x* v1 R- S: g* z
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);: y# {4 E% h$ u1 \3 n5 O; T7 B. @
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);6 k! m# u& x) t7 [" b
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);1 `0 Y* Z9 a/ m5 c: L* B
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
6 T, v& s: o# a HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);2 _; w7 z4 h, W: [3 o- ^7 m
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);$ q+ j1 I8 a4 a/ p
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);5 p; n* W5 y2 |/ b" n2 A' B
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);. x# t& @# t8 v- {: J
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
0 x: E; z4 v! l" K //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
6 i  S8 R8 K  p# ^4 k //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
( \; O+ k: c8 M}9 M' |( z+ R0 Q# w' m
$ \+ @7 B( K! Y: o0 K% C  L' N
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
1 i# o1 H0 [1 d  F4 O
" P$ N6 F+ _% F" n
- ]& ~! ~/ {5 d$ E% U

  i( R# ]/ U( F! ~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:3 Q, G- X& ^& U" q  s
1)CCS连接ARM核心) ~! S" b. D: g; H# L5 T! E
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心; x2 e1 S  h# T% u
3)连接DSP核,然后调试仿真  6 M7 B- W% e1 b" c/ |: e
: ^4 n5 p4 o4 |/ `; o3 t
初步联合调试,按照贵司方法如下:, s  g; V' H% l1 b0 l% C; z  I
1)启动OMAPL138  linux系统4 S- T! {$ a1 v% \& J; {' B
2)进入系统后3 d5 n9 G5 s; D6 t5 ?2 N
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
! K. i$ m" l1 I& |: w  D# A' D3)然后再次连接CCS ,连接DSP核心
" U8 J0 I8 c8 Q4 r  c再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
, S% g! }& j1 K, v2 e' Q$ q. i( q: {

$ w+ @2 c6 v: y  ?- ^) R4 d
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突0 B* P: d! x- H* X/ B: b6 r  ?9 l( {
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
. S" r$ z- t4 g; R+ Y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的1 A9 c- K1 p, V2 A' }! D
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14- ]7 J# J+ V8 D* C7 k7 g2 a
问题解决了,原来内核文件要用旧的

/ Y& d9 D0 {3 f6 l( k不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
) h% l" g& F2 D- F8 W( P9 \" {当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~9 A% G# k8 e1 \3 K
“TI C64x+ DSP CACH ...
0 V' t& a, n3 ?/ c+ G+ M7 A* X
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
% }: o+ }4 d( x2 [DDR存储使用的是缓存~~~

/ q5 |2 J- J7 c哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-3 04:03 , Processed in 0.043452 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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