<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Thu, Mar 8, 2018 at 8:48 AM, Rafael Antognolli <span dir="ltr"><<a href="mailto:rafael.antognolli@intel.com" target="_blank">rafael.antognolli@intel.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Some instructions contain fields that are either an address or a value<br>
of some type based on the content of other fields, such as clear color<br>
values vs address. That works fine if these fields are in the less<br>
significant dword, the lower 32 bits of the address, because they get<br>
OR'ed with the address. But if they are in the higher 32 bits, they get<br>
discarded.<br>
<br>
On Gen10 we have fields that share space with the higher 16 bits of the<br>
address too. This commit makes sure those fields don't get discarded.<br>
<br>
Signed-off-by: Rafael Antognolli <<a href="mailto:rafael.antognolli@intel.com">rafael.antognolli@intel.com</a>><br>
Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br>
---<br>
src/intel/genxml/gen_pack_<wbr>header.py | 9 +++++++--<br>
1 file changed, 7 insertions(+), 2 deletions(-)<br>
<br>
diff --git a/src/intel/genxml/gen_pack_<wbr>header.py b/src/intel/genxml/gen_pack_<wbr>header.py<br>
index 7dcada86fae..2d40760588e 100644<br>
--- a/src/intel/genxml/gen_pack_<wbr>header.py<br>
+++ b/src/intel/genxml/gen_pack_<wbr>header.py<br>
@@ -494,11 +494,16 @@ class Group(object):<br>
v_address = "v%d_address" % index<br>
print(" const uint64_t %s =\n __gen_combine_address(data, &dw[%d], values->%s, %s);" %<br>
(v_address, index, <a href="http://dw.address.name" rel="noreferrer" target="_blank">dw.address.name</a> + field.dim, v))<br>
- v = v_address<br>
-<br>
+ if len(dw.fields) > address_count:<br>
+ print(" dw[%d] = %s;" % (index, v_address))<br>
+ print(" dw[%d] = (%s >> 32) | (%s >> 32);" % (index + 1, v_address, v))<br>
+ continue<br>
+ else:<br>
+ v = v_address<br>
print(" dw[%d] = %s;" % (index, v))<br>
print(" dw[%d] = %s >> 32;" % (index + 1, v))<br>
<br>
+<br></blockquote><div><br></div><div>Spurrious whitespace change<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
class Value(object):<br>
def __init__(self, attrs):<br>
<a href="http://self.name" rel="noreferrer" target="_blank">self.name</a> = safe_name(attrs["name"])<br>
<span class="HOEnZb"><font color="#888888">--<br>
2.14.3<br>
<br>
______________________________<wbr>_________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
</font></span></blockquote></div><br></div></div>