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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
; @8 d6 t- y6 x" ]; b- }4 n6 I9 \; G     你好,我是保定炜达电力的# G# l! x2 y! _) `. N1 m: K! L
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)' j* w! n% o/ K" R
) W2 W4 P2 C( v0 ?5 \
void UPPPinMuxSetup(void); _5 E& S- L' r: o
{
7 b5 Y4 R; ~( k# N- k, T unsigned int savePinmux13 = 0;6 _; A# i' w/ S( _/ o, L/ y, F
unsigned int savePinmux14 = 0;
5 i' s7 S" v0 g: ^ unsigned int savePinmux15 = 0;  w2 ?; u7 Y$ R4 G2 m2 {* p7 B$ b( o9 z+ D. N
unsigned int savePinmux16 = 0;% d3 \( o  \, l- D8 `) @
unsigned int savePinmux17 = 0;! @0 f/ Q) G* e5 j2 {9 }, t1 ]3 y5 G
unsigned int savePinmux18 = 0;
2 Y4 P! r% }! p /* all pins (channel A, channel B, DATA, and XDATA)*/6 ]. s6 V  O: z7 z7 S  o. U
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
# Q9 O& n. V0 @/ @8 F& G savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);; M& P$ S+ y7 M- c
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 U1 @& v( v' q1 p1 v# x% `
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);! I# E: Y) z- g6 j  A  |7 I
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
( e1 A: f' l, I  V8 P% {0 k //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);2 x" S" `9 A3 V/ v
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
& }+ r4 ~3 k3 `7 o3 b( v HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
7 w( H' l& M5 ^6 B7 n2 m3 y1 `( Z HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);. c" p" k5 x+ W2 a! M
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
2 M9 T* \% N1 i% I$ x- N% { HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
9 m" ?" f  s* p4 P //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
+ E) u& C5 a, I  j //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
# s7 B. ^  b5 e //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);) }( X2 N9 S6 X) Q
}1 c2 z0 Q5 F- t$ [, P

, Z; B* a: w5 K     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
5 c! c+ t' ^. j0 l

7 w& ~% i, C  R) N  G5 k2 t; H; A# b  u( }/ P/ y

" u( `" P" v) F8 V$ l
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:5 _  x: w; H0 u% N; c) O  T: ^
1)CCS连接ARM核心
+ M( w, @- \$ C- M# r2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
& n" K/ h1 b, D3)连接DSP核,然后调试仿真  0 K, M$ T! B: }# }( v
; v# R* L9 E, h! A: R8 l
初步联合调试,按照贵司方法如下:* X1 J8 M6 h' Y, f5 r; s9 }
1)启动OMAPL138  linux系统
7 B2 s% y* B2 ~2)进入系统后
7 W+ |6 z1 [' ninsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
+ A3 y2 Z1 e% i3)然后再次连接CCS ,连接DSP核心
0 X: ?( Y% K) M, E: v0 w7 f再次在线仿真,就发现UPP不工作了,其他功能仿真正常。5 \! t1 A# w; Z% i

  }2 F1 n# ]# d. h' k) K5 E, x3 C8 e, m( R" _! T
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
; R% n% N8 ^7 D, }# s6 ysetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
$ H* k: }% l2 v! h# O5 @, E
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
1 A, _; o; H2 c
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
4 c  R" @) f# P! F问题解决了,原来内核文件要用旧的
4 g' Q, v+ U$ D
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
2 M7 I) F/ \' @, w# s当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~6 }( c+ a6 R/ C1 R" h% f) a# y
“TI C64x+ DSP CACH ...

/ K: i$ x3 v7 M, h# 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:385 p  C6 q& c9 M
DDR存储使用的是缓存~~~
2 V; w+ v5 v) a5 z. B- F
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 17:02 , Processed in 0.042953 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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