C++ exceptions: pthread key allocation error for __gthread_key_create

Sebastian Huber sebastian.huber at embedded-brains.de
Tue Dec 6 07:32:44 UTC 2016



On 06/12/16 08:02, Sebastian Huber wrote:
>
>
> On 06/12/16 01:25, Chris Johns wrote:
>> On 05/12/2016 18:19, Sebastian Huber wrote:
>>> On 05/12/16 07:57, Chris Johns wrote:
>>>> Is it the user who needs to account for the gthread key if using C++?
>>>
>>> Yes, its up to the user to ensure that there are enough POSIX keys
>>> available. This is quite a pain.
>>
>> It is also error prone and silent and this is a real concern because 
>> it exposed very real issues if not correctly configured. The 
>> libstdc++ is fragile in this regard.
>>
>>>
>>> Why is no TLS value used (instead of the POSIX key)?
>>>
>>
>> I do not know. It is wrapped by our gthread wrapper.
>
> It seems libstdc++ still uses POSIX keys in case it needs a destructor.
>
>>
>>> It would be possible to make the pthread_key_t self-contained, however,
>>> for the thread-specific value you need some system provided storage
>>> (currently the workspace).
>>
>> I do not know what this means.
>
> The problem is that all storage for POSIX keys is currently system 
> provided. Since it uses the workspace, the configuration must account 
> for libstdc++ resources.
>
> If we could change it to use only user provided storage, then we 
> wouldn't have to deal with the configuration.
>

https://devel.rtems.org/ticket/2831

-- 
Sebastian Huber, embedded brains GmbH

Address : Dornierstr. 4, D-82178 Puchheim, Germany
Phone   : +49 89 189 47 41-16
Fax     : +49 89 189 47 41-09
E-Mail  : sebastian.huber at embedded-brains.de
PGP     : Public key available on request.

Diese Nachricht ist keine geschäftliche Mitteilung im Sinne des EHUG.



More information about the devel mailing list