• Michael Cree's avatar
    Bug#822848: mpd FTBFS on Alpha; misaligned arrays in the test suite · 72637d00
    Michael Cree authored
    Source: mpd
    Version: 0.19.14-2
    Severity: important
    Justification: fails to build form source (but built in the past)
    Tags: patch
    User: debian-alpha@lists.debian.org
    Usertags: alpha
    
    mpd FTBFS on Alpha with a failure in the test suite [1]:
    
    FAIL: test/test_byte_reverse
    ============================
    
    .F...
    
    !!!FAILURES!!!
    Test Results:
    Run:  4   Failures: 1   Errors: 0
    
    1) test: ByteReverseTest::TestByteReverse2 (F) line: 58 test/test_byte_reverse.cxx
    assertion failed
    - Expression: strcmp(result, (const char *)dest) == 0
    
    This occurs because the test suite (in test/test_byte_reversal.cxx)
    allocates static char arrays and passes the char arrays to functions
    whose respective arguments were declared to be uint16_t *, etc., in
    the main code.
    
    This is in the realm of undefined behaviour on architectures with
    strict memory alignment requirements.  Although the test only fails
    on Alpha (because Alpha has a particular CPU load instruction that
    gcc likes to use to add bugs ..., ahem,  optimise the code on the
    assumption of alignment) it is potentially a latent bug for other
    architectures with strict alignment requirements.
    
    Since the code is compiled with the c++11 standard I attach a patch
    that modifies the test suite to align the non-compliant strings with
    the alignas() attribute.  The test suite now passes on Alpha with
    that patch.
    
    Cheers
    Michael
    
    [1] https://buildd.debian.org/status/fetch.php?pkg=mpd&arch=alpha&ver=0.19.14-2&stamp=1461542099
    72637d00
Name
Last commit
Last update
..
.gitignore Loading commit data...
DumpDatabase.cxx Loading commit data...
FakeDecoderAPI.cxx Loading commit data...
FakeDecoderAPI.hxx Loading commit data...
FakeReplayGainConfig.cxx Loading commit data...
ScopeIOThread.hxx Loading commit data...
ShutdownHandler.cxx Loading commit data...
ShutdownHandler.hxx Loading commit data...
TestCircularBuffer.hxx Loading commit data...
dump_playlist.cxx Loading commit data...
dump_rva2.cxx Loading commit data...
dump_text_file.cxx Loading commit data...
read_conf.cxx Loading commit data...
read_mixer.cxx Loading commit data...
read_tags.cxx Loading commit data...
run_avahi.cxx Loading commit data...
run_convert.cxx Loading commit data...
run_decoder.cxx Loading commit data...
run_encoder.cxx Loading commit data...
run_filter.cxx Loading commit data...
run_gunzip.cxx Loading commit data...
run_gzip.cxx Loading commit data...
run_inotify.cxx Loading commit data...
run_input.cxx Loading commit data...
run_neighbor_explorer.cxx Loading commit data...
run_normalize.cxx Loading commit data...
run_output.cxx Loading commit data...
run_resolver.cxx Loading commit data...
run_storage.cxx Loading commit data...
software_volume.cxx Loading commit data...
stdbin.h Loading commit data...
test_archive.cxx Loading commit data...
test_archive_bzip2.sh Loading commit data...
test_archive_iso9660.sh Loading commit data...
test_archive_zzip.sh Loading commit data...
test_byte_reverse.cxx Loading commit data...
test_icy_parser.cxx Loading commit data...
test_mixramp.cxx Loading commit data...
test_pcm_all.hxx Loading commit data...
test_pcm_channels.cxx Loading commit data...
test_pcm_dither.cxx Loading commit data...
test_pcm_export.cxx Loading commit data...
test_pcm_format.cxx Loading commit data...
test_pcm_main.cxx Loading commit data...
test_pcm_mix.cxx Loading commit data...
test_pcm_pack.cxx Loading commit data...
test_pcm_util.hxx Loading commit data...
test_pcm_volume.cxx Loading commit data...
test_protocol.cxx Loading commit data...
test_queue_priority.cxx Loading commit data...
test_rewind.cxx Loading commit data...
test_translate_song.cxx Loading commit data...
test_util.cxx Loading commit data...
test_vorbis_encoder.cxx Loading commit data...
visit_archive.cxx Loading commit data...