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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
创龙工程师:9 B' @* b% H+ V" u1 _
     你好,我是保定炜达电力的1 T5 j' e2 |$ ~# L
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
3 C- p- F! u( L; z
' c3 e0 d2 t0 X9 Qvoid UPPPinMuxSetup(void)+ C  i/ `1 F3 \5 _- v: }
{- \: z; b- x/ I% J- _
unsigned int savePinmux13 = 0;
! |8 \0 {# p( S unsigned int savePinmux14 = 0;
$ I: Q6 g7 O- k5 m) s9 M) R8 h3 R  Q8 l unsigned int savePinmux15 = 0;
. ~! ]# j8 g$ o unsigned int savePinmux16 = 0;
9 h+ P" j4 ~9 T0 }$ D# w1 i; h unsigned int savePinmux17 = 0;
& T0 h7 l% B' C6 G' w$ c unsigned int savePinmux18 = 0;, N% x6 [$ s* A" i
/* all pins (channel A, channel B, DATA, and XDATA)*/
0 ^/ K5 `" `5 w savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F2 C! C, Y6 i: C  h) Y
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
! j8 u3 F4 z6 b+ c; N savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
* i, B: X; C. g5 T4 V+ { savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
/ y/ ~- n0 O  X6 n2 g //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);2 ^8 _: X1 m; d- v- S' s
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
4 `4 q3 Y& h) T. s' n+ P' n //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
+ U& ~, `2 g6 R6 i2 e0 A HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
$ \0 R& O4 }" q& K; h$ ` HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
1 ^/ D/ c5 k  @3 L7 N% R HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
# s4 A( G# y- w' j HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);1 H# s6 g! V! P2 i
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
$ a* S* }* p$ T) T- c1 U //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
# v0 V) G, W; j$ B //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);2 D; K! q% i4 E+ a0 I- b
}
$ }, o1 W7 `7 K: w2 i4 x9 N* I; ~& @. @! T
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 0 e: V. N, C$ S! z! ]8 N
' c8 |8 w3 G; d* v( h
) ?5 |! B8 y. P$ _6 }8 @, ~2 A. G/ R
# k% r3 B% x% ~( @
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
11#
 楼主| 发表于 2015-8-11 10:13:52 | 只看该作者
本帖最后由 tulipyyf 于 2015-8-11 10:15 编辑
+ v; K4 A8 w6 \3 Z' I4 j1 T
% j$ X. G  j; V7 E2 x& K) p. s内核文件不用后来证明不用旧的~~~
) J/ {6 [5 t9 k实际上我就是在创龙的样板上进行了修改" `6 U) ^" C6 S; x% X& V. v( W5 ]
主要改动 1 移植到SYSBIOS中运行# ~$ |3 {2 @, X, P2 _
               2 因需要时刻储存,所以FPGA发送一次下降沿脉冲,DSP核心中断收到后,执行一次完整的UPP重载,只是重载时,需要把DDR存储接收地址更新,然后开始接收UPP数据: P3 {) P9 I, x) d$ r2 L! H
               3 重载之前,需要 CacheWBInvAll();                        //更新cache
- I4 ]! @1 j3 F- i* u: K* z4 h6 _9 ~
5 ^! |! @. g" u希望能帮助你  
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
10#
发表于 2015-8-9 16:54:19 | 只看该作者
tulipyyf 发表于 2015-8-7 16:38
  i& T4 d3 i& c8 L4 IDDR存储使用的是缓存~~~
3 A# }1 G# I6 x$ n
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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
8 J. E+ u# }7 A6 v8 Y/ D当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~' ?  @" H( J4 e8 Q  C8 W4 M+ V
“TI C64x+ DSP CACH ...

4 O& i, @& ^/ c$ {* a- q我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~! f4 C; l) K# H$ I; N% {) k5 |5 x1 C
“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14: v9 f& l' \" ?- B' m# b
问题解决了,原来内核文件要用旧的
  k( W/ |( u: @7 y7 ~% i1 l( ?
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
) n3 s/ f' e; X* c/ @; S/ j
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
5 l- K; W6 S+ m8 M6 C% c' jsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
& \% x  S$ q( v1 C+ F
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-3 04:03 , Processed in 0.045740 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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