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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:. t' g  p8 _  q3 U4 ?
     你好,我是保定炜达电力的) J! B7 ~8 G: i# L
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
1 b/ ?: ?  }( I, P- D& {, ]# W  ?7 L1 C' I# Y3 D4 E
void UPPPinMuxSetup(void)
4 W( q3 G, ^$ N. e( a1 S% A3 C{  @1 o; J8 |# P, u% Q6 J3 K
unsigned int savePinmux13 = 0;6 d4 g2 C+ n; }- S3 l0 z
unsigned int savePinmux14 = 0;/ x' C9 L% ]9 J1 \
unsigned int savePinmux15 = 0;
  J0 E0 P3 V* y* G6 T unsigned int savePinmux16 = 0;6 R1 e% [$ W. G9 m% N
unsigned int savePinmux17 = 0;
. t8 s* P& K/ \, w unsigned int savePinmux18 = 0;
" O! c, p5 M8 m: y( n# C /* all pins (channel A, channel B, DATA, and XDATA)*/% N6 s0 m" N* q! u3 h) M0 [4 M
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F& v2 J; c6 t; I) u
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
1 H- [; X# A" A  Q; Z savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
/ T; m  B0 P4 h savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
4 C6 V7 u/ {& r0 M/ @' I //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
7 K/ e' z2 c4 g. B" s. R# y //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);# I+ h# S6 ]: D
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
4 A* t9 H0 ~' E# ?* ^. d HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
' `6 `3 o; z/ W/ b( w8 B9 U8 l HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
+ }$ i' z4 p* o6 I* n: r5 {; J HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
8 [$ D6 h5 q9 d! w) ]4 X; L HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
* R- _( W, V1 T  L //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);3 j5 W% z5 D" J; _* c6 |1 j
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);4 {. j+ n- l6 {2 w1 s
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);! V' z) S* ~- F7 C5 \
}7 V: Z* C% u9 W, Y9 y/ m
) F: q; A$ a' U$ T* [4 d  K  J
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 + h7 W: f  C: e% T, u! u

( z& s3 _/ d% \6 W7 r2 l
' R) P& h5 }% ^; o, [4 d! I9 P  \& ?6 o. l/ \: U8 z: w8 {9 I
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
; H* B$ b7 F" Z, a" `) T# t1)CCS连接ARM核心8 w/ B8 p" H( s' h* m
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心! Y6 q( e* _1 y1 l
3)连接DSP核,然后调试仿真  
; r* u2 s) Z) E" ^( c$ L4 q$ A. D* d7 G
初步联合调试,按照贵司方法如下:* x+ T  [* i- q
1)启动OMAPL138  linux系统6 v% S+ B4 u7 N# m% g6 [
2)进入系统后
- X' i0 k5 X  x% z# \; V1 Kinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1* G* I7 m2 ~. c6 o2 L! o
3)然后再次连接CCS ,连接DSP核心" M  v, S1 S2 ~5 P! A3 v
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
9 ?% O; f+ e" Q1 ^- t+ j3 J$ J3 Y
' H; d+ K! L* A& X% M5 U# K- v) U+ ~; \  x+ w/ Z# s
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突; _3 t. @% l- d+ y$ _- Z2 N
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000007 K/ |# y, ?. `* t# Q
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
# O% N8 S! W. ]6 Q1 J
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14' y* i7 F3 C) V* k2 J' m. E
问题解决了,原来内核文件要用旧的

& ]. k9 H6 J2 d$ p! U' }2 [不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:278 l: U+ f, m* G
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~( D( x) X6 I) L5 m+ w  a
“TI C64x+ DSP CACH ...
. K' x7 E! G' c3 ?5 z3 z
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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: y# C0 s: g% Y# `3 ~8 [
DDR存储使用的是缓存~~~

1 z: G; X* g4 ^# ^; I7 w哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-30 22:54 , Processed in 0.042428 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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