
This is uncommon, but it does happen if the source pointer is a bitcast of a global. For example, if a struct is cast to an i8*, it's possible to index beyond what would appear to be the size of the pointer (i8*).
50 строки
1,2 КиБ
LLVM
50 строки
1,2 КиБ
LLVM
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64--linux"
|
|
|
|
@intToPtrResult = global i8 0
|
|
@ptrToIntResult = global i8 0
|
|
@someArray = internal global {i16, i8, i8} zeroinitializer
|
|
@someArrayPointer = global i8* zeroinitializer
|
|
|
|
define void @runtime.initAll() {
|
|
call void @main.init()
|
|
ret void
|
|
}
|
|
|
|
define internal void @main.init() {
|
|
call void @testIntToPtr()
|
|
call void @testPtrToInt()
|
|
call void @testConstGEP()
|
|
ret void
|
|
}
|
|
|
|
define internal void @testIntToPtr() {
|
|
%nil = icmp eq i8* inttoptr (i64 1024 to i8*), null
|
|
br i1 %nil, label %a, label %b
|
|
a:
|
|
; should not be reached
|
|
store i8 1, i8* @intToPtrResult
|
|
ret void
|
|
b:
|
|
; should be reached
|
|
store i8 2, i8* @intToPtrResult
|
|
ret void
|
|
}
|
|
|
|
define internal void @testPtrToInt() {
|
|
%zero = icmp eq i64 ptrtoint (i8* @ptrToIntResult to i64), 0
|
|
br i1 %zero, label %a, label %b
|
|
a:
|
|
; should not be reached
|
|
store i8 1, i8* @ptrToIntResult
|
|
ret void
|
|
b:
|
|
; should be reached
|
|
store i8 2, i8* @ptrToIntResult
|
|
ret void
|
|
}
|
|
|
|
define internal void @testConstGEP() {
|
|
store i8* getelementptr inbounds (i8, i8* bitcast ({i16, i8, i8}* @someArray to i8*), i32 2), i8** @someArrayPointer
|
|
ret void
|
|
}
|