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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
创龙工程师:8 N, n2 r" Y( \$ j
     你好,我是保定炜达电力的
! c" ?" w7 h2 }     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
0 d+ `# _  Q/ o( v5 k" p% |* q9 F  W/ M* C- M, w
void UPPPinMuxSetup(void)
# _, h( I1 V* V) c  E{
( U2 Q( ~8 K& }' z: |$ T unsigned int savePinmux13 = 0;
# z* d0 t" [7 O1 Z- Y+ g, k! ? unsigned int savePinmux14 = 0;3 t! W6 r4 V) E. m5 S* p# \6 F
unsigned int savePinmux15 = 0;
( k; h' T1 U4 Z( v unsigned int savePinmux16 = 0;9 K# Y4 H4 l8 J4 E! t1 y
unsigned int savePinmux17 = 0;
  s8 C) l! `. A, C9 k( p% j unsigned int savePinmux18 = 0;9 ^, }  a! n% l' j! ]/ i
/* all pins (channel A, channel B, DATA, and XDATA)*/
" p$ P# c) i( L1 D* v1 Q5 S. F" c& Z5 Q savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F/ f2 h/ v# S7 r& P, [
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);% |6 U1 u# I  r0 O8 u
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
8 u" G0 ?  F* V, F" U7 U/ T savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
* r2 f- C+ p3 h/ ^; B0 k. Q //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);: t1 B! D& |; N6 S
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);9 l3 c) @0 T; c8 G" n) p/ f
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
' u) m3 F% ]. o2 ~5 k HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
: d9 A4 k# G1 Q6 c/ T HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);& M' v5 f  z+ n# V3 e1 e/ `$ C
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);( V$ F1 n! x1 w3 f7 y. t
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
! C/ p' U$ K% Y: b/ m' V3 g' p //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);, W1 @( x* W! `: s7 E, @
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);, [+ d4 O; A- `& D) r
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
! n8 ~4 ?% |# }1 @* \# }}
  `$ q$ b8 s, U6 O- {
) ?1 Y+ g  c7 q# C6 p! {     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 0 {! l  I2 _1 A2 b7 I  F2 M9 s# ~
. K& Q! O+ S0 U' u; M# I
3 ?/ w9 F9 p: I0 W0 k4 ~, p- e6 I
" f/ s7 n, @5 D* \6 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 编辑
* h0 K* q" C# M! Z' `7 H
3 z& {. n% k: l* L6 v7 K: e  D内核文件不用后来证明不用旧的~~~3 P- b# y% f+ V" T
实际上我就是在创龙的样板上进行了修改
  G: u; L% @: F% w1 O9 F+ u主要改动 1 移植到SYSBIOS中运行& b4 a( h3 L/ C% a5 z$ b/ C; X7 |2 Z0 c
               2 因需要时刻储存,所以FPGA发送一次下降沿脉冲,DSP核心中断收到后,执行一次完整的UPP重载,只是重载时,需要把DDR存储接收地址更新,然后开始接收UPP数据
2 B: k2 E# _' f0 J5 ]! Y# z; X               3 重载之前,需要 CacheWBInvAll();                        //更新cache
8 K0 b  Z+ c  j8 i  e( |
4 ^% E9 ^6 w& t2 f% B2 G+ Q& ?希望能帮助你  
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
10#
发表于 2015-8-9 16:54:19 | 只看该作者
tulipyyf 发表于 2015-8-7 16:38
7 D5 Q  a# Y4 nDDR存储使用的是缓存~~~
' h$ b/ K/ }; W, Y# X& T) h& V, }
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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
& K) H, I, u- S" j" D. S; w) U当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
6 a% P( Z, F9 [3 r6 |2 K2 ~“TI C64x+ DSP CACH ...

% B4 E3 c+ b. r) b! [我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:145 U- M0 s, g* o" A/ i( }/ i" F
问题解决了,原来内核文件要用旧的

0 m1 w, x- B0 b; Q$ O不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
3 V9 V& e+ W3 }+ K/ Q6 p0 `' U- G; y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
) m# {+ x; ?. H: }9 Qsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
! K8 I1 X& e. L9 \5 U% t5 t7 I! }* h
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-16 09:08 , Processed in 0.040818 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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