<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><br><div><div>On Oct 1, 2014, at 10:05 AM, Adam Nemet <<a href="mailto:anemet@apple.com">anemet@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><br><div><div>On Oct 1, 2014, at 6:41 AM, Demikhovsky, Elena <<a href="mailto:elena.demikhovsky@intel.com">elena.demikhovsky@intel.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Patch 0002: I suggest to add "++additionalOperands" for all relevant modrm forms,<br>or just do this before switch.<br></div></blockquote><div><br></div><div>Doing before the switch would be a good improvement to this code, let me see if I can do it. I will probably commit that as a separate patch.</div></div></div></blockquote><div><br></div><div>It’s r218790.</div><br><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div><div><br></div><div>Thanks,</div><div>Adam</div><br><blockquote type="cite"><div style="font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br>- Elena<br><br><br>-----Original Message-----<br>From: Adam Nemet [<a href="mailto:anemet@apple.com">mailto:anemet@apple.com</a>]<span class="Apple-converted-space"> </span><br>Sent: Wednesday, October 01, 2014 08:57<br>To: Demikhovsky, Elena; Robert Khasanov<br>Cc: LLVM Commits<br>Subject: [AVX512] Add masking variants for vextract*x4<br><br>Hi Elena and Robert,<br><br>First I tried to implement this with the usual intrinsic lowering but unfortunately because vextract*x4 produces v4* vectors I would have needed VK4 and v4i1 for masking in AVX512f which only come with AVX512vl. I don't think these intrinsics are worth the hassle making that work so instead I went for asm-only instructions. Then I have the intrinsics Pat<>s to call the corresponding instruction.<br><br>This approach gave me a chance to incorporate asm-only masking support into the AVX512_masking hierarchy. See patch 1 and 4.<br><br>Also the masking operand was not supported with the MRMDestReg format, so I've added that too. See patch 2.<br><br>Please let me know if it looks good to you.<br><br>Thanks,<br>Adam<br><br>---------------------------------------------------------------------<br>Intel Israel (74) Limited<br><br>This e-mail and any attachments may contain confidential material for<br>the sole use of the intended recipient(s). Any review or distribution<br>by others is strictly prohibited. If you are not the intended<br>recipient, please contact the sender and delete all copies.</div></blockquote></div><br></div></blockquote></div><br></body></html>