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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:2 L# U3 @' o  U, ^
     你好,我是保定炜达电力的, l' l' X7 b6 {5 q" D) A+ ~
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
4 \+ \. I8 D. L3 m# }  P
, l7 g. X) E; l1 z- P5 cvoid UPPPinMuxSetup(void)
& ~, F3 s' L5 E{
0 L0 L3 u9 u) f. z; e7 g! S unsigned int savePinmux13 = 0;
9 \( F( B$ X3 v) a unsigned int savePinmux14 = 0;% @+ j% q( G3 B/ e& d; q: v
unsigned int savePinmux15 = 0;+ a6 P; V! G6 l& K% V9 i
unsigned int savePinmux16 = 0;
+ W6 G+ P% b+ ~% z) e unsigned int savePinmux17 = 0;
: f& A, ^% @$ R; e3 h unsigned int savePinmux18 = 0;$ }( s% e$ x+ g4 C* u' I- ]1 |
/* all pins (channel A, channel B, DATA, and XDATA)*/2 I/ q" H0 {9 }. b- E  e  C2 F' D1 ]
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F: W# f- K& ?- f: d
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
% c8 P" I$ V# z savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
9 S$ _; y5 z$ }, z savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
& E3 w9 G, i# |$ s //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);0 W+ s( V: d0 @4 I; p
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);* i% [3 I* a9 q7 u! N3 Q* ?5 q
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
2 U- b: _$ p0 G9 b9 \1 H0 w! m HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
" ~+ L1 @: Q& a) K# ^' e& x HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
2 B: Z# H0 [8 C) v HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
/ L' p1 j0 q! j4 f/ s3 _' W HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);% V# f! {" V, n" j% W
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
# Q- S1 M0 b# d* r$ z //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
% L  ~# _+ Y& B* }& p //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
$ z: _( X7 R* a0 U! M}9 ^4 r, @' t" Y5 |1 b( Y

7 N" \% k5 o% @$ ?3 w9 J' O     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 - u+ G' P2 T( B0 `

4 y$ L3 q4 \( a  K8 v
0 Z5 b3 t4 Z+ K0 c* Y6 W' F" g* Z, b7 l. r
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:( y* G* s8 R* F8 f% r# _4 N
1)CCS连接ARM核心
. L% @; |% \5 @2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心2 ?6 t6 K( \. G, L+ t
3)连接DSP核,然后调试仿真  ) b8 s( a: B! K( C% X& l* ?  O% Z

8 V. P9 p* ~0 Z8 m初步联合调试,按照贵司方法如下:+ V, M7 [; k$ u
1)启动OMAPL138  linux系统$ R4 d' v, {! Q6 P4 O6 y
2)进入系统后  m9 {  b) N1 u1 y/ G1 A. q; k2 r! ^! _
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1" w; U0 C2 i  D, E
3)然后再次连接CCS ,连接DSP核心
# P; [  d6 _1 p* F再次在线仿真,就发现UPP不工作了,其他功能仿真正常。, m+ L: `% f- |% g( W- q/ i" e
+ B- l1 ?2 L% h
- o# U9 Y( R, [" R9 l- `. @3 R5 k$ Y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
- J1 S# h4 p. q) \setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
, \; N; H+ o0 U  D- a$ }9 ?8 T
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
+ E6 y: X0 j# N. R/ H5 \8 g3 Z( R( O
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14  @0 B6 ?6 T, i
问题解决了,原来内核文件要用旧的

% E+ {- |1 R3 k2 N- B不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:271 o* H4 I, d6 r* @& D. c  q+ c" ^& _
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
* `$ J6 n" t! ~0 G% |% ~# x7 [! o8 l“TI C64x+ DSP CACH ...

# Z8 X, c" v8 N, S2 K0 q: k我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
! g$ R; ?% h' S& _8 F. xDDR存储使用的是缓存~~~

' t* F% {* C* N/ K哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-16 09:55 , Processed in 0.044787 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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