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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
7 Z8 z3 }( M* z) D     你好,我是保定炜达电力的2 e' d' A8 \4 Y& g# Q% a
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
+ I3 a8 [0 i* {, w2 R8 s/ w* P) H# R) v4 E9 Q0 z0 p2 o
void UPPPinMuxSetup(void), v. l5 S) u# P8 d$ A
{
+ i4 l- C6 _2 V5 l9 B unsigned int savePinmux13 = 0;4 D7 t6 u  I3 s
unsigned int savePinmux14 = 0;% q+ I# r% u* j7 q4 W+ u
unsigned int savePinmux15 = 0;+ _+ z/ m# A3 z. u, e& x
unsigned int savePinmux16 = 0;
) ~: f  Q2 A: }$ d( v unsigned int savePinmux17 = 0;* ~% G4 M+ X- h  t" }% p! }
unsigned int savePinmux18 = 0;
1 G2 ?! \( @- M /* all pins (channel A, channel B, DATA, and XDATA)*/2 I' P) }+ T6 j1 g
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F# v7 V% Y. Z5 r& i9 Y; ]7 d
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
: c) O5 f  i+ r7 B' q7 ~5 e, B savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);/ [* L/ Y' i5 n5 T
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
; O8 ^8 P" g: L$ y* Z) w2 f8 N8 F) z //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);7 u$ u$ _3 u% N
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
: B0 L: |1 \' A# L //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);% s* N7 Q8 g' s8 G) H; c/ l( @
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
" h( ~3 N* p# Q$ ^$ e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
  D( @' x9 \: { HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
. e( c6 w% c3 N8 n HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);. W. Z; U' Z; d2 {
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);; y. w0 I7 P& `  z6 L0 o
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);# Z9 s' ^5 X$ n4 P3 l1 Z/ m; I- }! @/ u2 m
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
. `5 \) q, J$ P& }9 G) L}
" ?1 s# L* V- E- I, N4 }9 P9 o% C! q: {  g) k9 \3 W1 T/ o
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 $ C4 d2 H3 v# M
9 m3 [8 k: S! C! a( ~7 f3 [

" A  g) v( U5 X3 m) J. {1 C
. t& @  }8 r1 W' U
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:0 P/ a, l7 H7 f) t
1)CCS连接ARM核心
: x! d" s9 c6 D  E, V2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
" k. I" a' T3 a, a& n5 u3)连接DSP核,然后调试仿真  9 v/ ~) Y; T* n; u% Y

" t+ G) N9 i8 y初步联合调试,按照贵司方法如下:) O5 N5 A" a0 X$ ]' c4 V
1)启动OMAPL138  linux系统& K, Y4 g8 z' B9 }' g
2)进入系统后& M5 M! Y) T' o/ F" p
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1; ~% I3 y( ]1 i8 X- s' ~" i9 k
3)然后再次连接CCS ,连接DSP核心% _" N) x; \0 N3 E" w
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。  K, M7 w% g. N2 H
3 t$ U# h0 v# e$ y

( E8 @7 z. Y6 c+ k
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突% g* Z$ H- k' p( Y2 u
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
) j, |# v! A% k' p
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
1 F3 I& F& o2 C8 v
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:147 j' k* Y; s' A' n2 z
问题解决了,原来内核文件要用旧的
9 F" _9 ?5 {* \( n: `* s/ [
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
( i  O8 _! v# R当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
2 J) p& P- ^% h. ]5 U) E! z! a“TI C64x+ DSP CACH ...

! k# ?: i5 x+ j: q  _5 }我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
9 Y7 `0 a& e. x$ q1 K3 BDDR存储使用的是缓存~~~
. X7 M) u; z2 J8 q
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-30 22:43 , Processed in 0.042173 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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