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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
创龙工程师:9 ]% o2 N* v9 O  `& {
     你好,我是保定炜达电力的
2 v( j+ h  a$ j6 _% x0 ~/ m     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)( i) F- f- D7 `. `. i! u) S+ B
, |# n9 |5 l; A3 X
void UPPPinMuxSetup(void)
) W* \. P' P/ v{2 f4 v& R: Q1 Q* a: g
unsigned int savePinmux13 = 0;
" t( t  @9 z  R- _ unsigned int savePinmux14 = 0;, I, }* G3 }; Z7 h" ?: K/ g
unsigned int savePinmux15 = 0;  Y; a  e$ N; v( B' I
unsigned int savePinmux16 = 0;  |( \0 e  c( ?: z3 e
unsigned int savePinmux17 = 0;
5 d/ t& s. h# T2 t3 w/ C unsigned int savePinmux18 = 0;& f* I" U4 `( Z8 a: i
/* all pins (channel A, channel B, DATA, and XDATA)*/, b/ c1 ?8 f$ w( x7 U
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
% G  v9 {6 B+ a0 G) A savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
  C% U$ h1 s2 ~8 q. c: j, X8 D1 R savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
+ s$ u# S8 `0 K+ t9 {: M# a savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);3 \5 o4 p+ @6 O8 C" X1 ~
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
+ w; u9 p4 W# l# b( g5 { //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);) u' W2 V4 ^$ Z' J8 x5 [
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);6 W9 }& Q! Q5 x$ p8 y
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);5 w& W/ w, X+ ~+ b4 _- S- J- j
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
. w- ?5 c; {$ T7 |1 b- P: P) \  M HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);9 w, @: X7 W) E3 f0 |8 n; @
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);/ [2 i5 m  x) Z& U- B6 g1 C
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);: J6 G% m; ?. C: Y, {* h+ {
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
$ n$ F1 \: n% v1 @4 X //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
1 _5 `6 A% J: l3 O}* k! B$ q" K4 `, K
) M% l9 [% l* e; D( z2 c/ v3 I
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 6 p. b5 B" L1 s- r& e9 U

4 M+ f* i' ]& L" l4 U
+ ^  W# o9 z# x1 C' S" D4 n: t  }6 q
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
11#
 楼主| 发表于 2015-8-11 10:13:52 | 只看该作者
本帖最后由 tulipyyf 于 2015-8-11 10:15 编辑
% Z' L$ O' L3 o/ V, Z6 i
$ [9 y, n0 e. J! _* C" m4 w/ H内核文件不用后来证明不用旧的~~~
6 N) C) G5 D' ^9 e实际上我就是在创龙的样板上进行了修改1 ^) b) t" q/ y* I  `" T: U
主要改动 1 移植到SYSBIOS中运行  u, i, [$ @$ w7 s6 a/ T4 e
               2 因需要时刻储存,所以FPGA发送一次下降沿脉冲,DSP核心中断收到后,执行一次完整的UPP重载,只是重载时,需要把DDR存储接收地址更新,然后开始接收UPP数据" ~; A# y" W6 }8 ]9 X
               3 重载之前,需要 CacheWBInvAll();                        //更新cache
9 F$ K# o" i/ S5 h- x( |' I' W2 W0 }$ l
希望能帮助你  
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
10#
发表于 2015-8-9 16:54:19 | 只看该作者
tulipyyf 发表于 2015-8-7 16:38: C+ m& |$ R2 _/ _
DDR存储使用的是缓存~~~
" f* W/ W! C: s* I6 d
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
9#
 楼主| 发表于 2015-8-7 16:38:55 | 只看该作者
DDR存储使用的是缓存~~~
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
8#
 楼主| 发表于 2015-8-7 16:38:33 | 只看该作者
我当时是upp定时从FPGA中读取数据,upp存储的数据直接放到DDR上,所以DDR上是存在一致性问题的~~
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27" b0 N/ q# g; q3 d
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~- B( Z, d# X& k' Y; R8 \5 ?. F
“TI C64x+ DSP CACH ...

% |, ~2 X4 Y3 ^我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
6 q+ b5 t9 s/ F问题解决了,原来内核文件要用旧的
* X0 g8 x- Y. s2 D+ [6 M( B
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
+ N' v% ~! B+ S3 I6 p& L( h4 G* j6 K
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
' s5 H# I4 X* l( i8 h: ksetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000- A; M9 S8 c2 D1 U( u3 Z# G7 f
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-30 22:32 , Processed in 0.043930 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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