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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
1 \9 k1 x) i' K: V9 S" l     你好,我是保定炜达电力的% g8 ~3 {, `0 f' [
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
' @0 g0 L* `4 D! u2 V4 ~
/ A1 Y+ A6 _7 I6 y" \$ P6 P' ovoid UPPPinMuxSetup(void)
, B! a7 D6 A4 o2 `' t{. w# ^8 V9 ^0 P7 N
unsigned int savePinmux13 = 0;! x# H* p6 z6 x; N  Z- r8 |' p
unsigned int savePinmux14 = 0;
  l8 F+ n/ I9 w5 G unsigned int savePinmux15 = 0;; x" Y7 M+ v. h  |2 f/ t5 _* [2 F
unsigned int savePinmux16 = 0;
8 }3 X+ I" Y. T* N( {, p# a unsigned int savePinmux17 = 0;- U: U8 q8 l1 x) N
unsigned int savePinmux18 = 0;
' H/ s% E$ g7 t  |7 J: S /* all pins (channel A, channel B, DATA, and XDATA)*/0 E# V9 N# y  p7 ^0 m" V% G; r
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F) G6 W: q$ U7 b# G# T
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);/ O# Z! C8 y' X; w  I" A( M9 D0 k
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);& ^+ v. [% a5 l: e$ N- H  n
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);* p5 M$ T) f  |5 p' ]$ Q
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
1 l0 U* J  S8 f& U //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
) W  ?, L% c* i7 Y6 ]3 ?+ l0 L9 { //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);8 L$ L8 R0 p  g( V8 `% l( \1 c& z
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);8 z+ a$ B( Z, S) Q' j# r
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);8 Y( D6 S# M3 w
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
7 e9 B1 ]. u& n7 _6 N HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);6 }* f' T" `& R# i+ N4 Z
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);3 J$ ?8 l! Z+ H
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);7 b& [" G) t7 V" R7 s5 X1 s
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);* h: B8 H7 H) `: {8 M- x% I
}
7 y/ H6 Y. L/ h
! G; M0 r# k9 X* u% k     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 ! ]8 H9 N. X6 F3 ^; ?
# D% Y9 k4 a0 a1 G! C. t9 {, g! }
; U4 v( I0 j: i- ~

9 U1 q' C  B9 R0 {
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
; P* X6 |& Y* o2 ]( s7 I3 v1)CCS连接ARM核心
1 G1 Q9 ^4 T# {# T5 [, a) ^2 G1 g2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
8 P6 {3 U! G7 Z, p1 `8 ^3)连接DSP核,然后调试仿真  9 S& l: R2 L  e1 x! k. h

- j: v9 T  ^5 l0 O初步联合调试,按照贵司方法如下:* A4 ^" c7 N& T. N6 i
1)启动OMAPL138  linux系统
6 E9 _& n4 P: ?1 g2)进入系统后# h3 R  o' y. W. Y; q; Y! I
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
$ I' s2 B& @4 ?( C: v# B4 t3)然后再次连接CCS ,连接DSP核心! U& H: d8 R7 R8 o* q; w/ w% N7 \
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。+ P& W4 G' H+ D- X
4 Y. b! l8 Z0 M5 S% f
- ?9 T; Y- q7 y! l$ w7 w/ |4 {
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
2 I8 O) m2 O" s2 z; }setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000* C1 ~/ c- Z* C, T7 Z
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的4 V- [6 {/ N, G' n
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

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

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
9 s$ t  N0 j1 @! Y当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
0 O2 o$ B9 A2 D0 e“TI C64x+ DSP CACH ...
0 B0 B; ~1 U& _) P: ^
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
  {. C9 [8 q& u3 b1 ?DDR存储使用的是缓存~~~

: z3 F1 k$ L! M( e) }9 ?$ P哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-16 11:41 , Processed in 0.039520 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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