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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
创龙工程师:2 Z- l) ^' A* ]& v) K
     你好,我是保定炜达电力的
. p2 V3 ?' E& R; F: x     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
; j8 }" a, F" J: P2 J/ B; q# Y* a. g
void UPPPinMuxSetup(void)( Y* [# _+ y0 C7 ?) S- B
{
+ I3 Q9 _' u) U% S7 h unsigned int savePinmux13 = 0;
. }! P% u% p/ A  l1 a unsigned int savePinmux14 = 0;) E( I/ A2 X- b: h  D* |+ h  ?5 W
unsigned int savePinmux15 = 0;1 r+ T2 r4 V2 Y6 I
unsigned int savePinmux16 = 0;
' Q: U- ~# Z' y, V( K unsigned int savePinmux17 = 0;
5 H: |% ?8 U6 G; _ unsigned int savePinmux18 = 0;' p& I: C8 [. b. X& l" \
/* all pins (channel A, channel B, DATA, and XDATA)*/3 U6 {; ]* r' E( o
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F7 A- m- j- }8 E: K- e
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
( Y. V% ~, h: C- j( |' S savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
, u8 \5 p' T) W( ^" X2 k savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);5 \" t3 f5 S% _7 B3 L
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);  Q* v6 m+ W1 M- P9 T& H& p1 L- O- V
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);) Y' T  A% h4 ]5 c/ _
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
( Y! [" B2 T. ]; |4 Z, ~) e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);& _0 S6 M3 G6 R) p2 A
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
6 ~8 a. y3 M  b1 w+ e: r HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);+ p5 x! X: \6 F! ], I
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
4 w, N6 |8 W# C; G# m- E+ {% w //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);4 R! b! n+ w4 ?1 }+ v& U9 ~4 I9 ^
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
# j$ e% A' ?. s& _ //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);& m/ [! F9 S0 x; d2 a
}# G. |6 t( i5 _4 A, n$ q
( v7 E$ Q, F. X  v3 Y' {
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
+ ?- _: |$ t- }' N4 A; J5 s" V  Z5 a
5 U3 V4 c  b: _, o- Y7 b+ w
7 @3 f; ~! N3 x3 L* b

* s9 D* y$ `, \# d6 I. V0 P
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
11#
 楼主| 发表于 2015-8-11 10:13:52 | 只看该作者
本帖最后由 tulipyyf 于 2015-8-11 10:15 编辑
  t; j: ~0 c4 V* V5 a  k7 \, t0 Z  A3 w
内核文件不用后来证明不用旧的~~~1 i; |. x. o7 c$ y
实际上我就是在创龙的样板上进行了修改& R# ?" A- a0 v8 s
主要改动 1 移植到SYSBIOS中运行
  {+ o6 Z$ M" d! Q               2 因需要时刻储存,所以FPGA发送一次下降沿脉冲,DSP核心中断收到后,执行一次完整的UPP重载,只是重载时,需要把DDR存储接收地址更新,然后开始接收UPP数据8 k: u9 \* d0 g4 ?
               3 重载之前,需要 CacheWBInvAll();                        //更新cache
; L8 Y; ]3 {4 k2 U
% u% J1 C7 e" x: B9 o  w希望能帮助你  
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
10#
发表于 2015-8-9 16:54:19 | 只看该作者
tulipyyf 发表于 2015-8-7 16:38
/ h. B! k8 t4 o: @0 kDDR存储使用的是缓存~~~

( c; U( e2 q+ Y3 i哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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
  g8 g/ P3 B8 G% z0 c& d当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~8 T- r1 ^. e, \4 c" `
“TI C64x+ DSP CACH ...
) U7 }7 S8 C. ]6 `# s
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:142 J8 F  t7 ^7 Q- a+ G! a; O5 V3 k
问题解决了,原来内核文件要用旧的

* e/ m+ Y8 j( n% I- i" C不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
# k; {3 s! ~  B/ Q
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突- Y; A: u7 X5 Q- Y7 [! [0 N
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000" b6 q/ X  I3 H0 r5 K# Q
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 07:13 , Processed in 0.042030 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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