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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:. p7 T, W) Z% w! q3 U' h
     你好,我是保定炜达电力的6 U: U$ O2 U5 T
     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)
' G* ?  v1 o3 v( R4 p& r9 R  G( h6 o' `' _
void UPPPinMuxSetup(void)) T+ N7 k4 {/ [* A
{
2 E6 c1 l  T" o+ K7 b4 X# D% e unsigned int savePinmux13 = 0;6 S  t8 S2 k8 p+ d; E5 f! M: i6 r% i
unsigned int savePinmux14 = 0;
% R5 c! {- u  Q' f unsigned int savePinmux15 = 0;
* M' C; D6 w9 s" v/ u1 B& t3 G unsigned int savePinmux16 = 0;# G+ i" N6 s# E" G* d8 |. R1 T
unsigned int savePinmux17 = 0;/ k' Q* }' a+ t$ y$ A
unsigned int savePinmux18 = 0;
$ |  \" W: ?# y0 n4 n /* all pins (channel A, channel B, DATA, and XDATA)*/1 p7 a! W* V1 }% E
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F3 @6 v+ w. \: R2 ?1 v7 L
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);1 {  W: J8 d- y) m
savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
& V; Y' p7 I+ U8 `; ?4 a# r  U savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);1 d% r/ g1 w# [
//savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);' }: C' W, o' ~7 ]2 Q% @  z
//savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);
. }$ x& v+ n- F' u7 P //savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
+ d( U2 k8 {* Y$ c HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);
0 {" O  w: x# q" T4 ?) P/ ?; d HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);1 K: z: S+ f5 r8 H7 r0 F, n- l
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);
2 {3 c8 x+ n- A7 I- ]3 \ HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);, ~* t2 b9 b3 _6 I, v; L/ [$ N# R
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);
0 F9 [  |$ w9 P0 Q: D //HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);- y' V/ r3 A$ X
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
% T# r! J/ ]3 {; U- o* v0 w}4 P% D3 b, v# J. C
+ p+ @4 ?: ^: c3 h$ u% y
     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。
; f! T( P1 l3 B# Y: O6 p! s

0 \( k* U& ?4 L5 e, i5 c
5 e1 S# y/ `# n. }% v* {
& H) a" @- t+ F% U; Y0 U
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:
9 R+ `2 S" Y5 X, e1)CCS连接ARM核心
% |5 K/ R) F  Q2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
/ @  Z- j( q7 ^, }( ]1 W- K3)连接DSP核,然后调试仿真  . p! ]( j4 [0 P. v8 _
4 G$ ?$ B3 Y$ k" j  ?. V% g! X
初步联合调试,按照贵司方法如下:
3 i; s7 N7 }6 P$ n1)启动OMAPL138  linux系统
+ U7 V9 s- k0 c4 a/ Y! }( d2)进入系统后% i$ K( |: J( Z5 q
insmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=14 @4 U9 R' j- y6 d& I3 r
3)然后再次连接CCS ,连接DSP核心
8 n% d* u% U+ t1 g: N+ m再次在线仿真,就发现UPP不工作了,其他功能仿真正常。# T+ i- w7 z7 c# q, ~. T- S/ Q

  k6 O' A3 R# O8 Y' h
8 \, W8 O7 u8 V$ H4 G) l" P7 R4 `' k
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突  L% C+ N1 P, J" n3 a# h% w, ~$ r  v
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000
3 B) V5 e4 V: Z$ p
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的7 R/ a4 [3 R; b, ~. F9 x2 `
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14
1 x; n" i, n0 ]问题解决了,原来内核文件要用旧的

& x. B1 \  Q$ n7 a7 T( s9 O* S: _不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27) @' [/ |" L; h, d" F
当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
3 N, f" b& R5 z0 C8 j“TI C64x+ DSP CACH ...

9 W8 p1 Z3 G/ [: P4 f0 F$ w. m我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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
2 {; q2 G/ o1 p0 t6 lDDR存储使用的是缓存~~~
/ W+ a( m* ]7 G. S3 O7 \5 h# f
哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-16 10:45 , Processed in 0.059563 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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