<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Helvetica,sans-serif;" dir="ltr">
<p style="margin-top:0;margin-bottom:0">Hi Jonas:</p>
<p style="margin-top:0;margin-bottom:0"><br>
</p>
<p style="margin-top:0;margin-bottom:0">The 'Single Issue', wherein an otherwise dual-issue machine can only single issue certain instruction, relies on BeginGroup/EndGroup and this change might affect that.</p>
<p style="margin-top:0;margin-bottom:0"><br>
</p>
<p style="margin-top:0;margin-bottom:0">- Javed</p>
</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> Jonas Paulsson <paulsson@linux.vnet.ibm.com><br>
<b>Sent:</b> 15 May 2018 12:39:17<br>
<b>To:</b> Andrew Trick<br>
<b>Cc:</b> llvm-dev; Javed Absar; Florian Hahn; Matthias Braun; Hal Finkel; Ulrich Weigand<br>
<b>Subject:</b> Re: [MachineScheduler] Question about IssueWidth / NumMicroOps</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText">Hi Andy,<br>
<br>
>> Right now it seems that BeginGroup/EndGroup is only used by SystemZ, <br>
>> or? I see they are used in checkHazard(), which I actually don't see <br>
>> as helpful during pre-RA scheduling for SystemZ. Could this be made <br>
>> optional, or perhaps only done post-RA if target does post-RA <br>
>> scheduling? SystemZ does post-RA scheduling to manage decoder <br>
>> grouping, which is where the BeginGroup/EndGroup and <br>
>> IssueWidth/NumMicroOps is useful. However doing this pre-RA and <br>
>> thereby limiting the freedom of other heuristics (making less <br>
>> instructions available) seems like a bad idea.<br>
><br>
> I've worked on a few cpus in the past that had issue group <br>
> restrictions. It seems like a natural way to handle special kinds of <br>
> instructions. But I'm not aware of any LLVM backend that depends on it <br>
> for preRA scheduling. If they are, hopefully they're reading this and <br>
> will speak up.<br>
><br>
> My thinking a few years back was that targets would only run post-RA <br>
> scheduling in rare cases and only for blocks with spill code, as a <br>
> spill-fixup pass. That's not what you, and probably others are doing, <br>
> so if you want to make those Begin/EndGroup post-RA specific, it's <br>
> fine with me. Or you could be more ambitious and introduce the concept <br>
> of a post-RA specific processor resource.<br>
><br>
This patch: <a href="https://reviews.llvm.org/D46870">https://reviews.llvm.org/D46870</a>, put those checks under a
<br>
post-RA flag, and also covers the NumUOps / IssueWidth the same way.<br>
<br>
/Jonas<br>
<br>
> -Andy<br>
><br>
>><br>
>>> Sorry, I don't have time to draw diagrams and tables. Hopefully you <br>
>>> can makes sense of my long-form rambling.<br>
>> Yes, very helpful to me :-)<br>
>><br>
>> Thanks again,<br>
>><br>
>> Jonas<br>
>><br>
><br>
<br>
</div>
</span></font></div>
IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents to any other person, use it for any purpose,
or store or copy the information in any medium. Thank you.
</body>
</html>