On 9/19/2023 4:38 AM, Wei Hu wrote:
> 
> 
>> -----Original Message-----
>> From: Ferruh Yigit <ferruh.yi...@amd.com>
>> Sent: Tuesday, September 19, 2023 2:03 AM
>> To: Wei Hu <w...@microsoft.com>; dev@dpdk.org; Long Li
>> <lon...@microsoft.com>
>> Cc: sta...@dpdk.org; Kevin Traynor <ktray...@redhat.com>; Luca Boccassi
>> <bl...@debian.org>
>> Subject: Re: [PATCH 1/1] net/mana: add 32 bit short doorbell
>>
>> On 9/9/2023 1:23 PM, Wei Hu wrote:
>>> Add 32 bit short doorbell support. Ring short doorbell when running in
>>> 32 bit applicactions.
>>>
>>
>> Hi Wei,
>>
>> Is this performance improvement for 32 bit, or is short doorbell support
>> required for 32 bit support?
>>      
>>
> Hi Ferruh,
> 
> This it not a performance improvement patch. Without this patch, 32 bit 
> applications
> do not function. 
> 

OK

>> This patch is using RTE_ARCH_32 compile time macro to enable short doorbell
>> support, so need to decide to support 32 bit or 64 bit in compile time.
>>
>> Also I guess 32 bit driver can run on 64 bit arch, what will be the result 
>> in that
>> case?
> 
> The patch is for those applications compiled in 32 bit, but running on a 64 
> bit Linux
> kernels.  There is no 64 bit mana kernel driver available. So the kernel 
> still needs to be
> in 64 bit.
>>
>> My point is, instead of using compile time flag, what do you think to detect
>> execution platform on runtime and use preferred doorbell according platform?
>>
>> I can see short descriptor support touches multiple functions, can the 
>> support
>> be abstracted to let to use it based on runtime detection?
> 
> The 32 bit support request is from a specific customer who only has 32 bit 
> applications. 
> The customer needs to build and link its applications into 32bit libraries 
> and drivers. 
> Therefore, the DPDK mana driver needs to be in 32 bit anyway. 
> 
> 32bit applications cannot use 64bit doorbells. 64bit applications can use 
> 32bit doorbells,
> however the performance would suffer and it definitely not recommended. 
> 

OK, can you please add this detail to the commit log?

> IMHO, there is not much difference between compile time flag and 
> "if...then...else" statement
> at runtime, except for in the latter case, a few more extra runtime 
> instructions and maybe
> some branch overhead in either 64bit or 32bit case.  Given we have limited 
> 32bit use
> cases, I chose to just use the compile time flag, which seems to be simpler 
> to implement
> and less work for our verification team. 
> 

You are right, I was thinking it can help on deployment, but need to
compile separate binaries for 32bit and 64bit anyway, so not much gain.


>>
>>> Cc: sta...@dpdk.org
>>>
>>
>> Similar comment as previous patch, this patch is not a fix but adding new
>> support, not sure about backporting it.
>>
> The customer who needs 32bit support wants it to be on 22.11.x. That is why 
> I put "Cc: sta...@dpdk.org" in it.
> 
>>> Signed-off-by: Wei Hu <w...@microsoft.com>
>>>
>>
>> <...>
>>
>>> @@ -97,6 +110,7 @@ mana_alloc_and_post_rx_wqe(struct mana_rxq *rxq)
>>>             /* update queue for tracking pending packets */
>>>             desc->pkt = mbuf;
>>>             desc->wqe_size_in_bu = wqe_size_in_bu;
>>> +           rxq->wqe_cnt_to_short_db += wqe_size_in_bu;
>>>
>>
>> This variable always used within RTE_ARCH_32 block, but set here without
>> RTE_ARCH_32 ifdef, is this intentional?
> 
> No, it is not intentional. Thanks for pointing this out. I will add ifdef in 
> next
> round.
> 
> Thanks,
> Wei
> 

Reply via email to