<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class=""><p class="p1">Hi Mehdi,</p><div class="">Thank you for the explanation, it is a lot more clear for me now.</div></div><div class=""><br class=""></div><div class="">Greetings,</div><div class=""><br class=""></div><div class="">Johan</div><div class=""><br class=""></div><div style=""><blockquote type="cite" class=""><div class="">On 24 Aug 2016, at 17:41, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" class="">mehdi.amini@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="Content-Type" content="text/html charset=utf-8" class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div class=""><blockquote type="cite" class=""><div class="">On Aug 24, 2016, at 8:18 AM, Johan Wehrli <<a href="mailto:johan.wehrli@strong.codes" class="">johan.wehrli@strong.codes</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="Content-Type" content="text/html charset=utf-8" class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">Hi Mehdi,<div class=""><br class=""></div><div class="">Thank you for you answer.</div><div class=""><br class=""></div><div class=""><blockquote type="cite" class=""><div class="">Yes it is normal you *have* to use the same context to manipulate IR inside a Module. The context owns the module and destroying the context destroys everything that is created in the context. It is not clear to me what other context you could even manage to use here conceptually.</div></blockquote><div class=""><br class=""></div>Actually I was using <i class="">llvm::getGlobalContext()</i> in order to get the context.</div></div></div></blockquote><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><div class="">I see, I removed getGlobalContext() in LLVM 3.9 because of this kind of confusions.</div><div class=""><br class=""></div></div><br class=""><blockquote type="cite" class=""><div class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class=""><br class=""></div><div class="">It seems that this is not the same context as <i class="">gv->getContext()</i>.</div></div></div></blockquote><div class=""><br class=""></div><div class="">It may or may not be: depending if the module was created with getGlobalContext in the first place.</div><div class=""><br class=""></div><div class="">— </div><div class="">Mehdi</div><div class=""><br class=""></div><blockquote type="cite" class=""><div class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class=""><br class=""></div><div class="">Greetings,<br class=""><div class="">

<meta http-equiv="content-type" content="text/html; charset=windows-1252" class=""><p class="p1">
  <img alt="" src="" style="width: 256px; height: 50px;" class="">
</p><p class="p1">
  <span style="color:#da291c;" class="">
    <span style="font-family:futura,helvetica,sans-serif;" class="">
      <span class="s1">
          JOHAN WEHRLI - Product and development
      </span>
    </span>
  </span>
</p><p class="p3">
  <span style="font-family:futura,helvetica,sans-serif;" class="">
    <span class="s2">
        Rue Galilée 7<br class="">
        CH-1400 Yverdon-les-Bains<br class="">
        <a href="https://strong.codes/" class="">https://strong.codes</a><br class="">
    </span>
  </span>
</p>


</div>
<br class=""><div style="" class=""><blockquote type="cite" class=""><div class="">On 24 Aug 2016, at 16:55, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" class="">mehdi.amini@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><blockquote type="cite" class=""><div class=""><br class="Apple-interchange-newline">On Aug 24, 2016, at 4:27 AM, Johan Wehrli via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi,<div class=""><br class=""></div><div class="">I am trying to update the initializer of a global value and I have encounter two issues:</div><div class=""><br class=""></div><div class="">The first one is that I can not change the type of the global value. Let say that I have the following variable: <i class="">@.str = private unnamed_addr constant [6 x i8] c”Test0A\00", align 1</i></div><div class=""><i class=""><br class=""></i></div><div class="">How can I change the <i class="">”Test0A\00”<span class="Apple-converted-space"> </span></i>to<i class=""> </i><i class="">”OtherTest0A\00”.<span class="Apple-converted-space"> </span></i>Is this possible? I know that you can change the<span class="Apple-converted-space"> </span><i class="">initializer</i><span class="Apple-converted-space"> </span>with<span class="Apple-converted-space"> </span><i class="">setInitializer</i><span class="Apple-converted-space"> </span>but the global value’s type will not be the same.</div></div></div></blockquote><blockquote type="cite" class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class="">For now, the only way I found was to create a new global value and to change all theses uses.</div></div></div></blockquote><div class=""><br class=""></div><div class=""><div class="">That’s the right thing to do: you need to create a new GV and replace the old one with the new one.</div><div class=""><br class=""></div><br class=""><blockquote type="cite" class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"></div></blockquote></div><br class=""><blockquote type="cite" class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><br class=""></div><div class="">The second problem that I have is with the function <i class="">Verifier::visitGlobalVariable</i>. Sometimes, the verifier tells me that the initializer type does not match the global variable type even when this is the case.</div><div class=""><br class=""></div><div class=""> This function will do the following check: </div><div class=""><br class=""></div><div class=""><div class=""><i class="">if (GV.hasInitializer()) {</i></div><div class=""><i class="">    Assert(GV.getInitializer()->getType() == GV.getType()->getElementType(),</i></div><div class=""><i class="">           "Global variable initializer type does not match global "</i></div><div class=""><i class="">           "variable type!",</i></div><div class=""><i class="">           &GV);</i></div></div><div class=""><br class=""></div><div class="">But I did not find any overload for the comparator operator (in the type class). So this will only check if the addresses of the type are the same and not if this is the same type.</div><div class=""><br class=""></div><div class="">To have the same type, I need to create the initializer with the same context as the global variable:</div><div class=""><br class=""></div><div class=""><div class=""><i class="">LLVMContext &C = gv->getContext();</i></div><div class=""><i class="">ConstantDataArray *data = cast<ConstantDataArray>(ConstantDataArray::getString(C, ref, false));       </i></div><div class=""><i class="">gv->setInitializer(data);</i></div></div><div class=""><br class=""></div><div class="">Is this normal? I am missing something?</div></div></div></blockquote></div><br class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Yes it is normal you *have* to use the same context to manipulate IR inside a Module. The context owns the module and destroying the context destroys everything that is created in the context. It is not clear to me what other context you could even manage to use here conceptually.</div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Anyway it is rooted quite deeply in LLVM that type can be compared by pointer thanks to this context uniquing.</div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br class=""></div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">You can have different LLVMContext when you manipulate multiple Modules (Context are here to enable multi-threading environment), but you won’t be able to compare type from one module to the other for example.</div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br class=""></div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">— </div><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Mehdi</div></div></blockquote></div><br class=""></div></div></div></blockquote></div><br class=""></div></div></blockquote></div><br class=""></body></html>