Hi, Ferruh, On 10/02, Ferruh Yigit wrote: >On 9/28/2018 10:47 PM, Xiaolong Ye wrote: >> The vdpa sample application creates vhost-user sockets by using the >> vDPA backend. vDPA stands for vhost Data Path Acceleration which utilizes >> virtio ring compatible devices to serve virtio driver directly to enable >> datapath acceleration. As vDPA driver can help to set up vhost datapath, >> this application doesn't need to launch dedicated worker threads for vhost >> enqueue/dequeue operations. >> >> Signed-off-by: Xiaolong Ye <xiaolong...@intel.com> >> Acked-by: Xiao Wang <xiao.w.w...@intel.com> >> Reviewed-by: Maxime Coquelin <maxime.coque...@redhat.com> > ><...> > >> +static int >> +parse_args(int argc, char **argv) >> +{ >> + static const char *short_option = "i"; >> + static struct option long_option[] = { >> + {"iface", required_argument, NULL, 0}, >> + {"interactive", no_argument, &interactive, 1}, >> + {"client", no_argument, &client_mode, 1}, >> + {NULL, 0, 0, 0}, >> + }; >> + int opt, idx; >> + char *prgname = argv[0]; >> + >> + while ((opt = getopt_long(argc, argv, short_option, long_option, &idx)) >> + != EOF) { >> + switch (opt) { >> + case 'i': >> + printf("Interactive-mode selected\n"); >> + interactive = 1; >> + break; >> + /* long options */ >> + case 0: >> + if (strncmp(long_option[idx].name, "iface", >> + MAX_PATH_LEN) == 0) { >> + strncpy(iface, optarg, MAX_PATH_LEN); > >Giving compiler warning [1], rte_strscpy() is safer to use. > >[1] >In function ‘parse_args’, > > > > inlined from ‘main’ at .../examples/vdpa/main.c:419:8: > > > >.../examples/vdpa/main.c:76:5: error: ‘strncpy’ specified bound 128 equals >destination size [-Werror=stringop-truncation] > > > strncpy(iface, optarg, MAX_PATH_LEN); > > > > ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Thanks for the finding, by the way, how do you get this warning? I can't see it in my local build, what compiler you used? Thanks, Xiaolong