From mboxrd@z Thu Jan 1 00:00:00 1970 From: Andrew Cooper Subject: [PATCH 6/8] x86/emul: Support speculative MSR reads Date: Mon, 5 Dec 2016 10:09:29 +0000 Message-ID: <1480932571-23547-7-git-send-email-andrew.cooper3@citrix.com> References: <1480932571-23547-1-git-send-email-andrew.cooper3@citrix.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <1480932571-23547-1-git-send-email-andrew.cooper3@citrix.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Errors-To: xen-devel-bounces@lists.xen.org Sender: "Xen-devel" To: Xen-devel Cc: Andrew Cooper , Paul Durrant , Jan Beulich List-Id: xen-devel@lists.xenproject.org VXBkYXRlIHRoZSByZWFkX21zcigpIGhvb2sgdG8gdGFrZSBhbiBhZGRpdGlvbmFsIHBhcmFtZXRl ciwgaW5kaWNhdGluZyB0aGF0CnRoZXJlIHNob3VsZCBiZSBubyBzaWRlIGVmZmVjdHMgb2YgdGhl IHJlYWQuCgpObyBmdW5jdGlvbmFsIGNoYW5nZS4KClNpZ25lZC1vZmYtYnk6IEFuZHJldyBDb29w ZXIgPGFuZHJldy5jb29wZXIzQGNpdHJpeC5jb20+Ci0tLQpDQzogSmFuIEJldWxpY2ggPEpCZXVs aWNoQHN1c2UuY29tPgpDQzogUGF1bCBEdXJyYW50IDxwYXVsLmR1cnJhbnRAY2l0cml4LmNvbT4K LS0tCiB4ZW4vYXJjaC94ODYvaHZtL2VtdWxhdGUuYyAgICAgICAgICAgICB8ICAzICsrLQogeGVu L2FyY2gveDg2L3g4Nl9lbXVsYXRlL3g4Nl9lbXVsYXRlLmMgfCAyNCArKysrKysrKysrKystLS0t LS0tLS0tLS0KIHhlbi9hcmNoL3g4Ni94ODZfZW11bGF0ZS94ODZfZW11bGF0ZS5oIHwgIDYgKysr KystCiAzIGZpbGVzIGNoYW5nZWQsIDE5IGluc2VydGlvbnMoKyksIDE0IGRlbGV0aW9ucygtKQoK ZGlmZiAtLWdpdCBhL3hlbi9hcmNoL3g4Ni9odm0vZW11bGF0ZS5jIGIveGVuL2FyY2gveDg2L2h2 bS9lbXVsYXRlLmMKaW5kZXggYjE4MmQ1Ny4uYmNlMGIwMCAxMDA2NDQKLS0tIGEveGVuL2FyY2gv eDg2L2h2bS9lbXVsYXRlLmMKKysrIGIveGVuL2FyY2gveDg2L2h2bS9lbXVsYXRlLmMKQEAgLTE1 MjksMTEgKzE1MjksMTIgQEAgc3RhdGljIGludCBodm1lbXVsX3dyaXRlX2NyKAogc3RhdGljIGlu dCBodm1lbXVsX3JlYWRfbXNyKAogICAgIHVuc2lnbmVkIGludCByZWcsCiAgICAgdWludDY0X3Qg KnZhbCwKKyAgICBib29sIHNwZWN1bGF0aXZlLAogICAgIHN0cnVjdCB4ODZfZW11bGF0ZV9jdHh0 ICpjdHh0KQogewogICAgIGludCByYyA9IGh2bV9tc3JfcmVhZF9pbnRlcmNlcHQocmVnLCB2YWwp OwogCi0gICAgaWYgKCByYyA9PSBYODZFTVVMX0VYQ0VQVElPTiApCisgICAgaWYgKCByYyA9PSBY ODZFTVVMX0VYQ0VQVElPTiAmJiAhc3BlY3VsYXRpdmUgKQogICAgICAgICB4ODZfZW11bF9od19l eGNlcHRpb24oVFJBUF9ncF9mYXVsdCwgMCwgY3R4dCk7CiAKICAgICByZXR1cm4gcmM7CmRpZmYg LS1naXQgYS94ZW4vYXJjaC94ODYveDg2X2VtdWxhdGUveDg2X2VtdWxhdGUuYyBiL3hlbi9hcmNo L3g4Ni94ODZfZW11bGF0ZS94ODZfZW11bGF0ZS5jCmluZGV4IDg3NzAyM2QuLjVjYmE3ZWMgMTAw NjQ0Ci0tLSBhL3hlbi9hcmNoL3g4Ni94ODZfZW11bGF0ZS94ODZfZW11bGF0ZS5jCisrKyBiL3hl bi9hcmNoL3g4Ni94ODZfZW11bGF0ZS94ODZfZW11bGF0ZS5jCkBAIC0xMzE5LDcgKzEzMTksNyBA QCBpbl9sb25nbW9kZSgKICAgICB1aW50NjRfdCBlZmVyOwogCiAgICAgaWYgKCAhb3BzLT5yZWFk X21zciB8fAotICAgICAgICAgdW5saWtlbHkob3BzLT5yZWFkX21zcihNU1JfRUZFUiwgJmVmZXIs IGN0eHQpICE9IFg4NkVNVUxfT0tBWSkgKQorICAgICAgICAgdW5saWtlbHkob3BzLT5yZWFkX21z cihNU1JfRUZFUiwgJmVmZXIsIGZhbHNlLCBjdHh0KSAhPSBYODZFTVVMX09LQVkpICkKICAgICAg ICAgcmV0dXJuIC0xOwogCiAgICAgcmV0dXJuICEhKGVmZXIgJiBFRkVSX0xNQSk7CkBAIC00NDEy LDcgKzQ0MTIsNyBAQCB4ODZfZW11bGF0ZSgKICAgICAgICAgewogICAgICAgICAgICAgdWludDY0 X3QgdHNjX2F1eDsKICAgICAgICAgICAgIGZhaWxfaWYob3BzLT5yZWFkX21zciA9PSBOVUxMKTsK LSAgICAgICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihNU1JfVFNDX0FVWCwgJnRzY19h dXgsIGN0eHQpKSAhPSAwICkKKyAgICAgICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihN U1JfVFNDX0FVWCwgJnRzY19hdXgsIGZhbHNlLCBjdHh0KSkgIT0gMCApCiAgICAgICAgICAgICAg ICAgZ290byBkb25lOwogICAgICAgICAgICAgX3JlZ3MuZWN4ID0gKHVpbnQzMl90KXRzY19hdXg7 CiAgICAgICAgICAgICBnb3RvIHJkdHNjOwpAQCAtNDU0OCwxMSArNDU0OCwxMSBAQCB4ODZfZW11 bGF0ZSgKIAogICAgICAgICAvKiBJbmplY3QgI1VEIGlmIHN5c2NhbGwvc3lzcmV0IGFyZSBkaXNh YmxlZC4gKi8KICAgICAgICAgZmFpbF9pZihvcHMtPnJlYWRfbXNyID09IE5VTEwpOwotICAgICAg ICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX0VGRVIsICZtc3JfY29udGVudCwgY3R4dCkp ICE9IDAgKQorICAgICAgICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX0VGRVIsICZtc3Jf Y29udGVudCwgZmFsc2UsIGN0eHQpKSAhPSAwICkKICAgICAgICAgICAgIGdvdG8gZG9uZTsKICAg ICAgICAgZ2VuZXJhdGVfZXhjZXB0aW9uX2lmKChtc3JfY29udGVudCAmIEVGRVJfU0NFKSA9PSAw LCBFWENfVUQpOwogCi0gICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihNU1JfU1RBUiwg Jm1zcl9jb250ZW50LCBjdHh0KSkgIT0gMCApCisgICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFk X21zcihNU1JfU1RBUiwgJm1zcl9jb250ZW50LCBmYWxzZSwgY3R4dCkpICE9IDAgKQogICAgICAg ICAgICAgZ290byBkb25lOwogCiAgICAgICAgIGNzLnNlbCA9IChtc3JfY29udGVudCA+PiAzMikg JiB+MzsgLyogU0VMRUNUT1JfUlBMX01BU0sgKi8KQEAgLTQ1NzQsMTEgKzQ1NzQsMTEgQEAgeDg2 X2VtdWxhdGUoCiAgICAgICAgICAgICBfcmVncy5yMTEgPSBfcmVncy5lZmxhZ3MgJiB+RUZMR19S RjsKIAogICAgICAgICAgICAgaWYgKCAocmMgPSBvcHMtPnJlYWRfbXNyKG1vZGVfNjRiaXQoKSA/ IE1TUl9MU1RBUiA6IE1TUl9DU1RBUiwKLSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAmbXNyX2NvbnRlbnQsIGN0eHQpKSAhPSAwICkKKyAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAmbXNyX2NvbnRlbnQsIGZhbHNlLCBjdHh0KSkgIT0gMCApCiAgICAgICAg ICAgICAgICAgZ290byBkb25lOwogICAgICAgICAgICAgX3JlZ3MucmlwID0gbXNyX2NvbnRlbnQ7 CiAKLSAgICAgICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihNU1JfRk1BU0ssICZtc3Jf Y29udGVudCwgY3R4dCkpICE9IDAgKQorICAgICAgICAgICAgaWYgKCAocmMgPSBvcHMtPnJlYWRf bXNyKE1TUl9GTUFTSywgJm1zcl9jb250ZW50LCBmYWxzZSwgY3R4dCkpICE9IDAgKQogICAgICAg ICAgICAgICAgIGdvdG8gZG9uZTsKICAgICAgICAgICAgIF9yZWdzLmVmbGFncyAmPSB+KG1zcl9j b250ZW50IHwgRUZMR19SRik7CiAgICAgICAgIH0KQEAgLTQ3OTMsNyArNDc5Myw3IEBAIHg4Nl9l bXVsYXRlKAogICAgICAgICAgICAgZ2VuZXJhdGVfZXhjZXB0aW9uX2lmKGNyNCAmIENSNF9UU0Qs IEVYQ19HUCwgMCk7CiAgICAgICAgIH0KICAgICAgICAgZmFpbF9pZihvcHMtPnJlYWRfbXNyID09 IE5VTEwpOwotICAgICAgICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX1RTQywgJnZhbCwg Y3R4dCkpICE9IDAgKQorICAgICAgICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX1RTQywg JnZhbCwgZmFsc2UsIGN0eHQpKSAhPSAwICkKICAgICAgICAgICAgIGdvdG8gZG9uZTsKICAgICAg ICAgX3JlZ3MuZWR4ID0gKHVpbnQzMl90KSh2YWwgPj4gMzIpOwogICAgICAgICBfcmVncy5lYXgg PSAodWludDMyX3QpKHZhbCA+PiAgMCk7CkBAIC00ODA0LDcgKzQ4MDQsNyBAQCB4ODZfZW11bGF0 ZSgKICAgICAgICAgdWludDY0X3QgdmFsOwogICAgICAgICBnZW5lcmF0ZV9leGNlcHRpb25faWYo IW1vZGVfcmluZzAoKSwgRVhDX0dQLCAwKTsKICAgICAgICAgZmFpbF9pZihvcHMtPnJlYWRfbXNy ID09IE5VTEwpOwotICAgICAgICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoKHVpbnQzMl90KV9y ZWdzLmVjeCwgJnZhbCwgY3R4dCkpICE9IDAgKQorICAgICAgICBpZiAoIChyYyA9IG9wcy0+cmVh ZF9tc3IoKHVpbnQzMl90KV9yZWdzLmVjeCwgJnZhbCwgZmFsc2UsIGN0eHQpKSAhPSAwICkKICAg ICAgICAgICAgIGdvdG8gZG9uZTsKICAgICAgICAgX3JlZ3MuZWR4ID0gKHVpbnQzMl90KSh2YWwg Pj4gMzIpOwogICAgICAgICBfcmVncy5lYXggPSAodWludDMyX3QpKHZhbCA+PiAgMCk7CkBAIC00 ODI1LDcgKzQ4MjUsNyBAQCB4ODZfZW11bGF0ZSgKICAgICAgICAgZ2VuZXJhdGVfZXhjZXB0aW9u X2lmKCFpbl9wcm90bW9kZShjdHh0LCBvcHMpLCBFWENfR1AsIDApOwogCiAgICAgICAgIGZhaWxf aWYob3BzLT5yZWFkX21zciA9PSBOVUxMKTsKLSAgICAgICAgaWYgKCAocmMgPSBvcHMtPnJlYWRf bXNyKE1TUl9TWVNFTlRFUl9DUywgJm1zcl9jb250ZW50LCBjdHh0KSkgIT0gMCApCisgICAgICAg IGlmICggKHJjID0gb3BzLT5yZWFkX21zcihNU1JfU1lTRU5URVJfQ1MsICZtc3JfY29udGVudCwg ZmFsc2UsIGN0eHQpKSAhPSAwICkKICAgICAgICAgICAgIGdvdG8gZG9uZTsKIAogICAgICAgICBn ZW5lcmF0ZV9leGNlcHRpb25faWYoIShtc3JfY29udGVudCAmIDB4ZmZmYyksIEVYQ19HUCwgMCk7 CkBAIC00ODUzLDExICs0ODUzLDExIEBAIHg4Nl9lbXVsYXRlKAogICAgICAgICAgICAgIChyYyA9 IG9wcy0+d3JpdGVfc2VnbWVudCh4ODZfc2VnX3NzLCAmc3JlZywgY3R4dCkpICE9IDAgKQogICAg ICAgICAgICAgZ290byBkb25lOwogCi0gICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihN U1JfU1lTRU5URVJfRUlQLCAmbXNyX2NvbnRlbnQsIGN0eHQpKSAhPSAwICkKKyAgICAgICAgaWYg KCAocmMgPSBvcHMtPnJlYWRfbXNyKE1TUl9TWVNFTlRFUl9FSVAsICZtc3JfY29udGVudCwgZmFs c2UsIGN0eHQpKSAhPSAwICkKICAgICAgICAgICAgIGdvdG8gZG9uZTsKICAgICAgICAgX3JlZ3Mu ZWlwID0gbG0gPyBtc3JfY29udGVudCA6ICh1aW50MzJfdCltc3JfY29udGVudDsKIAotICAgICAg ICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX1NZU0VOVEVSX0VTUCwgJm1zcl9jb250ZW50 LCBjdHh0KSkgIT0gMCApCisgICAgICAgIGlmICggKHJjID0gb3BzLT5yZWFkX21zcihNU1JfU1lT RU5URVJfRVNQLCAmbXNyX2NvbnRlbnQsIGZhbHNlLCBjdHh0KSkgIT0gMCApCiAgICAgICAgICAg ICBnb3RvIGRvbmU7CiAgICAgICAgIF9yZWdzLmVzcCA9IGxtID8gbXNyX2NvbnRlbnQgOiAodWlu dDMyX3QpbXNyX2NvbnRlbnQ7CiAKQEAgLTQ4NzMsNyArNDg3Myw3IEBAIHg4Nl9lbXVsYXRlKAog ICAgICAgICBnZW5lcmF0ZV9leGNlcHRpb25faWYoIWluX3Byb3Rtb2RlKGN0eHQsIG9wcyksIEVY Q19HUCwgMCk7CiAKICAgICAgICAgZmFpbF9pZihvcHMtPnJlYWRfbXNyID09IE5VTEwpOwotICAg ICAgICBpZiAoIChyYyA9IG9wcy0+cmVhZF9tc3IoTVNSX1NZU0VOVEVSX0NTLCAmbXNyX2NvbnRl bnQsIGN0eHQpKSAhPSAwICkKKyAgICAgICAgaWYgKCAocmMgPSBvcHMtPnJlYWRfbXNyKE1TUl9T WVNFTlRFUl9DUywgJm1zcl9jb250ZW50LCBmYWxzZSwgY3R4dCkpICE9IDAgKQogICAgICAgICAg ICAgZ290byBkb25lOwogCiAgICAgICAgIGdlbmVyYXRlX2V4Y2VwdGlvbl9pZighKG1zcl9jb250 ZW50ICYgMHhmZmZjKSwgRVhDX0dQLCAwKTsKZGlmZiAtLWdpdCBhL3hlbi9hcmNoL3g4Ni94ODZf ZW11bGF0ZS94ODZfZW11bGF0ZS5oIGIveGVuL2FyY2gveDg2L3g4Nl9lbXVsYXRlL3g4Nl9lbXVs YXRlLmgKaW5kZXggMTY0ZmMyNC4uODljZjIwZCAxMDA2NDQKLS0tIGEveGVuL2FyY2gveDg2L3g4 Nl9lbXVsYXRlL3g4Nl9lbXVsYXRlLmgKKysrIGIveGVuL2FyY2gveDg2L3g4Nl9lbXVsYXRlL3g4 Nl9lbXVsYXRlLmgKQEAgLTM3MiwxNSArMzcyLDE5IEBAIHN0cnVjdCB4ODZfZW11bGF0ZV9vcHMK ICAgICAvKgogICAgICAqIHJlYWRfbXNyOiBSZWFkIGZyb20gbW9kZWwtc3BlY2lmaWMgcmVnaXN0 ZXIuCiAgICAgICogIEByZWc6ICAgW0lOIF0gUmVnaXN0ZXIgdG8gcmVhZC4KKyAgICAgKiAgQHZh bDogICBbT1VUXSBWYWx1ZSByZWFkIChvbmx5IHZhbGlkIG9uIFg4NkVNVUxfT0tBWSkKKyAgICAg KiAgQHNwZWN1bGF0aXZlIFtJTl0gU3BlY3VsYXRpdmUgcmVhZD8KICAgICAgKi8KICAgICBpbnQg KCpyZWFkX21zcikoCiAgICAgICAgIHVuc2lnbmVkIGludCByZWcsCiAgICAgICAgIHVpbnQ2NF90 ICp2YWwsCisgICAgICAgIGJvb2wgc3BlY3VsYXRpdmUsCiAgICAgICAgIHN0cnVjdCB4ODZfZW11 bGF0ZV9jdHh0ICpjdHh0KTsKIAogICAgIC8qCi0gICAgICogd3JpdGVfZHI6IFdyaXRlIHRvIG1v ZGVsLXNwZWNpZmljIHJlZ2lzdGVyLgorICAgICAqIHdyaXRlX21zcjogV3JpdGUgdG8gbW9kZWwt c3BlY2lmaWMgcmVnaXN0ZXIuCiAgICAgICogIEByZWc6ICAgW0lOIF0gUmVnaXN0ZXIgdG8gd3Jp dGUuCisgICAgICogIEB2YWw6ICAgW0lOIF0gVmFsdWUgdG8gd3JpdGUuCiAgICAgICovCiAgICAg aW50ICgqd3JpdGVfbXNyKSgKICAgICAgICAgdW5zaWduZWQgaW50IHJlZywKLS0gCjIuMS40CgoK X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KWGVuLWRldmVs IG1haWxpbmcgbGlzdApYZW4tZGV2ZWxAbGlzdHMueGVuLm9yZwpodHRwczovL2xpc3RzLnhlbi5v cmcveGVuLWRldmVsCg==