summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2013-02-25 14:20:21 +0000
committerChandler Carruth <chandlerc@gmail.com>2013-02-25 14:20:21 +0000
commit05920b1847940da6e32d7574fba46b85b1d79c60 (patch)
treed55e8011e3308ad5ba302b170de587417f28ca90 /clang/lib/Sema
parentd0dfa07b44068f16c489601b74260d0cc6ca1275 (diff)
downloadbcm5719-llvm-05920b1847940da6e32d7574fba46b85b1d79c60.tar.gz
bcm5719-llvm-05920b1847940da6e32d7574fba46b85b1d79c60.zip
Fix the root cause of PR15348 by correctly handling alignment 0 on
memory intrinsics in the SDAG builder. When alignment is zero, the lang ref says that *no* alignment assumptions can be made. This is the exact opposite of the internal API contracts of the DAG where alignment 0 indicates that the alignment can be made to be anything desired. There is another, more explicit alignment that is better suited for the role of "no alignment at all": an alignment of 1. Map the intrinsic alignment to this early so that we don't end up generating aligned DAGs. It is really terrifying that we've never seen this before, but we suddenly started generating a large number of alignment 0 memcpys due to the new code to do memcpy-based copying of POD class members. That patch contains a bug that rounds bitfield alignments down when they are the first field. This can in turn produce zero alignments. This fixes weird crashes I've seen in library users of LLVM on 32-bit hosts, etc. llvm-svn: 176022
Diffstat (limited to 'clang/lib/Sema')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud