VLIB_BUFFER_TRACE_TRAJECTORY宏的作用-创新互联

可以通过开启宏VLIB_BUFFER_TRACE_TRAJECTORY,在mbuf里记录mbuf经过的node个数以及所经过的node的index:

创新互联是一家专业提供东西湖企业网站建设,专注与成都网站设计、成都网站建设、H5响应式网站、小程序制作等业务。10年已为东西湖众多企业、政府机构等服务。创新互联专业网站建设公司优惠进行中。

    if (VLIB_BUFFER_TRACE_TRAJECTORY && frame)

    {

      int i;

      int log_index;

      u32 * from;

      from = vlib_frame_vector_args (frame);

      for (i = 0; i < frame->n_vectors; i++)

      {

        vlib_buffer_t *b = vlib_get_buffer (vm, from[i]);

        ASSERT (b->pre_data[0] < 32);

        log_index = b->pre_data[0]++ + 1;

        b->pre_data[log_index] = node->node_index;

      }

      n = node->function (vm, node, frame);

    }

用以下函数打印记录的node信息

void vlib_dump_context_trace (vlib_main_t*vm, u32 bi)

{

   vlib_node_main_t * vnm = &vm->node_main;

   vlib_buffer_t * b;

   u8 i, n;

   if (VLIB_BUFFER_TRACE_TRAJECTORY)

   {

       b = vlib_get_buffer (vm, bi);

       n = b->pre_data[0];

       fformat(stderr, "Context trace for bi %d b 0x%llx, visited%d\n",

               bi, b, n);

       if (n == 0 || n > 20)

       {

           fformat(stderr, "n is unreasonable\n");

           return;

       }

       for (i = 0; i < n; i++)

       {

           u32 node_index;

           node_index = b->pre_data[i+1];

           if (node_index > vec_len (vnm->nodes))

           {

               fformat(stderr, "Skip bogusnode index %d\n", node_index);

               continue;

           }

           fformat(stderr, "%v (%d)\n",vnm->nodes[node_index]->name,

                   node_index);

       }

   }

   else

   {

       fformat(stderr,

               "in vlib/buffers.h,#define VLIB_BUFFER_TRACE_TRAJECTORY 1\n");

   }

}

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享题目:VLIB_BUFFER_TRACE_TRAJECTORY宏的作用-创新互联
转载来于:http://cdiso.cn/article/cciedg.html

其他资讯