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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
0 d7 k0 n) ?( Z3 Q" s0 d; r6 F$ v     你好,我是保定炜达电力的; C3 H* L' [! t* z' _8 E
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
+ y+ T; z% ^5 s$ o5 O$ i* E5 o4 b' ]
2 @/ B- m8 z6 q7 bvoid UPPPinMuxSetup(void)4 m3 c- G4 r8 B
{
9 ]! W/ u3 V8 o! g! D5 A2 Z unsigned int savePinmux13 = 0;& D- @. T( G% Y; ^
unsigned int savePinmux14 = 0;' M2 M6 n- R, A. q9 c% F
unsigned int savePinmux15 = 0;
1 P% w& i* |, p  N6 e9 {8 b unsigned int savePinmux16 = 0;
% e  I0 J$ a4 A8 C& ? unsigned int savePinmux17 = 0;
5 b% [) b) `9 {) h7 c8 H unsigned int savePinmux18 = 0;8 Q0 O( R8 }4 I  L/ \6 a# _
/* all pins (channel A, channel B, DATA, and XDATA)*/+ K# B  r& t7 D: B" ?
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F4 D2 l8 x6 f9 {. h: q  J
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);/ y- Z" {' a& m4 n5 j1 |4 S
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);: e- U3 s( N" A# N; A
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);! A  ]5 i) \9 t& t8 R) i4 q
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);) [2 d" }5 l  r; i) v6 j4 b
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);# O; p/ n5 t" D9 Y: F* e4 h4 u
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
" s- z6 f# `7 L( Q% y2 _1 `9 b HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
9 F- y4 V+ C8 \% ~; u4 [/ S HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
( }9 A5 H6 u7 m, V HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);2 s( d9 T: B9 [% R1 t
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);( Y9 U, `* m2 G
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
, T! [" p. g' m& _+ l* P, h  s //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);4 B( X7 T* z6 p" {+ P6 R
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);$ u, }. @7 c# ^8 J3 [; a
}
0 j) P9 a5 B& n, u' v+ L6 T0 c1 N0 a! C
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 2 ~2 ^" R4 J8 x
* i+ A. e3 o3 X

, E5 z( A/ W. v, {* E7 G$ z$ S
- N; o1 x' ~& ?- T" [
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
4 `) o1 v2 I# H% [4 Z" s8 ]1)CCS连接ARM核心
: k; |& ]; J% y- {; W7 w2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心- x1 f. H- a/ I$ t
3)连接DSP核,然后调试仿真  ( M8 ^; K- H- l' Y: a5 E8 R8 i
* J5 y! ?2 w- m( c2 ]- }' |
初步联合调试,按照贵司方法如下:7 v# [; K" f. W: O" {
1)启动OMAPL138  linux系统& O" A/ x- \' |" X) t
2)进入系统后
5 T  n; ^4 A2 R! a' e9 Winsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1, ?5 B1 u- F3 X$ f3 h0 w/ c6 Y. }
3)然后再次连接CCS ,连接DSP核心1 T( d* X8 e+ W+ L$ k
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。- c. W9 d  G7 G# o6 \- J
1 m  p. e. L# c1 T6 k2 d. G4 s

0 @$ ]: q  M  J1 K
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突
2 i" z: W. w4 F5 D, _* Qsetenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000, ~5 l* O+ h; T/ _1 S
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的+ J+ _& M. u/ B* c
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14# P' ?* H4 v1 ]/ e
问题解决了,原来内核文件要用旧的

5 q, a; [3 b" g7 E不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
6#
 楼主| 发表于 2015-8-4 08:27:19 | 只看该作者
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
2 v; j) Y" V+ D3 B: H" S! W5 Z5 k4 L“TI C64x+ DSP CACHE一致性分析与维护”那篇文献写的很清楚
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
9 \& j! E; G) E* f! Q  b当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
; [- w0 G" r2 Z& @3 A0 N“TI C64x+ DSP CACH ...
+ s2 w* h4 B2 m! u
我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
6 A- Q7 \% n/ J% PDDR存储使用的是缓存~~~
! ]4 _$ A2 ~, \
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-16 12:20 , Processed in 0.047435 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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