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