[dpdk-dev] [RFC] af_packet: support port hotplug
    Tetsuya Mukawa 
    mukawa at igel.co.jp
       
    Tue Mar 17 04:42:47 CET 2015
    
    
  
On 2015/03/16 23:47, Iremonger, Bernard wrote:
>
>> -----Original Message-----
>> From: Tetsuya Mukawa [mailto:mukawa at igel.co.jp]
>> Sent: Monday, March 16, 2015 8:57 AM
>> To: Iremonger, Bernard
>> Cc: John W. Linville; dev at dpdk.org
>> Subject: Re: [dpdk-dev] [RFC] af_packet: support port hotplug
>>
>>>>>>> @@ -835,10 +848,53 @@ rte_pmd_af_packet_devinit(const char *name, const char *params)
>>>>>>>       return 0;
>>>>>>>  }
>>>>>>>
>>>>>>> +static int
>>>>>>> +rte_pmd_af_packet_devuninit(const char *name) {
>>>>>>> +     struct rte_eth_dev *eth_dev = NULL;
>>>>>>> +     struct pmd_internals *internals;
>>>>>>> +     struct tpacket_req req;
>>>>>>> +
>>>>>>> +     unsigned q;
>>>>>>> +
>>>>>>> +     RTE_LOG(INFO, PMD, "Closing AF_PACKET ethdev on numa socket %u\n",
>>>>>>> +                     rte_socket_id());
>>>>>>> +
>>>>>>> +     if (name == NULL)
>>>>>>> +             return -1;
>>>>>> Hi  Tetsuya, John,
>>>>>>
>>>>>> Before detaching a port, the port must be stopped and closed.
>>>>>> The stop and close are only allowed for RTE_PROC_PRIMARY.
>>>>>> Should there be a check for process_type here?
>>>>>>
>>>>>> if (rte_eal_process_type() != RTE_PROC_PRIMARY)
>>>>>>         return -EPERM;
>>>>>>
>>>>>> Regards,
>>>>>>
>>>>>> Bernard
>>>>>>
>>>>> Hi Bernard,
>>>>>
>>>>> I agree with stop() and close() are only called by primary process,
>>>>> but it may not need to add like above.
>>>>> Could you please check rte_ethdev.c?
>>>>>
>>>>> - struct rte_eth_dev_data *rte_eth_dev_data; This array is shared between processes.
>>>>> So we need to initialize of finalize carefully like you said.
>>>>>
>>>>> - struct rte_eth_dev rte_eth_devices[] This array is per process.
>>>>> And 'data' variable of this structure indicates a pointer of rte_eth_dev_data.
>>>>>
>>>>> All PMDs for physical NIC allocates like above when PMDs are initialized.
>>>>> (Even when a process is secondary, initialization function of PMDs
>>>>> will be called) But virtual device PMDs allocate rte_eth_dev_data and overwrite 'data'
>>>>> variable of rte_eth_devices while initialization.
>>>>>
>>>>> As a result, primary and secondary process has their own 'rte_eth_dev_data' for a virtual device.
>>>>> So I guess all processes need to free it not to leak memory.
>>>>>
>>>>> Thanks,
>>>>> Tetsuya
>>>>>
>>>> Hi Tetsuya,
>>>>
>>>> In rte_ethdev.c   both rte_eth_dev_stop() and rte_eth_dev_close()  use the macro
>> PROC_PRIMARY_OR_RET().
>>>> So for secondary processes  both functions return without doing anything.
>>>> Maybe this check should be added to rte_eth_dev_attach() and rte_eth_dev_detach() ?
>>>>
>>>> For the Physical/Virtual  Functions of the NIC  a lot of the
>>>> finalization is done in the  dev->dev_ops->dev_stop() and
>>>> dev->dev_ops->dev_close() functions. To complete the finalization the dev_uninit() function is
>> called, this should probably do nothing for secondary processes  as the dev_stop() and dev_close()
>> functions will not have been executed.
>>> Hi Bernard,
>>>
>>> Sorry for my English.
>>> I meant 'virtual device PMD' as PMDs like pcap or af_packet PMDs.
>>> Not a PMDs for virtual functions on NIC.
>>>
>>> For PMDs like a pcap and af_packet PMDs, all data structures are
>>> allocated per processes.
>>> (Actually I guess nothing is shared between primary and secondary
>>> processes, because rte_eth_dev_data is overwritten by each processes.)
>>> So we need to free per process data when detach() is called.
>>>
>>>> For the Physical/Virtual  Functions of the NIC  the dev_init() is called for both primary and
>> secondary processes, however a subset of the function only is executed for secondary processes.
>>> Because of above, we probably not be able to add PROC_PRIMARY_OR_RET()
>>> to rte_eth_dev_detach().
>>> But I agree we should not call rte_eth_dev_detach() for secondary
>>> process, if PMDs are like e1000 or ixgbe PMD.
>> Correction:
>> We should not process rte_eth_dev_detach() for secondary process, if PMDs are like e1000 or ixgbe
>> PMD and if primary process hasn't called
>> stop() and close() yet.
>>
>> Tetsuya
>>
>>> To work like above, how about changing drv_flags dynamically in
>>> close() callback?
>>> For example, when primary process calls rte_eth_dev_close(), a
>>> callback of PMD will be called.
>>> (In the case of e1000 PMD, eth_em_close() is the callback.)
>>>
>>> At that time, specify RTE_PCI_DRV_DETACHABLE flag to drv_flag in the
>>> callback.
>>> It means if primary process hasn't called close() yet,
>>> rte_eth_dev_detach() will do nothing and return error.
>>> How about doing like above?
>>>
>>> Regards,
>>> Tetsuya
> Hi Tetsuya,
> For the e1000, igb and ixgbe PMD's it is probably  simpler to just check for the primary process in the uninit functions and just return without doing anything for secondary processes.
Thanks for clarifying.
In the case, is it okay for you to add PROC_PRIMARY_OR_RET() in e1000,
igb and ixgbe PMD code?
If it's okay, we may be able to ACK this patch. :)
Regards,
Tetsuya
>
> Regards,
>
> Bernard.
>
>
>
>
>
    
    
More information about the dev
mailing list