On 29/06/18 09:39 +0200, Christophe Lyon wrote:
On Fri, 29 Jun 2018 at 09:21, Jonathan Wakely <jwak...@redhat.com> wrote:

On 29/06/18 08:55 +0200, Christophe Lyon wrote:
>On Mon, 25 Jun 2018 at 18:23, Jonathan Wakely <jwak...@redhat.com> wrote:
>>
>> The additions to <experimental/random> were added in 2015 but the new
>> algorithms in <experimental/algorithm> were not. This adds them.
>>
>>         * include/experimental/algorithm (sample, shuffle): Add new overloads
>>         using per-thread random number engine.
>>         * testsuite/experimental/algorithm/sample.cc: Simpify and reduce
>>         dependencies by using __gnu_test::test_container.
>>         * testsuite/experimental/algorithm/sample-2.cc: New.
>>         * testsuite/experimental/algorithm/shuffle.cc: New.
>>
>> Tested x86_64-linux, committed to trunk.
>>
>> This would be safe to backport, but nobody has noticed the algos are
>> missing or complained, so it doesn't seem very important to backport.
>>
>>
>
>Hi,
>
>On bare-metal targets (aarch64 and arm + newlib), I've noticed that
>the two new tests fail:
>PASS: experimental/algorithm/shuffle.cc (test for excess errors)
>spawn 
/aci-gcc-fsf/builds/gcc-fsf-gccsrc/obj-arm-none-eabi/gcc3/utils/bin/qemu-wrapper.sh
>./shuffle.exe
>terminate called after throwing an instance of 'std::runtime_error'
>  what():  random_device::random_device(const std::string&)
>
>*** EXIT code 4242
>FAIL: experimental/algorithm/shuffle.cc execution test
>
>PASS: experimental/algorithm/sample-2.cc (test for excess errors)
>spawn 
/aci-gcc-fsf/builds/gcc-fsf-gccsrc/obj-arm-none-eabi/gcc3/utils/bin/qemu-wrapper.sh
>./sample-2.exe
>terminate called after throwing an instance of 'std::runtime_error'
>  what():  random_device::random_device(const std::string&)
>
>*** EXIT code 4242
>FAIL: experimental/algorithm/sample-2.cc execution test
>
>Does this ring a bell?

Does the existing testsuite/experimental/random/randint.cc file fail
in the same way?


Yes it does.

And so do:
25_algorithms/make_heap/complexity.cc

This one also uses std::random_device.

23_containers/array/element_access/at_neg.cc

Hmm,

 // Expected behavior is to either throw and have the uncaught
 // exception end up in a terminate handler which eventually exits,
 // or abort. (Depending on -fno-exceptions.)

So this is expected to XFAIL.

26_numerics/random/random_device/cons/default.cc

We should XFAIL the ones that use std::random_device, if we can
identify an effective target to describe them.


Reply via email to