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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:+ R5 |# q" M( F4 w6 s
     你好,我是保定炜达电力的; `, m; M( ]2 }! S# B* ]* w4 G
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
/ ^4 v* t+ e" R' v+ K  i% K2 h* L& i5 y1 Y
void UPPPinMuxSetup(void)# s8 O! g4 `% f/ m" j
{
0 A* C, S  L1 l1 _9 _ unsigned int savePinmux13 = 0;2 S" C% W! P9 l. m: b( \2 I  F# p$ S
unsigned int savePinmux14 = 0;
/ A0 f1 a& }' `& E unsigned int savePinmux15 = 0;, _$ q# ~+ K% V( t- T4 p$ E& j
unsigned int savePinmux16 = 0;
, e, t3 [4 g. Q( ` unsigned int savePinmux17 = 0;' v5 |, d( Y# W! K
unsigned int savePinmux18 = 0;5 D/ f! a5 o: j
/* all pins (channel A, channel B, DATA, and XDATA)*/- x4 c* H. p5 m. E  N- h) @6 A
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
4 I5 C5 k9 J6 @: J6 N& J savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);% [4 `# X. \( g+ c  q5 m/ s
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 N8 e- N, ~% y& F& M4 l; q8 @2 ?
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
4 W1 k1 S: _( U' c+ y# P$ v //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
9 `3 i. r; M! \! N //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);1 K/ u* _& b2 _; N2 X5 X1 c
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);) X9 H; a  f, U0 C$ e* V. d
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);! B- X" v+ ^+ {7 ?% V2 z3 J7 \  u. X5 t" f
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);5 e8 U6 S0 ?: Z3 ^- N5 O) H1 U) r
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
/ J: c+ I5 K/ m9 b% A HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);
( m6 f$ p/ z* V //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
6 ], e- O0 ]- f+ M( v0 u //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);
1 r7 b* a8 z0 a* ?4 S7 g8 r/ C //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
6 H( j  r! w  ?1 z4 }}
9 |/ \: C" |  L& i
. Z: C$ ]( C  F6 s     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
" J% q9 W9 f7 l) N/ Q0 m+ d4 x
5 S) h; ^  \$ R7 ?, {
8 P- v, o6 b. r. M5 R, M6 X8 s
! u7 V+ ~! _) U
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
1 C4 E: I! M" r8 K1 ]1)CCS连接ARM核心
3 Q9 m6 x5 |+ M2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心9 |( \4 m' w0 d3 {8 d0 ~) e
3)连接DSP核,然后调试仿真  
: }0 F1 C4 {8 U
: {# g9 `: [" v2 `7 B; [' O* u+ `初步联合调试,按照贵司方法如下:
6 |4 q) u4 B0 J) C& ]1)启动OMAPL138  linux系统
2 |7 t. a9 A5 e( l2)进入系统后# }- c6 M) S) n$ P6 \: |
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
& `: `& y. O" ~* V' ]( Y$ O3)然后再次连接CCS ,连接DSP核心0 K! M3 }. W4 f6 b" o- X" z
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。( L1 S( W0 U5 [" r1 {/ `
) ~/ i; D# i2 \% D
/ Y0 W& F# P7 u3 i* n5 b
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
8 A0 j2 B7 m8 `0 n( Psetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
  L) z# E/ s3 @
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
" M5 p6 T/ k7 o
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:144 G1 K! N; k6 F
问题解决了,原来内核文件要用旧的

) |: M, E; ?( h不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27& f$ ?3 s7 S; x7 H& ]
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~% p1 j+ D" ~/ U, b
“TI C64x+ DSP CACH ...

# V4 a" j( T) p+ v我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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: i) P: k0 ^- L+ p$ p1 B' ~
DDR存储使用的是缓存~~~
2 j3 N" A) F; s# O- L
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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