[llvm-dev] GlobalVariable Recursive loop
Johan Wehrli via llvm-dev
llvm-dev at lists.llvm.org
Thu Sep 29 00:51:31 PDT 2016
Hi Mehdi,
> What about keeping track of “visited” global in a side structure (hash map…) and skip these?
>
> Note also that only GlobalValue can create cycles, so you’d need only to track these, not all constant.
Thanks for the proposition, I will try that.
Greetings,
Johan
> On 28 Sep 2016, at 18:50, Mehdi Amini <mehdi.amini at apple.com> wrote:
>
>>
>> On Sep 28, 2016, at 9:35 AM, Johan Wehrli via llvm-dev <llvm-dev at lists.llvm.org <mailto:llvm-dev at lists.llvm.org>> wrote:
>>
>> Hi,
>>
>> I have implemented a recursive loop to go through all the user of a global variable but I have one issue left.
>>
>> Depending the code, the global variable is using itself:
>>
>> @sSelectedAccount = internal constant %struct.KVObserver { %0* bitcast (%struct.__NSConstantString_tag* @_unnamed_cfstring_.744 to %0*), i8* bitcast (%struct.KVObserver* @sSelectedAccount to i8*), i32 3 }, align 4
>>
>> With the IR code above, I am stuck in an infinite loop:
>>
>> 1) The global sSelectedAccount has the following user: "i8* bitcast (%struct.KVObserver* @sSelectedAccount to i8*)"
>> 2) The bit cast has the following user: "%struct.KVObserver { %"type 0x7ff164027360"* bitcast (%struct.__NSConstantString_tag* @_unnamed_cfstring_.744 to %"type 0x7ff164027360"*), i8* bitcast (%struct.KVObserver* @sSelectedAccount to i8*), i32 3 }"
>> 3) The previous has the user sSelectedAccount -> so this create the infinite loop.
>>
>> I was looking for a way to detect the loop and I think there is two possibilities:
>> - from the global value, iterate through all the element and find the loop, but this need a lot of cast and another recursive loop (need to handle ConstantStruct, ConstantExpr, ConstantArray, etc.) Does anyone know if there is an easier way to do this?
>> -during the recursive loop, can I find the “main” global value? e.g: when I am on "i8* bitcast (%struct.KVObserver* @sSelectedAccount to i8*)”, how can I get the global variable sSelectedAccount ?
>
>
> What about keeping track of “visited” global in a side structure (hash map…) and skip these?
>
> Note also that only GlobalValue can create cycles, so you’d need only to track these, not all constant.
>
> —
> Mehdi
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160929/1667aa25/attachment.html>
More information about the llvm-dev
mailing list