<div dir="ltr">Ah, I see (from your sample, and the test case here) - we used to use a ConstantFP in the IR, but now we just provide the raw bytes so it's a non-issue.<br><br>Yeah, I might've committed a test if this change had intended to address that - but now that it's there/a non-issue by design without any code needed to test it, I'm ambivalent/might not bother with it myself. *shrug* :)</div><br><div class="gmail_quote"><div dir="ltr">On Mon, Dec 12, 2016 at 4:32 PM David Gross <<a href="mailto:dgross@google.com">dgross@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class="gmail_msg"><div class="gmail_extra gmail_msg"><div class="gmail_quote gmail_msg">On Mon, Dec 12, 2016 at 4:15 PM, David Blaikie <span dir="ltr" class="gmail_msg"><<a href="mailto:dblaikie@gmail.com" class="gmail_msg" target="_blank">dblaikie@gmail.com</a>></span> wrote:<br class="gmail_msg"><blockquote class="gmail_quote gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="gmail_msg"><br class="gmail_msg"><br class="gmail_msg"><div class="gmail_quote gmail_msg"><span class="m_2335944632929894412gmail- gmail_msg"><div dir="ltr" class="gmail_msg">On Mon, Dec 12, 2016 at 4:11 PM David Gross <<a href="mailto:dgross@google.com" class="gmail_msg" target="_blank">dgross@google.com</a>> wrote:<br class="gmail_msg"></div><blockquote class="gmail_quote gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">Per the Details:<div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></div><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></blockquote></div><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">Prior to the change "DebugInfo: New metadata representation for global</span></div></blockquote></div><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">variables." (</span><a href="https://reviews.llvm.org/D20147" class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-view m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-type-object m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="text-decoration:none;color:rgb(0,0,0);font-weight:bold;white-space:nowrap;font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" target="_blank"><span class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-core-closed m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="text-decoration:line-through;color:rgba(0,0,0,0.498039);margin-top:0px"><span class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-core m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-color-object m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="color:rgb(0,0,0);border:1px solid rgb(231,231,231);border-radius:3px;padding:0px 4px;background-color:rgb(231,231,231);margin-top:0px">D20147</span></span></a><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">, </span><a href="https://reviews.llvm.org/D20415" class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-view m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-type-object m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="text-decoration:none;color:rgb(0,0,0);font-weight:bold;white-space:nowrap;font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" target="_blank"><span class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-core-closed m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="text-decoration:line-through;color:rgba(0,0,0,0.498039);margin-top:0px"><span class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-core m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691gmail-phui-tag-color-object m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="color:rgb(0,0,0);border:1px solid rgb(231,231,231);border-radius:3px;padding:0px 4px;background-color:rgb(231,231,231);margin-top:0px">D20415</span></span></a><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">), clang emitted debug metadata for static</span></div></blockquote></div><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">const values of floating-point types, but llvm did not translate this</span></div><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">debug metadata into DWARF. After that change, clang did not emit debug</span></div><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">metadata for static const values of floating-point types, but llvm is</span></div><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span style="color:rgb(0,0,0);font-family:"segoe ui","segoe ui web regular","segoe ui symbol",lato,"helvetica neue",helvetica,arial,sans-serif;font-size:13px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">capable of translating it into DWARF if it is emitted.</span></div></blockquote></div><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></blockquote><font color="#000000" face="segoe ui, segoe ui web regular, segoe ui symbol, lato, helvetica neue, helvetica, arial, sans-serif" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></font><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><font color="#000000" face="segoe ui, segoe ui web regular, segoe ui symbol, lato, helvetica neue, helvetica, arial, sans-serif" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">My (perhaps overly cautious) concern is that given what has occurred in the past (where llvm was not emitting bytes for floating-point types), it's possible that there might be a change in the future which would cause the emission of the bytes to become type-sensitive again, and I'd like to be sure we do continue to emit the bytes for floating-point types.</font></div></div></blockquote></span><div class="gmail_msg"><br class="gmail_msg">Hmm - could you point me to the particular parts of those changes (or roughly describe what was going on in the old code, and what goes on in the new code) that caused this change in behavior?<br class="gmail_msg"></div></div></div></blockquote><div class="gmail_msg"><br class="gmail_msg"></div><div class="gmail_msg"><br class="gmail_msg"></div></div></div></div><div dir="ltr" class="gmail_msg"><div class="gmail_extra gmail_msg"><div class="gmail_quote gmail_msg"><div class="gmail_msg">Briefly, in the old version of clang/llvm, clang emits debug metadata that's at a higher semantic level (that is, it's not emitting a DIExpression), and that debug metadata is type-independent (or at least treats integral types and floating-point types the same); but when llvm translates that debug metadata into DWARF, it does not do so for floating-point types.</div><div class="gmail_msg"><br class="gmail_msg"></div><div class="gmail_msg">(Looking back on what I wrote, I realize I just restated the Details from this patch.)  You could look at the two changes cited in the Details where the metadata representation changed.</div><div class="gmail_msg"><br class="gmail_msg"></div><div class="gmail_msg">Also, here is a patch applied to the old version of clang/llvm to make a similar fix.  Whereas for current versions of clang/llvm, the fix is to modify clang to emit debug metadata for floating-point types (llvm already does the right thing), for the old version of clang/llvm shown in the following patches, the fix is to modify llvm to emit DWARF for floating-point types (clang already does the right thing): <a href="https://android-review.googlesource.com/#/c/312566/1/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp" class="gmail_msg" target="_blank">https://android-review.googlesource.com/#/c/312566/1/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp</a><br class="gmail_msg"></div></div></div></div><div dir="ltr" class="gmail_msg"><div class="gmail_extra gmail_msg"><div class="gmail_quote gmail_msg"><div class="gmail_msg"> </div><blockquote class="gmail_quote gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="gmail_msg"><div class="gmail_quote gmail_msg"><div class="gmail_msg"><br class="gmail_msg">- Dave<br class="gmail_msg"> </div><blockquote class="gmail_quote gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><font color="#000000" face="segoe ui, segoe ui web regular, segoe ui symbol, lato, helvetica neue, helvetica, arial, sans-serif" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></font></div></div><div class="gmail_extra m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span class="m_2335944632929894412gmail- gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="gmail_quote m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">On Mon, Dec 12, 2016 at 3:47 PM, David Blaikie <span dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><<a href="mailto:dblaikie@gmail.com" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" target="_blank">dblaikie@gmail.com</a>></span> wrote:<br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><blockquote class="gmail_quote m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div class="gmail_quote m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><span class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><div dir="ltr" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">On Mon, Dec 12, 2016 at 3:24 PM David Gross via Phabricator <<a href="mailto:reviews@reviews.llvm.org" class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" target="_blank">reviews@reviews.llvm.org</a>> wrote:<br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></div><blockquote class="gmail_quote m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">dgross added a comment.<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
In <a href="https://reviews.llvm.org/D27551#620373" rel="noreferrer" class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" target="_blank">https://reviews.llvm.org/D27551#620373</a>, @dblaikie wrote:<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
> Does this need the test coverage if it's just "hey, LLVM can splat these bytes out into DWARF even if we (independently) say the type of those bytes is a float"? The code that emits the bytes is presumably independent of the code that emits the type description, so testing the combination seems unnecessary to me.<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
Can you explain this further?  What parts of this test case are you suggesting may be unnecessary?<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></blockquote><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"></div></span><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">All of it. (partly under the argument that no code changes were required to provide this functionality, but to be more complete:<br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">* We already have test coverage for emitting the correct DW_AT_type value here<br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">* We already have test coverage that the arbitrary bytes in the constant value are emitted into the right place in the DW_AT_const_value or whatnot<br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"><br class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">So what's the particularly interesting thing about testing the combination of those two (so far as I can see) orthogonal features?)</div><div class="m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg"> </div><blockquote class="gmail_quote m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<a href="https://reviews.llvm.org/D27551" rel="noreferrer" class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg" target="_blank">https://reviews.llvm.org/D27551</a><br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
<br class="m_2335944632929894412gmail-m_8856549020955551910m_-4118040117516390691m_-5303920041016513926gmail_msg m_2335944632929894412gmail-m_8856549020955551910gmail_msg gmail_msg">
</blockquote></div></div>
</blockquote></div><div style="color:rgb(33,33,33);font-family:"helvetica neue",helvetica,arial,sans-serif;font-size:13px;overflow:hidden;width:28px;height:28px" class="gmail_msg"><input type="file" multiple style="font-size:28px;height:28px;width:28px;opacity:0" class="gmail_msg"></div></span><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-mb gmail_msg" style="min-width:0px;display:flex;color:rgb(33,33,33);font-family:"helvetica neue",helvetica,arial,sans-serif;font-size:13px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-n gmail_msg" style="max-height:28px;overflow:hidden;display:inline-flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:np" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"> </div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Bold" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+bold" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-c8csvc gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Italic" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+italic" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-O807Gb gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Underline" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+underline" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-NowJzb gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:ny" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"> </div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-hy-aG-K gmail_msg" title="Text color" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+foreColor" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:auto;line-height:28px;padding:0px 5px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-Ig-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-s1-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-mr gmail_msg" style="display:inline-block;color:black"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-hy-aG-K-Gx gmail_msg" style="border-bottom:3px solid rgb(0,0,0);box-sizing:border-box;height:18px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-K2 gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px;line-height:18px"></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-NK gmail_msg" style="display:flex"> </div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-cX m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-GE gmail_msg" title="Font size" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+fontSize" style="display:flex;border-radius:3px;opacity:0.6;line-height:28px;padding:0px 5px;width:auto"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-Ig-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-s1-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-mr gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:nz" style="display:inline-block;color:black;font-size:0px;line-height:0;overflow:hidden;background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px">Normal</div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-NK gmail_msg" style="display:flex"> </div></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-pQ8uTb gmail_msg"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:no" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"> </div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="More formatting options" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-moreFormattingOptions" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-NK gmail_msg" style="display:flex"></div></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-Mx gmail_msg" style="background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;padding:8px;display:inline-flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:ob" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-tS m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-GE gmail_msg" title="Font" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+fontName" style="display:flex;border-radius:3px;opacity:0.6;line-height:28px;padding:0px 5px;width:auto"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-Ig-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-s1-lc gmail_msg" style="display:flex;width:96px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-mr gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:oc" style="display:inline-block;color:black;font-weight:bold;overflow:hidden;text-overflow:ellipsis;white-space:nowrap"></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-NK gmail_msg" style="display:flex"></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:oe" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Bullet list" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+insertUnorderedList" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-QBb5Bf gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Numbered list" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+insertOrderedList" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-xoUHxd gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:og" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Add or remove link" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+link" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-s gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px;font-size:0px"></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K gmail_msg" title="Remove formatting" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-+removeFormat" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:28px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-Ig-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-K-s1-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-N m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-HV735b gmail_msg" style="background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"></div></div></div></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-DKlKme gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-Cw-mD m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE gmail_msg" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:or" style="display:inline-block;background-image:initial;background-position:initial;background-size:initial;background-repeat:initial;background-origin:initial;background-clip:initial;background-color:rgb(229,229,229);height:28px;margin:0px 6px;width:1px"></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aZ-bm-aG-K gmail_msg" title="Templates" id="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-:os" style="display:flex;border-radius:3px;opacity:0.6;height:28px;width:auto;line-height:28px;padding:0px 5px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-Ig-lc gmail_msg" style="display:inline-block"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-s1-lc gmail_msg" style="display:flex"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-mr gmail_msg" style="display:inline-block;color:black;font-size:0px;line-height:0;overflow:hidden;background-position:50% 50%;background-repeat:no-repeat;background-size:18px;height:18px;width:18px"><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-h-sBkzoe gmail_msg"></div></div><div class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-mu-sE m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-g-W-aG-K-NK gmail_msg" style="display:flex"></div></div></div></div></div></div></div><br class="m_2335944632929894412gmail-m_8856549020955551910inbox-inbox-Apple-interchange-newline gmail_msg"></div>
</blockquote></div></div>
</blockquote></div></div></div></blockquote></div>