<html dir="ltr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style id="owaParaStyle" type="text/css">P {margin-top:0;margin-bottom:0;}</style>
</head>
<body ocsi="0" fpstyle="1">
<div style="direction: ltr;font-family: Tahoma;color: #000000;font-size: 10pt;">Hi all,<br>
I'm trying to solve a problem that we have in implementation of the assembler for Mips platform in llvm. Mips has some pseudo instructions that, depending on the arguments can be emitted as one or more real instructions by the assembler.
<br>
<pre class="bz_comment_text" id="comment_text_0"><font face="Tahoma">For example load immediate instruction can have multiple expansions depending on a size of immediate operand:
This expansion is for 0 ≤ j ≤ 65535.</font>
li d,j =>
ori d,$zero,j
<font face="Tahoma">This one is for −32768 ≤ j < 0.</font>
li d,j =>
addiu d,$zero,j
<font face="Tahoma">This one is for any other value of j that is representable as a 32-bit integer.</font>
li d,j =>
lui d,hi16(j)
ori d,d,lo16(j)</pre>
<font face="Tahoma">I have found that class PseudoLoweringEmitter emits code which deals with PseudoInstExpansion.
</font><font face="Tahoma">This sounds like exactly what we need , but</font><font face="Tahoma">, as stated in comment in PseudoLoweringEmitter.cpp:
<br>
// FIXME: This pass currently can only expand a pseudo to a single instruction. <br>
// The pseudo expansion really should take a list of dags, not just <br>
// a single dag, so we can do fancier things. <br>
<br>
Are the 'fancier things' mentioned in the comment</font> things that we need, expansion to a multiple instructions and could they use operand values as conditions for different expansions?<br>
Could it work for inline asm in C code, with/without direct-object emitter?<br>
<br>
Kind Regards<br>
<br>
Vladimir<br>
</div>
</body>
</html>