forked from OSchip/llvm-project
From his comment in PR12168, Eli seems confused about the alignment assumptions
we're making. We only ignore implicit casts. Add a testcase showing that we get the right behavior with explicit casts. llvm-svn: 151994
This commit is contained in:
parent
aaa18fad7d
commit
332673d39d
|
@ -52,9 +52,13 @@ int test6(char *X) {
|
||||||
// CHECK: @test7
|
// CHECK: @test7
|
||||||
// PR12094
|
// PR12094
|
||||||
int test7(int *p) {
|
int test7(int *p) {
|
||||||
|
struct snd_pcm_hw_params_t* hwparams; // incomplete type.
|
||||||
|
|
||||||
// CHECK: call void @llvm.memset{{.*}}256, i32 4, i1 false)
|
// CHECK: call void @llvm.memset{{.*}}256, i32 4, i1 false)
|
||||||
__builtin_memset(p, 0, 256); // Should be alignment = 4
|
__builtin_memset(p, 0, 256); // Should be alignment = 4
|
||||||
struct snd_pcm_hw_params_t* hwparams; // incomplete type.
|
|
||||||
|
// CHECK: call void @llvm.memset{{.*}}256, i32 1, i1 false)
|
||||||
|
__builtin_memset((char*)p, 0, 256); // Should be alignment = 1
|
||||||
|
|
||||||
__builtin_memset(hwparams, 0, 256); // No crash alignment = 1
|
__builtin_memset(hwparams, 0, 256); // No crash alignment = 1
|
||||||
// CHECK: call void @llvm.memset{{.*}}256, i32 1, i1 false)
|
// CHECK: call void @llvm.memset{{.*}}256, i32 1, i1 false)
|
||||||
|
|
Loading…
Reference in New Issue