<div dir="ltr">Choice 3 sounds too much, choices 1 or 2 seem better. I'd probably go with 1 because we already have lots of code which is templated for ELFT or Is64Bits, and IsLE falls in the same category. Target dependent code (Target.cpp) is small, so code bloat is not going to be an issue.<div><br></div><div>I'd define something like this: template <bool LE> class MipsTargetInfo, and use add32<LE>() instead of add32le and so on.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Oct 13, 2015 at 3:17 AM, Simon Atanasyan <span dir="ltr"><<a href="mailto:simon@atanasyan.com" target="_blank">simon@atanasyan.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi,<br>
<br>
I need an advice how to support both big and little endian MIPS<br>
targets in the new LLD ELF design and escape code duplication. MIPS<br>
32-bit big and little endian targets are very similar and differ in<br>
read/write functions. There are some options how to support both but I<br>
cannot make the best choice.<br>
<br>
1. Make MipsTargetInfo a class template. Use the template's argument<br>
to select read/write routines.<br>
2. Pass boolean argument to the MipsTargetInfo constructor. Use this<br>
argument to select read/write routines.<br>
3. Create a hierarchy of MipsTargetInfo classes. Keep common code in<br>
the MipsTargetInfo class, move endian-dependent code into the<br>
MipsELTargetInfo / MipsBETargetInfo descendants.<br>
4. Anything else?<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Simon Atanasyan<br>
</font></span></blockquote></div><br></div>