<div dir="ltr"><div>Hi again,<br><br></div>Please consider this. I'd be happy to fix various problem you may find, please give me some feedback.<br></div><div class="gmail_extra"><br><div class="gmail_quote">2014-10-10 20:45 GMT-07:00 deadal nix <span dir="ltr"><<a href="mailto:deadalnix@gmail.com" target="_blank">deadalnix@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi all, I'd really like to have feedback on that one.<br></div><div class="gmail_extra"><br><div class="gmail_quote">2014-10-05 20:09 GMT-07:00 deadal nix <span dir="ltr"><<a href="mailto:deadalnix@gmail.com" target="_blank">deadalnix@gmail.com</a>></span>:<div><div class="h5"><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div>As per title. Aggregate load and stores (granted they aren't unordered) are decomposed in a suite of scalar loads and stores and bit manipulation are used to reconstruct/deconstruct the aggregate using insertvalue/extractvalue.<br><br></div>I wasn't sure where to add the pass so I added it fairly early. It may not be the idea place, I'll let you expert tell me. It seems need that this run before SROA and any pass that manipulate memory as this would defeat the point entirely.<br><br></div><div>It do not need to run more than once as, as far as I know, no pass introduce aggregate load/store ever. So once the ones generated by the frontend are gone, the job is finished.<br></div><div><br></div>This pass does nothing on non aggregate load/store (except going thourgh the instruction to check they are none), so I don't expect this to impact frontend that don't use them in any major way.<br><br></div>I think this is a major step forward for LLVM usability from a front perspective.<br></div>
</blockquote></div></div></div><br></div>
</blockquote></div><br></div>