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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
) S% ~# ^3 b9 y: W% g0 X) d' s* g     你好,我是保定炜达电力的6 @5 `; b& D+ x/ w: G! T
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)/ e0 a) T$ y8 Z' d/ q' r* F' \
' b% u1 v2 t* R8 F+ Z0 j$ {
void UPPPinMuxSetup(void)
7 b" u* a( Z$ H{
$ k/ d: E) e  _6 D: q unsigned int savePinmux13 = 0;& E& E3 ]0 r7 L: [: _. O5 K) B
unsigned int savePinmux14 = 0;
+ ~6 v6 f) d1 M2 m unsigned int savePinmux15 = 0;
+ G4 S% B9 e8 Q( {$ ? unsigned int savePinmux16 = 0;; Q# b  v5 u2 g1 Z- K1 o$ e
unsigned int savePinmux17 = 0;
$ F( s% ~( g! Z% U* u$ _) e, X unsigned int savePinmux18 = 0;; i8 n( b8 q% B/ ?
/* all pins (channel A, channel B, DATA, and XDATA)*/  v4 }/ {: o7 f% E$ u
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F
, j: p7 e$ X* J# L/ i; [* V savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);' Z6 G% T, K: _6 f# ~
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);5 r0 [% R/ y% S
savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
$ s7 A9 u5 @: y! ~& p. p //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);! L5 k8 p0 z6 ]9 B
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
5 t1 x" e8 t( `2 O //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
2 j9 b. M) {- c1 B. f$ V  r HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
. O1 l7 z+ x  T( |0 m# K HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);$ {  s5 ~3 G  V' ~" v
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
) {& i# T2 X! e# v# e HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);1 j9 N7 q9 _8 Z9 I5 Y* d
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
# {( v. `9 U" p+ x' C% c //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);: g& r) ]( J* O4 D
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
* p# M3 J7 \! N}! b4 @; F5 f% |6 k, e

" C9 ^: `- f/ n     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 , u( W+ Z3 {. l# m% _0 E8 F

) w" c$ z; b& c+ J' i' k" O
$ \; m  \" w; o- {8 r! x  }0 s/ d: R% B. {
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
! i. @# n# L5 i' B: Y1 ~1)CCS连接ARM核心
, B0 @2 y* |, q# g2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心$ h9 _/ |) Y; X0 N' r  A4 [! N
3)连接DSP核,然后调试仿真  
3 q% `0 k5 u8 y( x
* t" F5 Z# R# @初步联合调试,按照贵司方法如下:
8 M  i$ M* ^3 ]' X: D/ ]; ~! b1)启动OMAPL138  linux系统2 A% b$ T2 l3 Z$ C: q( P" Y0 t# Q
2)进入系统后- [) W  F. c+ w; d% W  D4 M
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
4 Z# E7 {4 O" A- w! d+ y/ u3)然后再次连接CCS ,连接DSP核心2 T/ @* Q# ~# X+ |5 x; }/ d; G/ E
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。0 |. h- l) u3 c4 H! b0 ]7 V8 T

& r% t; C3 ^: a) e$ V! e" s3 o- |4 T  U; V" M7 V
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突5 d1 `6 s( e! ?% T
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
6 x( G2 @/ _4 }
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的% r8 n3 b" R- A4 l! W% j$ Q
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:143 j. I2 P, D2 d# U: F. T8 V3 s
问题解决了,原来内核文件要用旧的
, p7 _& C; y7 L7 n
不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
8 w. F- f- L0 [' N' ]" W当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
0 c- G# J0 N7 r& b9 U' @: c“TI C64x+ DSP CACH ...

$ P4 |; P9 a6 d我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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: d! U% m. h% N' G
DDR存储使用的是缓存~~~
7 e9 A' i" U6 _2 |, \! F( `
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-16 15:56 , Processed in 0.041088 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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