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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:+ B% |, p* v: U
     你好,我是保定炜达电力的7 S. r/ O+ o4 I# t3 `2 c3 U/ w  V& s
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
% R( C; F$ N5 L; e4 Q7 }5 V4 \2 ]0 V' S
void UPPPinMuxSetup(void)
! W, v2 R8 `/ |7 c+ R' m) q, e{4 x) M! \6 }6 `6 z
unsigned int savePinmux13 = 0;
7 r% N& H" K+ m unsigned int savePinmux14 = 0;
! f: s* U. ~0 ^8 D4 t- w unsigned int savePinmux15 = 0;
8 D2 m) J4 s/ z& \8 ^) |  h unsigned int savePinmux16 = 0;
  ~) u6 h4 Q3 m" j# D unsigned int savePinmux17 = 0;% ^# K. V: U, P- O) C
unsigned int savePinmux18 = 0;2 \+ s# S4 T( v* e
/* all pins (channel A, channel B, DATA, and XDATA)*/
) G8 I. K. H7 P2 W- `- x savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F9 S  c6 B" B( V; ^: j( j, b
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
6 f% @, b1 Z4 U( V- u savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);% K* p/ i7 X+ [7 w, l3 I9 R/ U( X
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
7 y" f' {. x* P  R( f4 | //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
  U/ Y! ]2 w2 z+ M+ L+ ^! w //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);( z' g6 {$ r  ?# z! B6 `
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);; x0 |  [* i' ^& O# S. Q
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);" n, D9 E/ z- y0 d
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);. v; @4 |6 ~$ `; q7 M% g
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
8 V! @$ _' _  R* }/ X HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
6 D* F$ }! v. ?$ y //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);7 c) z1 c% E( Z$ @( ?
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);9 U1 h- e3 H1 X& V5 F: E
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);& q6 A6 F* {! _5 ?
}
# p7 u9 S1 L, I; z, C/ s
  w  _) k+ S: U7 `7 ]* n+ P     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
' F/ b! L, k- M  L5 `

* P) C+ u% V: t) z9 j( m% J( y/ i5 l" N. h9 H6 z$ p

$ @4 `1 Q* q. H! l5 v# j5 V
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:9 d, C, f) m% n
1)CCS连接ARM核心  k% r+ @/ f" g9 ^+ f! I2 _. {
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心0 ]/ D$ [9 i% ~+ w% I0 s
3)连接DSP核,然后调试仿真  % k" l/ V* Q$ H6 I$ w/ H+ }

. r5 l' Q) F! B2 p% _. w3 x1 O初步联合调试,按照贵司方法如下:+ q: x+ S! u, x2 t
1)启动OMAPL138  linux系统
2 ?6 E) e' |: `! f2)进入系统后
# g9 g! Y* f! I# Y5 g4 k8 Zinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1; ?; ]2 X- M- d, j* Q
3)然后再次连接CCS ,连接DSP核心
. A( B: o  h- d3 k9 L# R' P再次在线仿真,就发现UPP不工作了,其他功能仿真正常。7 o$ y* I' b. r' {" O
. ~% x% ^. B3 _/ h4 h
$ r# i6 `/ Q) v: t; v9 s
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
. V) u5 K& C8 v8 r2 q* a) qsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc40000002 {/ m4 C0 R' {9 I- y
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的9 K  Y% @/ |& i1 f/ a; k3 }8 ^( N
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:144 J: ~$ g/ R) l0 @9 w/ E: d2 R
问题解决了,原来内核文件要用旧的

! v' {$ {0 j# T  N/ g4 g不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
8 G8 r& C/ w7 M" @3 i6 v7 {$ ]当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~5 P8 i- h3 E. ], @
“TI C64x+ DSP CACH ...

! r% J4 C% @2 u7 b我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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  G: K/ M2 B# f1 U0 H; Z3 t+ C6 e& J' t
DDR存储使用的是缓存~~~
+ y$ U/ d- ^( k3 l8 D) Y( d1 l
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-3 06:11 , Processed in 0.038851 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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