论坛里的前面的SYSBIOS系统的指针操作耗时长的问题没有解... - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 3759|回复: 1
打印 上一主题 下一主题

论坛里的前面的SYSBIOS系统的指针操作耗时长的问题没有解...

[复制链接]

17

主题

30

帖子

149

积分

注册会员

Rank: 2

积分
149
跳转到指定楼层
楼主
发表于 2016-8-24 16:44:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
你好,前面提的问题:sysbios系统工程指针操作耗时长的问题 这个问题还没解决啊。
2 P! U$ W: f5 a: H5 d3 Yhttp://www.51dsp.net/forum.php?m ... p;tid=1198#lastpost
2 e. D5 ]; c  [$ o" \5 Z' |5 v$ _. X, k8 D" d; j8 y& C  T1 n9 a0 {
) i% v) R1 S. t, w) u
自己有尝试好几次,感觉像是sysbios下面的读内存比写内存更花费指令周期,我看了测试程序的汇编语句:
- \! b& ?/ t- p5 [+ v. z# g; l5 y
2 v' ~) [" A  O, C& P
- `& u$ M0 N$ n27                *pda = 30;% b8 R! d0 P; v  ~  y6 }  p1 t
c30025cc:   0200106E            LDW.D2T2      *+B14[16],B4
/ Q8 R: \. y0 v/ d$ Dc30025d0:   DA93                MVK.S2        30,B5! ]4 a  I: m: m
c30025d2:   4C6E                NOP           37 r; m8 @4 j# y1 ~3 N. r
c30025d4:   029002F6            STW.D2T2      B5,*+B4[0]
4 c- h) ^1 ?( f% w' Q4 {+ ^! K5 Q* f+ H4 R$ P
这是指针赋值的汇编语句;
& w$ E0 b( Q( r# z7 m' b7 m下面这个是变量赋值的汇编语句:" C5 S* P1 |, _' _$ |
27                test = 30;# s$ z# }0 p8 c! o$ i6 q/ x1 ^
c30025c4:   01800F28            MVK.S1        0x001e,A35 r: K3 D+ P0 F, m0 G! H
c30025c8:   0180017C            STW.D2T1      A3,*+B14[1]
* R9 Z4 c9 \2 k7 E" F4 Z  C/ I; u
. o% J1 q/ b, M9 f7 m) P
/ ~6 h$ D" T$ P1 [* L我对比了看指针赋值比变量赋值也就是多了一个把地址读出来的操作,但是指针赋值要比变量赋值多几十倍的指令周期。完全不应该啊。
$ {, O- O6 O' @7 K我把测试代码再贴出来一下,在前面那个问题上已经贴过了:
; c. o. j$ u4 p. ~3 V3 `2 |# w#include“c6x.h”
/ B9 ~# ~; z$ {  B2 }1 ^, L  D2 J! r" Dint test;# ]9 L9 n; K" O# S
int *pda= &test;% L5 J! J" u& P: c7 H
long long t1,t2,tdelt,;
2 x4 h7 Z/ K/ \Int main()
1 ]2 i- z7 o! D{1 K/ Y9 y& R* {8 [1 i: _' E3 U
        TSCH=0;
0 M, h" c7 ^/ g- ]7 y        TSCL=0;
+ ~: E' O, P* v; F% h! J' U% d        t1 = _itoll (TSCH, TSCL);$ Q; k  R5 i* k& _1 @0 t  u
        *pda = 20;
# \1 X6 G( {1 ]6 \4 n* G        t2 = _itoll (TSCH, TSCL);
7 _! o. Y" i* R0 H+ g0 [: ]        tdelt = t2-t1;* {, X# b1 _2 Y( h& B# ]1 `
        return 0;/ S3 l/ A" i6 L# q  x5 Q+ Y
}
: a/ }, t" R" ^0 ~# I5 [' \& f6 |: C9 L$ W+ f5 |
此处tdelt的值得到是307,而将*pda = 20;替换成test=20;那tdelt的值就是6.差距如此大。7 x4 j# r8 I; X; c+ }/ l& ?

7 O2 q4 J0 q7 m+ i4 U8 O* t1 H
$ }8 j; |5 L& T3 G! R希望创龙的朋友的也可以试一下看看,只要在CCS里面新建有sysbios工程,就用上面的代码测一下就能看到现象了。
5 ^# L" f% U- m9 T. }请帮忙分析一下原因啊。4 M1 E' m: ~3 S5 t% _
2 o3 I9 {) g  ~

% `! T& ~- W8 m0 E" Q& W) I' e
' ?9 \/ v+ n5 _& f1 ~3 l1 G
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
沙发
发表于 2016-8-25 16:30:02 | 只看该作者
11 时钟周期 挺正常的....% z+ ~: J/ e  Y+ J' M6 T% M

7 m7 q9 V" h+ N$ N, I5 v

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-4 09:54 , Processed in 0.037470 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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