Re: Fix gnu versioned namespace mode 00/03

2024-05-15 Thread François Dumont


On 13/05/2024 10:34, Jonathan Wakely wrote:



On Mon, 13 May 2024, 07:30 Iain Sandoe,  wrote:



> On 13 May 2024, at 06:06, François Dumont 
wrote:
>
>
> On 07/05/2024 18:15, Iain Sandoe wrote:
>> Hi François
>>
>>> On 4 May 2024, at 22:11, François Dumont
 wrote:
>>>
>>> Here is the list of patches to restore gnu versioned namespace
mode.
>>>
>>> 1/3: Bump gnu version namespace
>>>
>>> This is important to be done first so that once build of gnu
versioned namespace is fixed there is no chance to have another
build of '__8' version with a different abi than last successful
'__8' build.



The versioned namespace build is not expected to be ABI compatible 
though, so nobody should be expecting compatibility with previous 
builds. Especially not on the gcc-15 trunk, a week or two after 
entering stage 1!


Ok, I really thought that we needed to preserve ABI for a given version, 
'__8' at the moment.




>>>
>>> 2/3: Fix build using cxx11 abi for versioned namespace
>>>
>>> 3/3: Proposal to default to "new" abi when dual abi is
disabled and accept any default-libstdcxx-abi either dual abi is
enabled or not.
>>>
>>> All testsuite run for following configs:
>>>
>>> - dual abi
>>>
>>> - gcc4-compatible only abi
>>>
>>> - new only abi
>>>
>>> - versioned namespace abi
>> At the risk of delaying this (a bit) - I think we should also
consider items like once_call that have broken impls.
> Do you have any pointer to this once_call problem, sorry I'm not
aware about it (apart from your messages).

(although this mentions one specific target, it applies more widely).


I've removed the "on ppc64le" part from the summary.

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66146

Thanks for the ref, I'll have a look but I fear that I won't be of any 
help here.





Also, AFAICT, any nested once_call is a problem (not just exceptions).


Could you update the bug with that info please?


>>  in the current library - and at least get proposed
replacements available behind the versioned namespace; rather than
using up a namespace version with the current broken code.
>
> I'm not proposing to fix all library bugs on all platforms with
this patch, just fix the versioned namespace mode.

Sorry, I was not intending to suggest that (although perhaps my
comments read that way).

I was trying to suggest that, in the case where we have proposed
fixes that are blocked because they are ABI breaks, that those
could be put behind the versioned namspace (it was not an
intention to suggest that such additions should be part of this
patch series).

> As to do so I also need to adopt cxx11 abi in versioned mode it
already justify a bump of version.

I see - it’s just a bit strange that we are bumping a version for
a mode that does not currently work; however, i guess someone
might have deployed it even so.


It does work though, doesn't it?
It's known to fail on powerpc64 due to conflicts with the ieee128 
stuff, but it should work elsewhere.
It doesn't work with --with-default-libstdcxx-abi=cxx11 but that's 
just a "this doesn't work and isn't supported" limitation.


The point of the patch series is to change it so the versioned 
namespace always uses the cxx11 ABI, which does seem worth bumping the 
version (even though the versioned namespace is explicitly not a 
stable ABI and not backwards compatible).


So I just need to wait for proper review, right ?

This is what I plan to do on this subject for the moment.


Re: Fix gnu versioned namespace mode 00/03

2024-05-13 Thread Jonathan Wakely
On Mon, 13 May 2024, 07:30 Iain Sandoe,  wrote:

>
>
> > On 13 May 2024, at 06:06, François Dumont  wrote:
> >
> >
> > On 07/05/2024 18:15, Iain Sandoe wrote:
> >> Hi François
> >>
> >>> On 4 May 2024, at 22:11, François Dumont  wrote:
> >>>
> >>> Here is the list of patches to restore gnu versioned namespace mode.
> >>>
> >>> 1/3: Bump gnu version namespace
> >>>
> >>> This is important to be done first so that once build of gnu versioned
> namespace is fixed there is no chance to have another build of '__8'
> version with a different abi than last successful '__8' build.
>


The versioned namespace build is not expected to be ABI compatible though,
so nobody should be expecting compatibility with previous builds.
Especially not on the gcc-15 trunk, a week or two after entering stage 1!


> >>>
> >>> 2/3: Fix build using cxx11 abi for versioned namespace
> >>>
> >>> 3/3: Proposal to default to "new" abi when dual abi is disabled and
> accept any default-libstdcxx-abi either dual abi is enabled or not.
> >>>
> >>> All testsuite run for following configs:
> >>>
> >>> - dual abi
> >>>
> >>> - gcc4-compatible only abi
> >>>
> >>> - new only abi
> >>>
> >>> - versioned namespace abi
> >> At the risk of delaying this (a bit) - I think we should also consider
> items like once_call that have broken impls.
> > Do you have any pointer to this once_call problem, sorry I'm not aware
> about it (apart from your messages).
>
> (although this mentions one specific target, it applies more widely).
>

I've removed the "on ppc64le" part from the summary.

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66146
>
> Also, AFAICT, any nested once_call is a problem (not just exceptions).
>

Could you update the bug with that info please?


> >>  in the current library - and at least get proposed replacements
> available behind the versioned namespace; rather than using up a namespace
> version with the current broken code.
> >
> > I'm not proposing to fix all library bugs on all platforms with this
> patch, just fix the versioned namespace mode.
>
> Sorry, I was not intending to suggest that (although perhaps my comments
> read that way).
>
> I was trying to suggest that, in the case where we have proposed fixes
> that are blocked because they are ABI breaks, that those could be put
> behind the versioned namspace (it was not an intention to suggest that such
> additions should be part of this patch series).
>
> > As to do so I also need to adopt cxx11 abi in versioned mode it already
> justify a bump of version.
>
> I see - it’s just a bit strange that we are bumping a version for a mode
> that does not currently work;  however, i guess someone might have deployed
> it even so.
>

It does work though, doesn't it?
It's known to fail on powerpc64 due to conflicts with the ieee128 stuff,
but it should work elsewhere.
It doesn't work with --with-default-libstdcxx-abi=cxx11 but that's just a
"this doesn't work and isn't supported" limitation.

The point of the patch series is to change it so the versioned namespace
always uses the cxx11 ABI, which does seem worth bumping the version (even
though the versioned namespace is explicitly not a stable ABI and not
backwards compatible).


>
> > The reason I'm proposing to integrate this patch this early in gcc 15
> stage is to have time to integrate any other library fix/optimization that
> could make use of it. I already have 1 on my side for the hashtable
> implementation
>
> Ah, then I think we are aiming for the same thing.
>
> > . I hope your once_call fix also have time to be ready for gcc 15, no ?
>
> Yes; if we put it behind the versioned namespace - there are (I think)
> several proposed solutions to that specific issue.
>
> thanks
> Iain
>
> >
> > François
>
>


Re: Fix gnu versioned namespace mode 00/03

2024-05-13 Thread Iain Sandoe



> On 13 May 2024, at 06:06, François Dumont  wrote:
> 
> 
> On 07/05/2024 18:15, Iain Sandoe wrote:
>> Hi François
>> 
>>> On 4 May 2024, at 22:11, François Dumont  wrote:
>>> 
>>> Here is the list of patches to restore gnu versioned namespace mode.
>>> 
>>> 1/3: Bump gnu version namespace
>>> 
>>> This is important to be done first so that once build of gnu versioned 
>>> namespace is fixed there is no chance to have another build of '__8' 
>>> version with a different abi than last successful '__8' build.
>>> 
>>> 2/3: Fix build using cxx11 abi for versioned namespace
>>> 
>>> 3/3: Proposal to default to "new" abi when dual abi is disabled and accept 
>>> any default-libstdcxx-abi either dual abi is enabled or not.
>>> 
>>> All testsuite run for following configs:
>>> 
>>> - dual abi
>>> 
>>> - gcc4-compatible only abi
>>> 
>>> - new only abi
>>> 
>>> - versioned namespace abi
>> At the risk of delaying this (a bit) - I think we should also consider items 
>> like once_call that have broken impls.
> Do you have any pointer to this once_call problem, sorry I'm not aware about 
> it (apart from your messages).

(although this mentions one specific target, it applies more widely).
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66146

Also, AFAICT, any nested once_call is a problem (not just exceptions).

>>  in the current library - and at least get proposed replacements available 
>> behind the versioned namespace; rather than using up a namespace version 
>> with the current broken code.
> 
> I'm not proposing to fix all library bugs on all platforms with this patch, 
> just fix the versioned namespace mode.

Sorry, I was not intending to suggest that (although perhaps my comments read 
that way).

I was trying to suggest that, in the case where we have proposed fixes that are 
blocked because they are ABI breaks, that those could be put behind the 
versioned namspace (it was not an intention to suggest that such additions 
should be part of this patch series).

> As to do so I also need to adopt cxx11 abi in versioned mode it already 
> justify a bump of version.

I see - it’s just a bit strange that we are bumping a version for a mode that 
does not currently work;  however, i guess someone might have deployed it even 
so.
> 
> The reason I'm proposing to integrate this patch this early in gcc 15 stage 
> is to have time to integrate any other library fix/optimization that could 
> make use of it. I already have 1 on my side for the hashtable implementation

Ah, then I think we are aiming for the same thing.

> . I hope your once_call fix also have time to be ready for gcc 15, no ?

Yes; if we put it behind the versioned namespace - there are (I think) several 
proposed solutions to that specific issue.

thanks
Iain

> 
> François



Re: Fix gnu versioned namespace mode 00/03

2024-05-12 Thread François Dumont



On 07/05/2024 18:15, Iain Sandoe wrote:

Hi François


On 4 May 2024, at 22:11, François Dumont  wrote:

Here is the list of patches to restore gnu versioned namespace mode.

1/3: Bump gnu version namespace

This is important to be done first so that once build of gnu versioned 
namespace is fixed there is no chance to have another build of '__8' version 
with a different abi than last successful '__8' build.

2/3: Fix build using cxx11 abi for versioned namespace

3/3: Proposal to default to "new" abi when dual abi is disabled and accept any 
default-libstdcxx-abi either dual abi is enabled or not.

All testsuite run for following configs:

- dual abi

- gcc4-compatible only abi

- new only abi

- versioned namespace abi

At the risk of delaying this (a bit) - I think we should also consider items 
like once_call that have broken impls.
Do you have any pointer to this once_call problem, sorry I'm not aware 
about it (apart from your messages).

  in the current library - and at least get proposed replacements available 
behind the versioned namespace; rather than using up a namespace version with 
the current broken code.


I'm not proposing to fix all library bugs on all platforms with this 
patch, just fix the versioned namespace mode.


As to do so I also need to adopt cxx11 abi in versioned mode it already 
justify a bump of version.




I have a proposed once_call replacement (but I think Jonathan also has one or 
more alternatives there)

Please can we try to identify any other similar blocked fixes?


How ? We can only count on bugzilla bug reports to do so, no ?

If we face another similar problem in the future, after gcc 15 release, 
then we'll just have to bump again. Is it such a problem ?


The reason I'm proposing to integrate this patch this early in gcc 15 
stage is to have time to integrate any other library fix/optimization 
that could make use of it. I already have 1 on my side for the hashtable 
implementation. I hope your once_call fix also have time to be ready for 
gcc 15, no ?


François



Re: Fix gnu versioned namespace mode 00/03

2024-05-07 Thread Iain Sandoe
Hi François

> On 4 May 2024, at 22:11, François Dumont  wrote:
> 
> Here is the list of patches to restore gnu versioned namespace mode.
> 
> 1/3: Bump gnu version namespace
> 
> This is important to be done first so that once build of gnu versioned 
> namespace is fixed there is no chance to have another build of '__8' version 
> with a different abi than last successful '__8' build.
> 
> 2/3: Fix build using cxx11 abi for versioned namespace
> 
> 3/3: Proposal to default to "new" abi when dual abi is disabled and accept 
> any default-libstdcxx-abi either dual abi is enabled or not.
> 
> All testsuite run for following configs:
> 
> - dual abi
> 
> - gcc4-compatible only abi
> 
> - new only abi
> 
> - versioned namespace abi

At the risk of delaying this (a bit) - I think we should also consider items 
like once_call that have broken impls. in the current library - and at least 
get proposed replacements available behind the versioned namespace; rather than 
using up a namespace version with the current broken code.

I have a proposed once_call replacement (but I think Jonathan also has one or 
more alternatives there)

Please can we try to identify any other similar blocked fixes?

Iain



Fix gnu versioned namespace mode 00/03

2024-05-04 Thread François Dumont

Here is the list of patches to restore gnu versioned namespace mode.

1/3: Bump gnu version namespace

This is important to be done first so that once build of gnu versioned 
namespace is fixed there is no chance to have another build of '__8' 
version with a different abi than last successful '__8' build.


2/3: Fix build using cxx11 abi for versioned namespace

3/3: Proposal to default to "new" abi when dual abi is disabled and 
accept any default-libstdcxx-abi either dual abi is enabled or not.


All testsuite run for following configs:

- dual abi

- gcc4-compatible only abi

- new only abi

- versioned namespace abi

François