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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
9 w' {6 ?, W; w9 }9 o3 p2 C" |3 D     你好,我是保定炜达电力的7 V9 F6 ~3 [9 i& v+ P" w
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
4 @: U! G# a7 ]+ _, _+ q" [+ v$ R; z( i7 A
void UPPPinMuxSetup(void)# k( X% Q2 s# g* f0 V# x
{
; g! N5 @/ e7 R$ | unsigned int savePinmux13 = 0;
  T1 e0 A( d# y unsigned int savePinmux14 = 0;
3 x3 J, e4 Y. G& t4 | unsigned int savePinmux15 = 0;: \1 ~* d- x- R3 R1 r$ P+ Y+ u8 y8 w
unsigned int savePinmux16 = 0;& [: {6 y8 n2 h+ k& \- N/ {
unsigned int savePinmux17 = 0;' o+ R! @6 d8 s0 ^! V+ u
unsigned int savePinmux18 = 0;% @* X! h2 c# |( i6 f8 ^; w" ^
/* all pins (channel A, channel B, DATA, and XDATA)*/7 D. }3 N8 ]/ T: k+ ~# T, q
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
- q/ n: c9 m, S, C' r$ x savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
) Q! g1 j8 ~8 j4 c savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
) Y; M8 Z/ _: j% y/ T8 g7 ?$ j. Z savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);# K- y8 [. ~3 V5 w. C& o/ h  ]  T
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);- J) h! m! B# A8 C. k
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);# r9 h4 U  b  {7 _$ u+ g( P
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
% |! q& g" J' X. t HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
, u0 _( s9 e& {+ a# U0 M HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
% D- I/ c* v4 \; E9 U HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
1 T/ _1 G, c; ?0 E& J/ L HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
+ {) }" Z4 ~1 V. O0 _; h //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
% Z/ m8 H6 \  t' l //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);& \4 _7 m" W" c7 c9 ]
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);+ Z# J; m2 T3 l+ S" c7 L* [
}
( V) X' ]' U0 u" N9 I2 {) g( z3 _1 o2 |7 e1 p- F
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 & r$ o/ Q) A0 v9 p

% D) |% ^, `% F  t; R4 R  [$ K2 _
; e+ o/ U7 m* R, c; P$ N! {
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
; m$ J; M5 [  y( E- m1)CCS连接ARM核心6 G: j) `' N, M9 W5 {3 n
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
! @3 z/ n& W% J; [* C) z3)连接DSP核,然后调试仿真  
) G1 H7 N4 ?0 {3 I! S' e9 B" i8 g. {. [
; z, S9 G, |6 \2 ~& C# {/ C初步联合调试,按照贵司方法如下:- A1 [" l. _/ i- @
1)启动OMAPL138  linux系统, C% x) O- _8 q7 A' L0 N7 J. h5 h# G
2)进入系统后6 Y5 q; A, R( D  b( m
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1" G# w+ w( G; W9 W! |5 h; m' H9 i
3)然后再次连接CCS ,连接DSP核心: H1 M& \" ^9 c! X
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
0 `. q& r, ~" R- D7 r) n/ x6 ?9 U% J4 h! N( \3 ^

( i' u8 m- `. s' h* i0 u+ r, f
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突& U" ?0 b. ]% f
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
7 \, |- S) A+ H9 Y& G
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
% Z1 \! {+ O8 e6 D7 z. A! J
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14! E; @& d4 n; G. B2 O6 B
问题解决了,原来内核文件要用旧的
# }9 V6 r; a% f
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
1 V3 H4 o! p8 R, o& Z3 b( W“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:275 {/ L7 f9 s% S$ T* S  F$ b; X8 {% ?3 l
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
- l: l2 r* M% z1 k. `4 c4 k( _8 E“TI C64x+ DSP CACH ...

& R' d, ]! u2 I我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:38
7 @& c0 h' j0 k" ADDR存储使用的是缓存~~~

- ?; R6 i3 }( I+ e" G哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 07:07 , Processed in 0.040252 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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