http://blog.csdn.net/lights_joy/archive/2008/07/18/2670447.aspx
前段时间,将uclinux内核移植到了Visual DSP 5.0下,也就来说说对Vdsp5的一些看法。
总的说,VDSP5还是一个比较不错的IDE的,面对23M的dxe文件,都能正确地进行调试,虽然其下载速度变慢,大概要4分钟左右才可以下载完。
对VDSP的意见集中在下面几个方面:
1、不支持空行。
比如仅仅在一行上打上一个分号,VDSP就会有强烈的意见。这一点可能不应该把帐算在VDSP的头上,但是我相信只要对编译器进行很小的改动就可以实现,这对于将软件从GCC编译器移植到VDSP却有莫大的好处。
2、.macro
在gcc下的汇编支持.macro,它类似于define,但是使用.macro可以在定义中使用#ifdef这样的条件编译,而用define则不行,希望未来VDSP也可以支持它。
3、.rept
使用.rept,相当于可以对代码进行copy / paste的操作,可以节省很多时间,希望未来VDSP也可以支持。
4、jump 1f
可恨,这么好的一个东西,VDSP居然不支持。
5、嵌入汇编
这是VDSP最烂的一个地方,如果你在C中嵌入汇编,而这个代码又很不幸地出错了,那你别指望VDSP会帮助你,它的错误提示完全让人不知所云!!
关于C编译器,主要存在两个BUG,都和优化有关。
1、__builtin_expect
这个本来是个好东西,可惜有时它会引起编译器的崩溃,而且其提示让人不知所云!
2、inline
这个也是个好东西,但当内联超过多层的时候(不确定是否这个原因),也会引起编译器的崩溃!就像这样的:
..\..\mm\filemap.c
At end of source: : internal error: Uncaught exception Assertion failed raised
at ../../../bril/optimiser/dominators.c:910 (in pass
cleanup_scalar_stores_nonopt during compilation of
_find_or_create_page). Please submit a bug report with this message,
the command line used, type of machine and the output of the
compiler when you add -ED -v to the command line. Please also send
us the pre-processed file that is generated by the -ED option (the
file generated is named <original_filename>.i)
1 catastrophic error detected in the compilation of "..\..\mm\filemap.c".
Compilation aborted.
cc3089: fatal error: Compilation failed
1、当要调试的系统变大时,偶而有不稳定的现象发生,比如下载完成后要将系统中断下来,此时当按下中断按钮时,直接就跑飞了,你再下载一次就OK了。这在系统较小时几乎不会发生。
2、在显示变量值的窗口(Expression)中,有一些结构体无法显示结构体的成员。
3、在跟踪inline函数时,无法查看其变量的值。这个似乎不应该归罪于VDSP,写下来供参考。
这个就比较让人恼火了,如果你定义一块比较大的空间,然后将这个空间分成多个section,这个时候,链接器会自动将一些小代码或者小变量塞到一些内存的空隙中,以此提高对空间的利用率。本来是件好事情,但是在有些时候这却会造成致命的错误!
链接脚本里提供了一个FORCE_CONTIG的命令,但是实际发现它并不起作用!
欢迎光临 mobile CCTV,mobile surveillance,police body worn cameras (http://bbs.besovideo.com:8067/) | Powered by Discuz! X3.2 |