Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 1 | # |
| 2 | # Basic validation of x86 versioned CPU models and CPU model aliases |
| 3 | # |
| 4 | # Copyright (c) 2019 Red Hat Inc |
| 5 | # |
| 6 | # Author: |
| 7 | # Eduardo Habkost <ehabkost@redhat.com> |
| 8 | # |
| 9 | # This library is free software; you can redistribute it and/or |
| 10 | # modify it under the terms of the GNU Lesser General Public |
| 11 | # License as published by the Free Software Foundation; either |
Gan Qixin | 6a2cd95 | 2020-11-11 02:42:22 +0800 | [diff] [blame] | 12 | # version 2.1 of the License, or (at your option) any later version. |
Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 13 | # |
| 14 | # This library is distributed in the hope that it will be useful, |
| 15 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 16 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 17 | # Lesser General Public License for more details. |
| 18 | # |
| 19 | # You should have received a copy of the GNU Lesser General Public |
| 20 | # License along with this library; if not, see <http://www.gnu.org/licenses/>. |
| 21 | # |
| 22 | |
| 23 | |
| 24 | import avocado_qemu |
| 25 | import re |
| 26 | |
Philippe Mathieu-Daudé | 2283b62 | 2021-09-27 18:14:33 +0200 | [diff] [blame] | 27 | class X86CPUModelAliases(avocado_qemu.QemuSystemTest): |
Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 28 | """ |
| 29 | Validation of PC CPU model versions and CPU model aliases |
| 30 | |
| 31 | :avocado: tags=arch:x86_64 |
| 32 | """ |
| 33 | def validate_aliases(self, cpus): |
| 34 | for c in cpus.values(): |
| 35 | if 'alias-of' in c: |
| 36 | # all aliases must point to a valid CPU model name: |
| 37 | self.assertIn(c['alias-of'], cpus, |
| 38 | '%s.alias-of (%s) is not a valid CPU model name' % (c['name'], c['alias-of'])) |
| 39 | # aliases must not point to aliases |
| 40 | self.assertNotIn('alias-of', cpus[c['alias-of']], |
| 41 | '%s.alias-of (%s) points to another alias' % (c['name'], c['alias-of'])) |
| 42 | |
| 43 | # aliases must not be static |
| 44 | self.assertFalse(c['static']) |
| 45 | |
| 46 | def validate_variant_aliases(self, cpus): |
| 47 | # -noTSX, -IBRS and -IBPB variants of CPU models are special: |
| 48 | # they shouldn't have their own versions: |
| 49 | self.assertNotIn("Haswell-noTSX-v1", cpus, |
| 50 | "Haswell-noTSX shouldn't be versioned") |
| 51 | self.assertNotIn("Broadwell-noTSX-v1", cpus, |
| 52 | "Broadwell-noTSX shouldn't be versioned") |
| 53 | self.assertNotIn("Nehalem-IBRS-v1", cpus, |
| 54 | "Nehalem-IBRS shouldn't be versioned") |
| 55 | self.assertNotIn("Westmere-IBRS-v1", cpus, |
| 56 | "Westmere-IBRS shouldn't be versioned") |
| 57 | self.assertNotIn("SandyBridge-IBRS-v1", cpus, |
| 58 | "SandyBridge-IBRS shouldn't be versioned") |
| 59 | self.assertNotIn("IvyBridge-IBRS-v1", cpus, |
| 60 | "IvyBridge-IBRS shouldn't be versioned") |
| 61 | self.assertNotIn("Haswell-noTSX-IBRS-v1", cpus, |
| 62 | "Haswell-noTSX-IBRS shouldn't be versioned") |
| 63 | self.assertNotIn("Haswell-IBRS-v1", cpus, |
| 64 | "Haswell-IBRS shouldn't be versioned") |
| 65 | self.assertNotIn("Broadwell-noTSX-IBRS-v1", cpus, |
| 66 | "Broadwell-noTSX-IBRS shouldn't be versioned") |
| 67 | self.assertNotIn("Broadwell-IBRS-v1", cpus, |
| 68 | "Broadwell-IBRS shouldn't be versioned") |
| 69 | self.assertNotIn("Skylake-Client-IBRS-v1", cpus, |
| 70 | "Skylake-Client-IBRS shouldn't be versioned") |
| 71 | self.assertNotIn("Skylake-Server-IBRS-v1", cpus, |
| 72 | "Skylake-Server-IBRS shouldn't be versioned") |
| 73 | self.assertNotIn("EPYC-IBPB-v1", cpus, |
| 74 | "EPYC-IBPB shouldn't be versioned") |
| 75 | |
| 76 | def test_4_0_alias_compatibility(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 77 | """ |
| 78 | Check if pc-*-4.0 unversioned CPU model won't be reported as aliases |
| 79 | |
| 80 | :avocado: tags=machine:pc-i440fx-4.0 |
| 81 | """ |
Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 82 | # pc-*-4.0 won't expose non-versioned CPU models as aliases |
| 83 | # We do this to help management software to keep compatibility |
| 84 | # with older QEMU versions that didn't have the versioned CPU model |
| 85 | self.vm.add_args('-S') |
Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 86 | self.vm.launch() |
Vladimir Sementsov-Ogievskiy | 684750a | 2023-10-06 18:41:15 +0300 | [diff] [blame] | 87 | cpus = dict((m['name'], m) for m in |
| 88 | self.vm.cmd('query-cpu-definitions')) |
Eduardo Habkost | dcafd1e | 2019-06-27 21:28:39 -0300 | [diff] [blame] | 89 | |
| 90 | self.assertFalse(cpus['Cascadelake-Server']['static'], |
| 91 | 'unversioned Cascadelake-Server CPU model must not be static') |
| 92 | self.assertNotIn('alias-of', cpus['Cascadelake-Server'], |
| 93 | 'Cascadelake-Server must not be an alias') |
| 94 | self.assertNotIn('alias-of', cpus['Cascadelake-Server-v1'], |
| 95 | 'Cascadelake-Server-v1 must not be an alias') |
| 96 | |
| 97 | self.assertFalse(cpus['qemu64']['static'], |
| 98 | 'unversioned qemu64 CPU model must not be static') |
| 99 | self.assertNotIn('alias-of', cpus['qemu64'], |
| 100 | 'qemu64 must not be an alias') |
| 101 | self.assertNotIn('alias-of', cpus['qemu64-v1'], |
| 102 | 'qemu64-v1 must not be an alias') |
| 103 | |
| 104 | self.validate_variant_aliases(cpus) |
| 105 | |
| 106 | # On pc-*-4.0, no CPU model should be reported as an alias: |
| 107 | for name,c in cpus.items(): |
| 108 | self.assertNotIn('alias-of', c, "%s shouldn't be an alias" % (name)) |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 109 | |
| 110 | def test_4_1_alias(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 111 | """ |
| 112 | Check if unversioned CPU model is an alias pointing to right version |
| 113 | |
| 114 | :avocado: tags=machine:pc-i440fx-4.1 |
| 115 | """ |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 116 | self.vm.add_args('-S') |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 117 | self.vm.launch() |
| 118 | |
Vladimir Sementsov-Ogievskiy | 684750a | 2023-10-06 18:41:15 +0300 | [diff] [blame] | 119 | cpus = dict((m['name'], m) for m in |
| 120 | self.vm.cmd('query-cpu-definitions')) |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 121 | |
| 122 | self.assertFalse(cpus['Cascadelake-Server']['static'], |
| 123 | 'unversioned Cascadelake-Server CPU model must not be static') |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 124 | self.assertEqual(cpus['Cascadelake-Server'].get('alias-of'), |
| 125 | 'Cascadelake-Server-v1', |
| 126 | 'Cascadelake-Server must be an alias of Cascadelake-Server-v1') |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 127 | self.assertNotIn('alias-of', cpus['Cascadelake-Server-v1'], |
| 128 | 'Cascadelake-Server-v1 must not be an alias') |
| 129 | |
| 130 | self.assertFalse(cpus['qemu64']['static'], |
| 131 | 'unversioned qemu64 CPU model must not be static') |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 132 | self.assertEqual(cpus['qemu64'].get('alias-of'), 'qemu64-v1', |
| 133 | 'qemu64 must be an alias of qemu64-v1') |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 134 | self.assertNotIn('alias-of', cpus['qemu64-v1'], |
| 135 | 'qemu64-v1 must not be an alias') |
| 136 | |
| 137 | self.validate_variant_aliases(cpus) |
| 138 | |
| 139 | # On pc-*-4.1, -noTSX and -IBRS models should be aliases: |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 140 | self.assertEqual(cpus["Haswell"].get('alias-of'), |
| 141 | "Haswell-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 142 | "Haswell must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 143 | self.assertEqual(cpus["Haswell-noTSX"].get('alias-of'), |
| 144 | "Haswell-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 145 | "Haswell-noTSX must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 146 | self.assertEqual(cpus["Haswell-IBRS"].get('alias-of'), |
| 147 | "Haswell-v3", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 148 | "Haswell-IBRS must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 149 | self.assertEqual(cpus["Haswell-noTSX-IBRS"].get('alias-of'), |
| 150 | "Haswell-v4", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 151 | "Haswell-noTSX-IBRS must be an alias") |
| 152 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 153 | self.assertEqual(cpus["Broadwell"].get('alias-of'), |
| 154 | "Broadwell-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 155 | "Broadwell must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 156 | self.assertEqual(cpus["Broadwell-noTSX"].get('alias-of'), |
| 157 | "Broadwell-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 158 | "Broadwell-noTSX must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 159 | self.assertEqual(cpus["Broadwell-IBRS"].get('alias-of'), |
| 160 | "Broadwell-v3", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 161 | "Broadwell-IBRS must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 162 | self.assertEqual(cpus["Broadwell-noTSX-IBRS"].get('alias-of'), |
| 163 | "Broadwell-v4", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 164 | "Broadwell-noTSX-IBRS must be an alias") |
| 165 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 166 | self.assertEqual(cpus["Nehalem"].get('alias-of'), |
| 167 | "Nehalem-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 168 | "Nehalem must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 169 | self.assertEqual(cpus["Nehalem-IBRS"].get('alias-of'), |
| 170 | "Nehalem-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 171 | "Nehalem-IBRS must be an alias") |
| 172 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 173 | self.assertEqual(cpus["Westmere"].get('alias-of'), |
| 174 | "Westmere-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 175 | "Westmere must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 176 | self.assertEqual(cpus["Westmere-IBRS"].get('alias-of'), |
| 177 | "Westmere-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 178 | "Westmere-IBRS must be an alias") |
| 179 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 180 | self.assertEqual(cpus["SandyBridge"].get('alias-of'), |
| 181 | "SandyBridge-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 182 | "SandyBridge must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 183 | self.assertEqual(cpus["SandyBridge-IBRS"].get('alias-of'), |
| 184 | "SandyBridge-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 185 | "SandyBridge-IBRS must be an alias") |
| 186 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 187 | self.assertEqual(cpus["IvyBridge"].get('alias-of'), |
| 188 | "IvyBridge-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 189 | "IvyBridge must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 190 | self.assertEqual(cpus["IvyBridge-IBRS"].get('alias-of'), |
| 191 | "IvyBridge-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 192 | "IvyBridge-IBRS must be an alias") |
| 193 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 194 | self.assertEqual(cpus["Skylake-Client"].get('alias-of'), |
| 195 | "Skylake-Client-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 196 | "Skylake-Client must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 197 | self.assertEqual(cpus["Skylake-Client-IBRS"].get('alias-of'), |
| 198 | "Skylake-Client-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 199 | "Skylake-Client-IBRS must be an alias") |
| 200 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 201 | self.assertEqual(cpus["Skylake-Server"].get('alias-of'), |
| 202 | "Skylake-Server-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 203 | "Skylake-Server must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 204 | self.assertEqual(cpus["Skylake-Server-IBRS"].get('alias-of'), |
| 205 | "Skylake-Server-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 206 | "Skylake-Server-IBRS must be an alias") |
| 207 | |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 208 | self.assertEqual(cpus["EPYC"].get('alias-of'), |
| 209 | "EPYC-v1", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 210 | "EPYC must be an alias") |
Thomas Huth | 861f724 | 2023-11-14 14:43:26 +0100 | [diff] [blame] | 211 | self.assertEqual(cpus["EPYC-IBPB"].get('alias-of'), |
| 212 | "EPYC-v2", |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 213 | "EPYC-IBPB must be an alias") |
| 214 | |
| 215 | self.validate_aliases(cpus) |
| 216 | |
| 217 | def test_none_alias(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 218 | """ |
| 219 | Check if unversioned CPU model is an alias pointing to some version |
| 220 | |
| 221 | :avocado: tags=machine:none |
| 222 | """ |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 223 | self.vm.add_args('-S') |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 224 | self.vm.launch() |
| 225 | |
Vladimir Sementsov-Ogievskiy | 684750a | 2023-10-06 18:41:15 +0300 | [diff] [blame] | 226 | cpus = dict((m['name'], m) for m in |
| 227 | self.vm.cmd('query-cpu-definitions')) |
Eduardo Habkost | 0788a56 | 2019-06-27 21:28:42 -0300 | [diff] [blame] | 228 | |
| 229 | self.assertFalse(cpus['Cascadelake-Server']['static'], |
| 230 | 'unversioned Cascadelake-Server CPU model must not be static') |
| 231 | self.assertTrue(re.match('Cascadelake-Server-v[0-9]+', cpus['Cascadelake-Server']['alias-of']), |
| 232 | 'Cascadelake-Server must be an alias of versioned CPU model') |
| 233 | self.assertNotIn('alias-of', cpus['Cascadelake-Server-v1'], |
| 234 | 'Cascadelake-Server-v1 must not be an alias') |
| 235 | |
| 236 | self.assertFalse(cpus['qemu64']['static'], |
| 237 | 'unversioned qemu64 CPU model must not be static') |
| 238 | self.assertTrue(re.match('qemu64-v[0-9]+', cpus['qemu64']['alias-of']), |
| 239 | 'qemu64 must be an alias of versioned CPU model') |
| 240 | self.assertNotIn('alias-of', cpus['qemu64-v1'], |
| 241 | 'qemu64-v1 must not be an alias') |
| 242 | |
| 243 | self.validate_aliases(cpus) |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 244 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 245 | |
Philippe Mathieu-Daudé | 2283b62 | 2021-09-27 18:14:33 +0200 | [diff] [blame] | 246 | class CascadelakeArchCapabilities(avocado_qemu.QemuSystemTest): |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 247 | """ |
| 248 | Validation of Cascadelake arch-capabilities |
| 249 | |
| 250 | :avocado: tags=arch:x86_64 |
| 251 | """ |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 252 | def get_cpu_prop(self, prop): |
Vladimir Sementsov-Ogievskiy | 684750a | 2023-10-06 18:41:15 +0300 | [diff] [blame] | 253 | cpu_path = self.vm.cmd('query-cpus-fast')[0].get('qom-path') |
| 254 | return self.vm.cmd('qom-get', path=cpu_path, property=prop) |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 255 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 256 | def test_4_1(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 257 | """ |
| 258 | :avocado: tags=machine:pc-i440fx-4.1 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 259 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 260 | """ |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 261 | # machine-type only: |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 262 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 263 | self.set_vm_arg('-cpu', |
| 264 | 'Cascadelake-Server,x-force-features=on,check=off,' |
| 265 | 'enforce=off') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 266 | self.vm.launch() |
| 267 | self.assertFalse(self.get_cpu_prop('arch-capabilities'), |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 268 | 'pc-i440fx-4.1 + Cascadelake-Server should not have arch-capabilities') |
| 269 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 270 | def test_4_0(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 271 | """ |
| 272 | :avocado: tags=machine:pc-i440fx-4.0 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 273 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 274 | """ |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 275 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 276 | self.set_vm_arg('-cpu', |
| 277 | 'Cascadelake-Server,x-force-features=on,check=off,' |
| 278 | 'enforce=off') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 279 | self.vm.launch() |
| 280 | self.assertFalse(self.get_cpu_prop('arch-capabilities'), |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 281 | 'pc-i440fx-4.0 + Cascadelake-Server should not have arch-capabilities') |
| 282 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 283 | def test_set_4_0(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 284 | """ |
| 285 | :avocado: tags=machine:pc-i440fx-4.0 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 286 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 287 | """ |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 288 | # command line must override machine-type if CPU model is not versioned: |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 289 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 290 | self.set_vm_arg('-cpu', |
| 291 | 'Cascadelake-Server,x-force-features=on,check=off,' |
| 292 | 'enforce=off,+arch-capabilities') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 293 | self.vm.launch() |
| 294 | self.assertTrue(self.get_cpu_prop('arch-capabilities'), |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 295 | 'pc-i440fx-4.0 + Cascadelake-Server,+arch-capabilities should have arch-capabilities') |
| 296 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 297 | def test_unset_4_1(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 298 | """ |
| 299 | :avocado: tags=machine:pc-i440fx-4.1 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 300 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 301 | """ |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 302 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 303 | self.set_vm_arg('-cpu', |
| 304 | 'Cascadelake-Server,x-force-features=on,check=off,' |
| 305 | 'enforce=off,-arch-capabilities') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 306 | self.vm.launch() |
| 307 | self.assertFalse(self.get_cpu_prop('arch-capabilities'), |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 308 | 'pc-i440fx-4.1 + Cascadelake-Server,-arch-capabilities should not have arch-capabilities') |
| 309 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 310 | def test_v1_4_0(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 311 | """ |
| 312 | :avocado: tags=machine:pc-i440fx-4.0 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 313 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 314 | """ |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 315 | # versioned CPU model overrides machine-type: |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 316 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 317 | self.set_vm_arg('-cpu', |
| 318 | 'Cascadelake-Server-v1,x-force-features=on,check=off,' |
| 319 | 'enforce=off') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 320 | self.vm.launch() |
| 321 | self.assertFalse(self.get_cpu_prop('arch-capabilities'), |
Cleber Rosa | d0b6308 | 2019-08-28 15:36:27 -0400 | [diff] [blame] | 322 | 'pc-i440fx-4.0 + Cascadelake-Server-v1 should not have arch-capabilities') |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 323 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 324 | def test_v2_4_0(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 325 | """ |
| 326 | :avocado: tags=machine:pc-i440fx-4.0 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 327 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 328 | """ |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 329 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 330 | self.set_vm_arg('-cpu', |
| 331 | 'Cascadelake-Server-v2,x-force-features=on,check=off,' |
| 332 | 'enforce=off') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 333 | self.vm.launch() |
| 334 | self.assertTrue(self.get_cpu_prop('arch-capabilities'), |
| 335 | 'pc-i440fx-4.0 + Cascadelake-Server-v2 should have arch-capabilities') |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 336 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 337 | def test_v1_set_4_0(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 338 | """ |
| 339 | :avocado: tags=machine:pc-i440fx-4.0 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 340 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 341 | """ |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 342 | # command line must override machine-type and versioned CPU model: |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 343 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 344 | self.set_vm_arg('-cpu', |
| 345 | 'Cascadelake-Server-v1,x-force-features=on,check=off,' |
| 346 | 'enforce=off,+arch-capabilities') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 347 | self.vm.launch() |
| 348 | self.assertTrue(self.get_cpu_prop('arch-capabilities'), |
| 349 | 'pc-i440fx-4.0 + Cascadelake-Server-v1,+arch-capabilities should have arch-capabilities') |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 350 | |
Cleber Rosa | 7219c2e | 2019-08-28 15:36:28 -0400 | [diff] [blame] | 351 | def test_v2_unset_4_1(self): |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 352 | """ |
| 353 | :avocado: tags=machine:pc-i440fx-4.1 |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 354 | :avocado: tags=cpu:Cascadelake-Server |
Cleber Rosa | ba21bde | 2019-11-04 10:13:18 -0500 | [diff] [blame] | 355 | """ |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 356 | self.vm.add_args('-S') |
Wainer dos Santos Moschetta | 3843a32 | 2021-04-30 10:34:14 -0300 | [diff] [blame] | 357 | self.set_vm_arg('-cpu', |
| 358 | 'Cascadelake-Server-v2,x-force-features=on,check=off,' |
| 359 | 'enforce=off,-arch-capabilities') |
Cleber Rosa | 3e9c181 | 2019-09-24 15:44:59 -0400 | [diff] [blame] | 360 | self.vm.launch() |
| 361 | self.assertFalse(self.get_cpu_prop('arch-capabilities'), |
Eduardo Habkost | fd63c6d | 2019-06-27 21:28:44 -0300 | [diff] [blame] | 362 | 'pc-i440fx-4.1 + Cascadelake-Server-v2,-arch-capabilities should not have arch-capabilities') |