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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
$ A2 Q: F7 ?7 R; r* U' a     你好,我是保定炜达电力的
' u- u% b- I: U8 T6 x     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
3 ]8 k& T  O& a2 R* V( @. b
  @0 s: V/ k4 C7 _2 c. Cvoid UPPPinMuxSetup(void)
: n9 c2 `1 Y) t) F5 P{( c( x; l& S4 V$ T. R
unsigned int savePinmux13 = 0;# e+ o  h( }) U8 M0 @3 n
unsigned int savePinmux14 = 0;
, H* N6 s- b; t/ _ unsigned int savePinmux15 = 0;
: J* X2 k( J* ~* [9 o/ B unsigned int savePinmux16 = 0;
5 x5 h( Z. I2 h" A1 b, U3 K unsigned int savePinmux17 = 0;8 M2 |# `7 [0 e/ z5 j
unsigned int savePinmux18 = 0;+ Y8 [9 S* [" u$ F+ c5 e
/* all pins (channel A, channel B, DATA, and XDATA)*/1 c  X: m( m2 ~+ I; A+ D
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F& R' [, D0 }' t# l$ ]3 @2 S  z
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
4 [# ^" o- I! x5 L) g* \* G- v5 O savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
: U9 Y; ]* O3 @- Z& Z savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
( B" Z2 T" O5 c //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);4 b, W  ~; s* l# r1 g+ o& _& }
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);# l( p2 `3 {0 f& m
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
! I7 @, @, e+ U8 _) N HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
  |7 I. n, G5 D* J4 f( K0 e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
; @* ?0 k# X5 Q5 d+ s HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);# T/ _3 y* z0 B
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
% N1 {: d) b( Q% `+ q' b/ M //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);5 o' O! ]  z# z8 U! T" G0 V" r
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
4 C6 |& }, }  h7 U //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
. s* Q5 Z2 d6 m* P/ ]}
8 _4 b1 h7 q& U5 e% K
' S6 {8 {. p2 E4 ~     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
' a* u) s; w" |. _* a# C% T
/ }6 O( v# k, t& n  @6 A

, U$ x. o' p/ e4 \2 ^. w+ X5 t3 k7 b1 A* {/ `5 k5 W' o  `
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
" j( k( ^' g; d" o; `' \) p1)CCS连接ARM核心/ e! N8 T4 M+ [
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
7 c7 m- a) C" m" ?9 r" |9 E$ u3)连接DSP核,然后调试仿真  " z' P6 U; U4 Q1 l; @
, Q! b6 f% O* S3 v2 Z
初步联合调试,按照贵司方法如下:0 a7 f' o+ {- D; v7 c0 Q- C: I
1)启动OMAPL138  linux系统
2 i; [5 P# I  ]2)进入系统后
  C1 E+ ~! [3 Ginsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
( H5 s( c" d+ m, y4 P3)然后再次连接CCS ,连接DSP核心$ W3 l2 K: l) _" \
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。  I; H9 W* _% a) r

7 t8 l, F/ m3 o; M" ~4 m
* @( d. h! m4 c$ Q( X, w  Y0 o
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突0 X! S& F) W+ D) x. t) d% a
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
# ^* {$ c- T( Y" X/ V
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
/ i) {0 ^, f/ t4 M& x
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14' k* P7 l6 ^" e8 n5 S; O
问题解决了,原来内核文件要用旧的
$ {/ `8 C. L8 u& _* n' W% c$ O
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27, J& w- I! U; ^6 U, f: o
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~" c# O& |4 `* W9 g4 }; s  z- C
“TI C64x+ DSP CACH ...

' M' n/ d* `+ l6 n* a; f3 e我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
) k8 o, L) f8 X' K# WDDR存储使用的是缓存~~~

, H' T1 p2 ~, K+ f, S哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-16 10:52 , Processed in 0.050036 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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