双核工作下,UPP不工作 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
/ R( t; I5 m3 ^+ ]/ Q% h: q     你好,我是保定炜达电力的! O5 Z9 z* S$ s7 U; H: t( a
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)- n8 I4 d1 G* z) T7 K/ `
  s* V8 ]4 E1 t/ X
void UPPPinMuxSetup(void)
+ h+ J4 C2 E4 z{7 |, l1 g" q6 K" D2 b8 {" |( C
unsigned int savePinmux13 = 0;1 e" V/ g" ~+ k3 y# m
unsigned int savePinmux14 = 0;9 J* _) W; b- T- d7 j
unsigned int savePinmux15 = 0;' w8 S0 \. W$ H6 u( t& y
unsigned int savePinmux16 = 0;
+ d" p+ n1 o6 ^4 L" d1 F unsigned int savePinmux17 = 0;# b! p3 k- f0 a3 W3 s' T
unsigned int savePinmux18 = 0;
6 O/ r3 O4 t* p7 ~" G2 I0 K: _ /* all pins (channel A, channel B, DATA, and XDATA)*/
$ y5 L( r# V: R6 e1 _ savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F8 M( X# O4 }9 l2 v' v
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
+ u6 Y0 s( G: D  J  [4 K6 V savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
* H2 f2 c" |- G3 i$ R$ i savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);+ e1 k" }4 {4 [0 _* ~/ J
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);/ ]/ w, M  P! r9 g, k/ f# |. B2 W
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);; L: L$ v$ O# M# _) y% q
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);, w8 ^( M' P. E% g! y
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);( ~2 x9 L# j; `4 u" E
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
' d# r4 V0 y  q HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
4 y/ o: i' d- C HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);! R) |* \, F- ]
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
8 e! J# S# ~1 y //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
" F: ]' v( Y/ m# W' j1 {6 j //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
6 e6 p: E  s7 H$ {# S}
* r0 o, x0 }- X6 P% ~' h
% S& H% {+ h( v; {" Y* u$ N1 i     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 4 |: t4 j$ r, H5 \! \: }  ?2 @
! q: x1 o+ `4 r2 h1 w- R3 Y! h

- Y1 w/ S1 e, T. g8 A4 c* O
' Q6 @7 x) u+ u$ f9 }" A
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:$ Z- w5 j* h: z8 L) a$ V
1)CCS连接ARM核心
5 |8 |+ g- E4 L0 G9 L; T2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
8 H/ [$ [" G5 l* j- ]3)连接DSP核,然后调试仿真  - ^3 K" u. c  i6 _5 e. H

7 [  `- g6 d% t# M# H/ \! ^初步联合调试,按照贵司方法如下:8 t; u" c( ^! w4 K6 u/ ]
1)启动OMAPL138  linux系统
' W" @. q+ c  Q3 k2)进入系统后
7 w* H, _: @, L/ N) l0 Y3 Sinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1! j4 |' S, x0 U
3)然后再次连接CCS ,连接DSP核心6 P* _+ c/ f4 E1 _, i$ Q7 b
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。6 y7 e5 ]- e& ~) Y  N

" m" L7 O1 Z* i0 I2 R
+ n2 ]3 K* _9 {& ?: w! [
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
/ f  W& c- c3 Gsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
  |; u. N: e  Y8 W  k& B
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
% }/ W  V; i- ^6 E3 t; z2 M
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
  P% j+ U; J0 j问题解决了,原来内核文件要用旧的
5 A5 y" k7 [' V4 y% f/ }
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27# H7 o: w& R# B! f' V
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
7 R& z2 C9 ?2 C+ f“TI C64x+ DSP CACH ...
# Q5 E5 m" w2 l/ f
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
% s. W  O1 L. t0 @/ @1 RDDR存储使用的是缓存~~~
9 h, a: p" b+ M9 @
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

点击跳转“创龙科技服务通”

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

GMT+8, 2026-3-17 03:47 , Processed in 0.040771 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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