#
3d68ce90 |
| 05-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
[CodeGen] Unify generation of scalar and struct-path TBAA tags
This patch makes it possible to produce access tags in a uniform manner regardless whether the resulting tag will be a scalar or a stru
[CodeGen] Unify generation of scalar and struct-path TBAA tags
This patch makes it possible to produce access tags in a uniform manner regardless whether the resulting tag will be a scalar or a struct-path one. getAccessTagInfo() now takes care of the actual translation of access descriptors to tags and can handle all kinds of accesses. Facilities that specific to scalar accesses are eliminated.
Some more details: * DecorateInstructionWithTBAA() is not responsible for conversion of types to access tags anymore. Instead, it takes an access descriptor (TBAAAccessInfo) and generates corresponding access tag from it. * getTBAAInfoForVTablePtr() reworked to getTBAAVTablePtrAccessInfo() that now returns the virtual-pointer access descriptor and not the virtual-point type metadata. * Added function getTBAAMayAliasAccessInfo() that returns the descriptor for may-alias accesses. * getTBAAStructTagInfo() renamed to getTBAAAccessTagInfo() as now it is the only way to generate access tag by a given access descriptor. It is capable of producing both scalar and struct-path tags, depending on options and availability of the base access type. getTBAAScalarTagInfo() and its cache ScalarTagMetadataCache are eliminated. * Now that we do not need to care about whether the resulting access tag should be a scalar or struct-path one, getTBAAStructTypeInfo() is renamed to getBaseTypeInfo(). * Added function getTBAAAccessInfo() that constructs access descriptor by a given QualType access type.
This is part of D37826 reworked to be a separate patch to simplify review.
Differential Revision: https://reviews.llvm.org/D38503
llvm-svn: 314979
show more ...
|
#
afc074cc |
| 05-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
Revert r314977 "[CodeGen] Unify generation of scalar and struct-path TBAA tags"
D37826 has been mistakenly committed where it should be the patch from D38503.
Differential Revision: https://reviews
Revert r314977 "[CodeGen] Unify generation of scalar and struct-path TBAA tags"
D37826 has been mistakenly committed where it should be the patch from D38503.
Differential Revision: https://reviews.llvm.org/D38503
llvm-svn: 314978
show more ...
|
#
6fa20cfe |
| 05-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
[CodeGen] Unify generation of scalar and struct-path TBAA tags
This patch makes it possible to produce access tags in a uniform manner regardless whether the resulting tag will be a scalar or a stru
[CodeGen] Unify generation of scalar and struct-path TBAA tags
This patch makes it possible to produce access tags in a uniform manner regardless whether the resulting tag will be a scalar or a struct-path one. getAccessTagInfo() now takes care of the actual translation of access descriptors to tags and can handle all kinds of accesses. Facilities that specific to scalar accesses are eliminated.
Some more details: * DecorateInstructionWithTBAA() is not responsible for conversion of types to access tags anymore. Instead, it takes an access descriptor (TBAAAccessInfo) and generates corresponding access tag from it. * getTBAAInfoForVTablePtr() reworked to getTBAAVTablePtrAccessInfo() that now returns the virtual-pointer access descriptor and not the virtual-point type metadata. * Added function getTBAAMayAliasAccessInfo() that returns the descriptor for may-alias accesses. * getTBAAStructTagInfo() renamed to getTBAAAccessTagInfo() as now it is the only way to generate access tag by a given access descriptor. It is capable of producing both scalar and struct-path tags, depending on options and availability of the base access type. getTBAAScalarTagInfo() and its cache ScalarTagMetadataCache are eliminated. * Now that we do not need to care about whether the resulting access tag should be a scalar or struct-path one, getTBAAStructTypeInfo() is renamed to getBaseTypeInfo(). * Added function getTBAAAccessInfo() that constructs access descriptor by a given QualType access type.
This is part of D37826 reworked to be a separate patch to simplify review.
Differential Revision: https://reviews.llvm.org/D38503
llvm-svn: 314977
show more ...
|
#
a511ed75 |
| 03-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
[CodeGen] Introduce generic TBAA access descriptors
With this patch we implement a concept of TBAA access descriptors that are capable of representing both scalar and struct-path accesses in a gener
[CodeGen] Introduce generic TBAA access descriptors
With this patch we implement a concept of TBAA access descriptors that are capable of representing both scalar and struct-path accesses in a generic way.
This is part of D37826 reworked to be a separate patch to simplify review.
Differential Revision: https://reviews.llvm.org/D38456
llvm-svn: 314780
show more ...
|
#
5c8e7596 |
| 02-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
[CodeGen] Have a special function to get TBAA info for may-alias accesses
This is part of D37826 reworked to be a separate patch to simplify review.
Differential Revision: https://reviews.llvm.org/
[CodeGen] Have a special function to get TBAA info for may-alias accesses
This is part of D37826 reworked to be a separate patch to simplify review.
Differential Revision: https://reviews.llvm.org/D38408
llvm-svn: 314660
show more ...
|
#
289574ed |
| 02-Oct-2017 |
Ivan A. Kosarev <ikosarev@accesssoftek.com> |
[CodeGen] Do not refer to complete TBAA info where we actually deal with just TBAA access types
This patch fixes misleading names of entities related to getting, setting and generation of TBAA acces
[CodeGen] Do not refer to complete TBAA info where we actually deal with just TBAA access types
This patch fixes misleading names of entities related to getting, setting and generation of TBAA access type descriptors.
This is effectively an attempt to provide a review for D37826 by breaking it into smaller pieces.
Differential Revision: https://reviews.llvm.org/D38404
llvm-svn: 314657
show more ...
|
#
99fdfb6a |
| 26-Sep-2017 |
Erich Keane <erich.keane@intel.com> |
Emit section information for extern variables.
Currently, if _attribute_((section())) is used for extern variables, section information is not emitted in generated IR when the variables are used.
Emit section information for extern variables.
Currently, if _attribute_((section())) is used for extern variables, section information is not emitted in generated IR when the variables are used. This is expected since sections are not generated for external linkage objects. However NiosII requires this information as it uses special GP-relative accesses for any objects that use attribute section (.sdata). GCC keeps this attribute in middle-end.
This change emits the section information for all targets.
Patch By: Elizabeth Andrews
Differential Revision:https://reviews.llvm.org/D36487
llvm-svn: 314262
show more ...
|
#
bffc1bb2 |
| 26-Sep-2017 |
Matthias Braun <matze@braunis.de> |
CodeGenModule: Adapt to LLVM TargetLibraryInfo changes
Adapt to LLVM TargetLibraryInfo changes in r314185.
See also https://reviews.llvm.org/D38106 and https://reviews.llvm.org/D37891
llvm-svn: 31
CodeGenModule: Adapt to LLVM TargetLibraryInfo changes
Adapt to LLVM TargetLibraryInfo changes in r314185.
See also https://reviews.llvm.org/D38106 and https://reviews.llvm.org/D37891
llvm-svn: 314187
show more ...
|
#
2eccdab3 |
| 25-Sep-2017 |
Vlad Tsyrklevich <vlad@tsyrklevich.net> |
Allow specifying sanitizers in blacklists
Summary: This is the follow-up patch to D37924.
This change refactors clang to use the the newly added section headers in SpecialCaseList to specify which
Allow specifying sanitizers in blacklists
Summary: This is the follow-up patch to D37924.
This change refactors clang to use the the newly added section headers in SpecialCaseList to specify which sanitizers blacklists entries should apply to, like so:
[cfi-vcall] fun:*bad_vcall* [cfi-derived-cast|cfi-unrelated-cast] fun:*bad_cast*
The SanitizerSpecialCaseList class has been added to allow querying by SanitizerMask, and SanitizerBlacklist and its downstream users have been updated to provide that information. Old blacklists not using sections will continue to function identically since the blacklist entries will be placed into a '[*]' section by default matching against all sanitizers.
Reviewers: pcc, kcc, eugenis, vsk
Reviewed By: eugenis
Subscribers: dberris, cfe-commits, mgorny
Differential Revision: https://reviews.llvm.org/D37925
llvm-svn: 314171
show more ...
|
#
0acf3434 |
| 22-Sep-2017 |
Vedant Kumar <vsk@apple.com> |
[Coverage] Add an option to emit limited coverage info
Add an option to emit limited coverage info for unused decls. It's just a cl::opt for now to allow us to experiment quickly.
When building llc
[Coverage] Add an option to emit limited coverage info
Add an option to emit limited coverage info for unused decls. It's just a cl::opt for now to allow us to experiment quickly.
When building llc, this results in an 84% size reduction in the llvm_covmap section, and a similar size reduction in the llvm_prf_names section. In practice I expect the size reduction to be roughly quadratic with the size of the program.
The downside is that coverage for headers will no longer be complete. This will make the line/function/region coverage metrics incorrect, since they will be artificially high. One mitigation would be to somehow disable those metrics when using limited-coverage=true.
This is related to: llvm.org/PR34533 (make SourceBasedCodeCoverage scale)
Differential Revision: https://reviews.llvm.org/D38107
llvm-svn: 314002
show more ...
|
#
c6c9b8fa |
| 11-Sep-2017 |
Bob Haarman <llvm@inglorion.net> |
[codeview] omit debug locations for nested exprs unless column info enabled
Summary: Microsoft Visual Studio expects debug locations to correspond to statements. We used to emit locations for expres
[codeview] omit debug locations for nested exprs unless column info enabled
Summary: Microsoft Visual Studio expects debug locations to correspond to statements. We used to emit locations for expressions nested inside statements. This would confuse the debugger, causing it to stop multiple times on the same line and breaking the "step into specific" feature. This change inhibits the emission of debug locations for nested expressions when emitting CodeView debug information, unless column information is enabled.
Fixes PR34312.
Reviewers: rnk, zturner
Reviewed By: rnk
Subscribers: majnemer, echristo, aprantl, cfe-commits
Differential Revision: https://reviews.llvm.org/D37529
llvm-svn: 312965
show more ...
|
#
7cb1b304 |
| 05-Sep-2017 |
Mehdi Amini <joker.eph@gmail.com> |
Emit static constexpr member as available_externally definition
By exposing the constant initializer, the optimizer can fold many of these constructs.
This is a recommit of r311857 that was reverte
Emit static constexpr member as available_externally definition
By exposing the constant initializer, the optimizer can fold many of these constructs.
This is a recommit of r311857 that was reverted in r311898 because an assert was hit when building Chromium. We have to take into account that the GlobalVariable may be first created with a different type than the initializer. This can happen for example when the variable is a struct with tail padding while the initializer does not have padding. In such case, the variable needs to be destroyed an replaced with a new one with the type of the initializer.
Differential Revision: https://reviews.llvm.org/D34992
llvm-svn: 312512
show more ...
|
Revision tags: llvmorg-5.0.0, llvmorg-5.0.0-rc5, llvmorg-5.0.0-rc4 |
|
#
edd66ab9 |
| 28-Aug-2017 |
Hans Wennborg <hans@hanshq.net> |
Revert r311857 "Emit static constexpr member as available_externally definition"
It caused PR759744.
> Emit static constexpr member as available_externally definition > > By exposing the constant i
Revert r311857 "Emit static constexpr member as available_externally definition"
It caused PR759744.
> Emit static constexpr member as available_externally definition > > By exposing the constant initializer, the optimizer can fold many > of these constructs. > > Differential Revision: https://reviews.llvm.org/D34992
llvm-svn: 311898
show more ...
|
#
f2384760 |
| 27-Aug-2017 |
Mehdi Amini <joker.eph@gmail.com> |
Emit static constexpr member as available_externally definition
By exposing the constant initializer, the optimizer can fold many of these constructs.
Differential Revision: https://reviews.llvm.or
Emit static constexpr member as available_externally definition
By exposing the constant initializer, the optimizer can fold many of these constructs.
Differential Revision: https://reviews.llvm.org/D34992
llvm-svn: 311857
show more ...
|
Revision tags: llvmorg-5.0.0-rc3 |
|
#
de0fe07e |
| 15-Aug-2017 |
John McCall <rjmccall@apple.com> |
Extract IRGen's constant-emitter into its own helper class and clean up the interface.
The ultimate goal here is to make it easier to do some more interesting things in constant emission, like emit
Extract IRGen's constant-emitter into its own helper class and clean up the interface.
The ultimate goal here is to make it easier to do some more interesting things in constant emission, like emit constant initializers that have ignorable side-effects, or doing the majority of an initialization in-place and then patching up the last few things with calls. But for now this is mostly just a refactoring.
llvm-svn: 310964
show more ...
|
#
efb4d4c7 |
| 15-Aug-2017 |
Sven van Haastregt <sven.vanhaastregt@arm.com> |
[OpenCL] Allow targets to select address space per type
Generalize getOpenCLImageAddrSpace into getOpenCLTypeAddrSpace, such that targets can select the address space per type.
No functional change
[OpenCL] Allow targets to select address space per type
Generalize getOpenCLImageAddrSpace into getOpenCLTypeAddrSpace, such that targets can select the address space per type.
No functional changes intended.
Initial patch by Simon Perretta.
Differential Revision: https://reviews.llvm.org/D33989
llvm-svn: 310911
show more ...
|
Revision tags: llvmorg-5.0.0-rc2 |
|
#
b7b82505 |
| 30-Jul-2017 |
NAKAMURA Takumi <geek4civic@gmail.com> |
CodeGenModule.cpp: [PR33810][Modules] Remove an assertion that confirms MangledDeclNames[CanonicalGD] might be still empty.
FIXME: It is accepted that MangledDeclNames[CanonicalGD] is overwritten he
CodeGenModule.cpp: [PR33810][Modules] Remove an assertion that confirms MangledDeclNames[CanonicalGD] might be still empty.
FIXME: It is accepted that MangledDeclNames[CanonicalGD] is overwritten here? llvm-svn: 309504
show more ...
|
#
6e4d774b |
| 30-Jul-2017 |
NAKAMURA Takumi <geek4civic@gmail.com> |
CodeGenModule.cpp: [PR33810][Modules] Avoid reusing FoundStr to try to fix crash.
MangledDeclNames might grow up and be reallocated when it were reused by reentering CodeGenModule::getMangledName().
CodeGenModule.cpp: [PR33810][Modules] Avoid reusing FoundStr to try to fix crash.
MangledDeclNames might grow up and be reallocated when it were reused by reentering CodeGenModule::getMangledName().
llvm-svn: 309501
show more ...
|
#
c9220039 |
| 30-Jul-2017 |
NAKAMURA Takumi <geek4civic@gmail.com> |
CodeGenModule.cpp: [PR33810][Modules] Make sure actual memory corruption before random crash with -fmodules.
llvm-svn: 309499
|
Revision tags: llvmorg-5.0.0-rc1 |
|
#
1a116db1 |
| 20-Jul-2017 |
Simon Atanasyan <simon@atanasyan.com> |
[CodeGen][mips] Support `long_call/far/near` attributes
This patch adds support for the `long_call`, `far`, and `near` attributes for MIPS targets. The `long_call` and `far` attributes are synonyms.
[CodeGen][mips] Support `long_call/far/near` attributes
This patch adds support for the `long_call`, `far`, and `near` attributes for MIPS targets. The `long_call` and `far` attributes are synonyms. All these attributes override `-mlong-calls` / `-mno-long-calls` command line options for particular function.
Differential revision: https://reviews.llvm.org/D35479
llvm-svn: 308667
show more ...
|
#
b0d4423b |
| 18-Jul-2017 |
Erich Keane <erich.keane@intel.com> |
Convert attribute 'target' parsing from a 'pair' to a 'struct' to make further improvements easier
Convert attribute 'target' parsing from a 'pair' to a 'struct' to make further improvements easie
Convert attribute 'target' parsing from a 'pair' to a 'struct' to make further improvements easier
Convert attribute 'target' parsing from a 'pair' to a 'struct' to make further improvements easier
The attribute 'target' parse function previously returned a pair. Convert this to a 'pair' in order to add more functionality, and improve usability.
Differential Revision: https://reviews.llvm.org/D35574
llvm-svn: 308357
show more ...
|
#
7bce6424 |
| 08-Jul-2017 |
Yaxun Liu <Yaxun.Liu@amd.com> |
Fix build failure with gcc about mixing enum and non-enum
llvm-svn: 307483
|
#
6fbfdec5 |
| 08-Jul-2017 |
Benjamin Kramer <benny.kra@googlemail.com> |
[CodeGen] Fold variable into assert.
Avoids warnings in Release builds.
llvm-svn: 307472
|
#
cbf647cc |
| 08-Jul-2017 |
Yaxun Liu <Yaxun.Liu@amd.com> |
CodeGen: Fix address space of global variable
Certain targets (e.g. amdgcn) require global variable to stay in global or constant address space. In C or C++ global variables are emitted in the defau
CodeGen: Fix address space of global variable
Certain targets (e.g. amdgcn) require global variable to stay in global or constant address space. In C or C++ global variables are emitted in the default (generic) address space. This patch introduces virtual functions TargetCodeGenInfo::getGlobalVarAddressSpace and TargetInfo::getConstantAddressSpace to handle this in a general approach.
It only affects IR generated for amdgcn target.
Differential Revision: https://reviews.llvm.org/D33842
llvm-svn: 307470
show more ...
|
#
1283e986 |
| 07-Jul-2017 |
Richard Smith <richard-llvm@metafoo.co.uk> |
[modules ts] Basic for module linkage.
In addition to the formal linkage rules, the Modules TS includes cases where internal-linkage symbols within a module interface unit can be referenced from out
[modules ts] Basic for module linkage.
In addition to the formal linkage rules, the Modules TS includes cases where internal-linkage symbols within a module interface unit can be referenced from outside the module via exported inline functions / templates. We give such declarations "module-internal linkage", which is formally internal linkage, but results in an externally-visible symbol.
llvm-svn: 307434
show more ...
|