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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

双核工作下,UPP不工作

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-1-29 09:38:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师:
" n" p; M0 K6 t$ @- c/ E; B# W     你好,我是保定炜达电力的
2 d( V* W, N8 c  I* z3 v: c* m     咨询问一个问题,我OMAPL138的DSP核部分已经用DSP仿真器调试通过了,使用SYSBIOS系统,UPP采集FPGA的数据,只使用UPP的A口,在初始化UPP时,修改了贵司的初始化文件(XDATA数据线因与LCD公用,所以修改)8 t  b: U& r9 U/ ^: d6 @
# j- y6 d# b4 ~
void UPPPinMuxSetup(void)
! J. {. r0 T, h7 `' N{0 p( H; R; P9 e% B4 C# @
unsigned int savePinmux13 = 0;% y# E: _( Q% w: `( `4 P3 F
unsigned int savePinmux14 = 0;! A4 z$ U! T" n$ X2 O
unsigned int savePinmux15 = 0;
9 l/ c& Y- {8 I* s! |0 Q unsigned int savePinmux16 = 0;
! p7 g1 T: t$ ]6 Q' L0 c unsigned int savePinmux17 = 0;
" [' h. @* v. W3 F% P unsigned int savePinmux18 = 0;
# \. Z: G/ m4 h* w /* all pins (channel A, channel B, DATA, and XDATA)*/. ?+ ~  G8 W5 {* K- T
savePinmux13 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) & 0x0000FFFF);    //不要的输入F0 X  J0 a* c* B9 J
savePinmux14 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) & 0x000000FF);
% N1 i: x5 @7 ^7 @/ |# Q4 T savePinmux15 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) & 0x00000000);
: o; V2 @+ e( e4 c savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0xFFFFFF00);
+ f/ u+ G6 ~4 w+ d0 |5 A% u1 y //savePinmux16 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) & 0x00000000);
! v3 ]$ M4 }: C1 i //savePinmux17 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) & 0x00000000);7 h% r; S  e  h, ^- h
//savePinmux18 = (HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) & 0xFF000000);
: e: S# V. W3 b& U( _ HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(13)) = (0x44440000 | savePinmux13);; e0 N$ U- ]" n& i' |
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(14)) = (0x44444400 | savePinmux14);
. h8 `% Q2 T; a$ ~; `1 L8 W HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(15)) = (0x44444444 | savePinmux15);) }4 ?: A2 e2 u# v0 t
HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x00000044 | savePinmux16);, f3 m; T' o# i: @8 ~- F3 Z  Y
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(16)) = (0x44444444 | savePinmux16);" F* v/ l+ B+ m
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(17)) = (0x44444444 | savePinmux17);' Y0 j  A' T( O2 c/ a7 x
//HWREG(SOC_SYSCFG_0_REGS + SYSCFG0_PINMUX(18)) = (0x00444444 | savePinmux18);
6 T1 a7 ?& S9 E5 w" B! V}
2 d5 K* D+ U; T6 x6 x& H$ z
# v( ]5 P; z$ I- y8 ~; G2 s     现在我的问题是,我DSP核心独立仿真调试没有问题了,但是现在OMAPL138 linux系统启动后,再加载DSP核应用程序,居然UPP中断不工作了,不知道是为什么,是不是LINUX系统与DSP有冲突,麻烦指导看一下。 ) ^/ g6 \( M6 Y* v- m: l( \5 w- Y
0 ^* m9 F8 ^7 S* c! A( }" o; x
3 Y9 V7 ^5 d6 r* \
8 L- H# U  [! t) v  _+ F
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-1-29 09:57:42 | 只看该作者
补充说明一下:按照贵司说明独立调试的方法是:8 n% }* b, t0 ^3 c; z% m
1)CCS连接ARM核心7 N- G4 R. z  y) [
2)加载omapl138.gel后,初始化相关操作后,唤醒DSP核心
; P* F1 M3 k; u4 H- b2 H5 S' _: G3)连接DSP核,然后调试仿真  6 ]; {/ ~, T8 t0 q# M9 ?4 o( `

: L- L5 n( [2 D# r初步联合调试,按照贵司方法如下:! f( n- U1 h* j; \3 E4 S+ ]0 e, c% ~
1)启动OMAPL138  linux系统
+ N0 ?3 K" X, u# d2 R' z- `2)进入系统后
6 n! l+ u( r: V- n! B/ S( _" cinsmod /lib/modules/3.3.0/kernel/drivers/dsp/syslink.ko TRACE=1 TRACEFAILURE=1
; \0 J9 Z) s6 O9 G3)然后再次连接CCS ,连接DSP核心5 ]: g0 W' ^* f  m& X4 p
再次在线仿真,就发现UPP不工作了,其他功能仿真正常。
# V7 \3 c1 m5 w( D
" {& I  @$ e! l, W9 e) E" z$ Y& g# [) M. A# u( h. U5 x& s
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-1-29 09:58:45 | 只看该作者
再次补充说明 LINUX启动时已经如下设置,DDR不应该有冲突7 N& K. @3 h% W4 \- ~
setenv bootargs console=ttyS2,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext3 mem=32M@0xc0000000 mem=64M@0xc4000000# M5 q: |% K! l7 j! `
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
地板
 楼主| 发表于 2015-1-29 17:14:14 | 只看该作者
问题解决了,原来内核文件要用旧的
/ `1 p2 Y& N: k; e) E
回复 支持 反对

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
5#
发表于 2015-7-31 12:13:47 | 只看该作者
tulipyyf 发表于 2015-1-29 17:14' X9 e6 |- `( B$ {) v0 ^9 B5 Y' W
问题解决了,原来内核文件要用旧的

' v; c# f5 _) q不好意思,打扰了,我现在所遇到的问题和你一模一样,看了你的回复说;内核文件要用旧的,不知道什么意思。麻烦告知下,谢谢
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

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

使用道具 举报

6

主题

18

帖子

129

积分

注册会员

Rank: 2

积分
129
7#
发表于 2015-8-7 14:42:55 | 只看该作者
tulipyyf 发表于 2015-8-4 08:27
0 Y  M  w* g$ t当时应该最后是因为内存使用一致性问题导致的~~~你可以查看一下内存使用一致性文档~~~
5 }0 e% }; Q" ^6 N# x* A+ M7 y“TI C64x+ DSP CACH ...

' h/ b! Y, `8 N' z, W+ q# R: o我看了下,好像没有使用缓存,应该跟一致性 没有关系吧。
回复 支持 反对

使用道具 举报

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:384 A5 w; U, E5 c2 z7 `6 U
DDR存储使用的是缓存~~~

7 W- w9 G$ h  ~: y% X6 W0 F. Z7 e哦,但我还是想知道你是具体怎么解决的。对于内核文件要用旧的一直不理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-30 22:31 , Processed in 0.040753 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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