<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<span style="color: rgb(51, 51, 51); font-family: Cambria, serif; font-size: 12pt;">Hi all LLVM expert,</span><br>
</div>
<div style="font-family: Calibri, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt">
<span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)"> </span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt">
<span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)">I¡¯m trying to ask how to bind hidden micro-architecture specific resource index to architecture resource index in tablegen</span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)">There may be instruction uses 1 sr and 1 vr as source operand (using index sr_src_idx, vr_src_idx), then uses 1 sr and 1 vr as destination
 (using index sr_dst_idx, vr_dst_idx). Additionally, this instruction trigger a write to a hidden resource whose index is same as the vr destination index (vr_dst_idx). The instruction's write to SR/VR/HR are with different latency, say 1/3/6.  Example code
 are as below</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt; box-sizing: border-box; orphans: 4">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)">Is there a way to describe this in tablegen? How to bind the index between hr and vr?</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt">
<span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(51, 51, 51)"><br>
</span><span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)">Scalar_Register sr[32]; //architecture visible resource</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt; box-sizing: border-box; orphans: 4">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)">Vector_Register vr[32]; //architecture visible resource</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt; box-sizing: border-box; orphans: 4">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)">Hidden_Resource hr[32]; //target specific micro-architecture resource, hidden from architecture but impact performance</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)">//instruction info defined in ISA</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)"></span></p>
<p style="margin-right: 0in; margin-left: 0in; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); margin-bottom: 9.6pt; box-sizing: border-box; orphans: 4">
<span style="margin: 0px"><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)">(VR vr_dst_idx, SR sr_dst_idx) = instruciton_1 (VR vr_src_idx, SR sr_src_idx) ;</span></span><span style="margin: 0px; font-size: 12pt; font-family: Cambria, serif; color: rgb(0, 112, 192)"></span></p>
<p style="margin: 0in 0in 0.0001pt; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255); box-sizing: border-box; orphans: 4">
 </p>
<p style="margin: 0in 0in 0.0001pt; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255)">
 </p>
<p style="margin: 0in 0in 0.0001pt; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255)">
<span style="margin: 0px; font-family: Cambria, serif">Chuang Feng</span></p>
<p style="margin: 0in 0in 0.0001pt; font-size: 11pt; font-family: Calibri, sans-serif; color: rgb(32, 31, 30); background-color: rgb(255, 255, 255)">
 </p>
<br>
</div>
<div>
<div dir="ltr">
<div class="x_gmail_quote">
<blockquote class="x_gmail_quote" style="margin:0px 0px 0px 0.8ex; border-left:1px solid rgb(204,204,204); padding-left:1ex">
<div dir="ltr"></div>
</blockquote>
</div>
</div>
</div>
</body>
</html>