On 10/3/2018 7:04 AM, Ye Xiaolong wrote:
> 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?

gcc,

$ gcc --version
gcc (GCC) 8.1.1 20180712 (Red Hat 8.1.1-5)

Reply via email to