On 2020-05-13 10:57, Morten Brørup wrote:
>> From: Honnappa Nagarahalli [mailto:honnappa.nagaraha...@arm.com]
>> Sent: Tuesday, May 12, 2020 9:24 PM
>>
>> <snip>
>>
>> Subject: Re: [PATCH v4 4/4] eal/atomic: add wrapper for c11 atomics
>>
>> On Tue, May 12, 2020 at 4:03 pm, Phil Yang <mailto:phil.y...@arm.com>
>> wrote:
>>
>> parameter. Signed-off-by: Phil Yang <mailto:phil.y...@arm.com>
>>
>>
>> What is the purpose of having rte_atomic at all?
>> Is this level of indirection really helping?
>> [HONNAPPA] (not sure why this email has html format, converted to text
>> format)
>> I believe you meant, why not use the __atomic_xxx built-ins directly?
>> The only reason for now is handling of
>> __atomic_thread_fence(__ATOMIC_SEQ_CST) for x86. This is equivalent to
>> rte_smp_mb which has an optimized implementation for x86. According to
>> Konstantin, the compiler does not generate optimal code. Wrapping that
>> built-in alone is going to be confusing.
>>
>> The wrappers also allow us to have our own implementation using inline
>> assembly for compilers versions that do not support C11 atomic built-
>> ins. But, I do not know if there is a need to support those versions.
> If I recall correctly, someone mentioned that one (or more) of the aging 
> enterprise Linux distributions don't include a compiler with C11 atomics.
>
> I think Stephen is onto something here...
>
> It is silly to add wrappers like this, if the only purpose is to support 
> compilers and distributions that don't properly support an official C 
> standard which is nearly a decade old. The quality and quantity of the DPDK 
> documentation for these functions (including examples, discussions on Stack 
> Overflow, etc.) will be inferior to the documentation of the standard C11 
> atomics, which increases the probability of incorrect use.


What's being used in DPDK today, and what's being wrapped here, is not 
standard C11 atomics - it's a bunch of GCC built-ins. Nothing in the __ 
namespace is in the standard. It's reserved for the implementation (e.g. 
compiler).


> And if some compiler generates code that is suboptimal for a user, then it 
> should be the choice of the user to either accept it or use a better 
> compiler. Using a suboptimal compiler will not only affect the user's DPDK 
> applications, but all applications developed by the user. And if he accepts 
> it for his other applications, he will also accept it for his DPDK 
> applications.
>
> We could introduce some sort of marker or standardized comment to indicate 
> when functions only exist for backwards compatibility with ancient compilers 
> and similar, with a reference to documentation describing why. And when the 
> documented preconditions are no longer relevant, e.g. when those particular 
> enterprise Linux distributions become obsolete, these functions become 
> obsolete too, and should be removed. However, getting rid of obsolete cruft 
> will break the ABI. In other words: Added cruft will never be removed again, 
> so think twice before adding.
>
>
> Med venlig hilsen / kind regards
> - Morten Brørup
>
>
>

Reply via email to