分享

TI DSP编程中使用LOG_Printf () 与 Printf ()的区别(转) ? ...

 oskycar 2010-07-24
在开发的时候通常需要使用printf()来显示当前状态。但是printf()是非常花费时间的函数 而且不具有实时性。因为DSP需要对显示的数据进行分析,整理成合适的显示格式,并调用输出显示模块。所以在一个实时性要求很高的应用中,对printf()的调用可能会使系统根本无法满足实时要求。在DSP/BIOS中引入了一个相应的函数LOG_printf()。该函数是LOG对象的一个方法(或调用函数〕。LOG对象本质上是一个32bit的整形数,其高低16bit分别代表要显示的两个数据。例1是分别使用printf()和LOG_printf()作比较的示范程序:

    #include <stdio.h>
    /* Header files needed for DSP BIOS */
    #include <std.h>
    #include <log.h>

    /* functions */
    void func_printf();
    void func_LOG_printf();

    /* Objects created by the Configuration Tool */
    extern LOG_Obj logTrace;

    /*======== main ======== */
    void main ()
    {
         return;
    }

    void func_printf(int time)
     {
         printf(″Strart printf demo\n″);
         printf(″Current time=%d \n″ , time);
         printf(″End printf demo\n″);
          return;
    }

    void func_LOG_printf(int time)
    {
        LOG_printf(&logTrace,″Strart LOG_printf demo\n″);
        LOG_printf(&logTrace, ″Current time=%d \n″ time);
        LOG_printf(&logTrace, ″End LOG_printf demo\n″);
        return;
    }

    func_printf()和func_LOG_printf()由DSP内时钟控制每100ms周期性地分别调用一次。通过对printf()和LOG_printf()运行时间作比较发现,在C6211运行在150MHz的情况下,printf()需花费4000个周期约26.7μs, LOG_printf()只花费36个周期约0.24μs。printf()比LOG_printf()多开销100倍以上的时间,因此LOG_printf()对于实时地显示一些运行状态是非常有帮助的。而且对于熟悉C语言的开发者来说,LOG_printf()的调用格式几乎与printf()完全一样。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多