xref: /titanic_41/usr/src/uts/i86pc/os/cpuid.c (revision 6d970e53a6c1130d58dea5b08c0333ee46049844)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
23  * Copyright (c) 2011 by Delphix. All rights reserved.
24  * Copyright 2013 Nexenta Systems, Inc. All rights reserved.
25  */
26 /*
27  * Copyright (c) 2010, Intel Corporation.
28  * All rights reserved.
29  */
30 /*
31  * Portions Copyright 2009 Advanced Micro Devices, Inc.
32  */
33 /*
34  * Copyright (c) 2012, Joyent, Inc. All rights reserved.
35  */
36 /*
37  * Various routines to handle identification
38  * and classification of x86 processors.
39  */
40 
41 #include <sys/types.h>
42 #include <sys/archsystm.h>
43 #include <sys/x86_archext.h>
44 #include <sys/kmem.h>
45 #include <sys/systm.h>
46 #include <sys/cmn_err.h>
47 #include <sys/sunddi.h>
48 #include <sys/sunndi.h>
49 #include <sys/cpuvar.h>
50 #include <sys/processor.h>
51 #include <sys/sysmacros.h>
52 #include <sys/pg.h>
53 #include <sys/fp.h>
54 #include <sys/controlregs.h>
55 #include <sys/bitmap.h>
56 #include <sys/auxv_386.h>
57 #include <sys/memnode.h>
58 #include <sys/pci_cfgspace.h>
59 
60 #ifdef __xpv
61 #include <sys/hypervisor.h>
62 #else
63 #include <sys/ontrap.h>
64 #endif
65 
66 /*
67  * Pass 0 of cpuid feature analysis happens in locore. It contains special code
68  * to recognize Cyrix processors that are not cpuid-compliant, and to deal with
69  * them accordingly. For most modern processors, feature detection occurs here
70  * in pass 1.
71  *
72  * Pass 1 of cpuid feature analysis happens just at the beginning of mlsetup()
73  * for the boot CPU and does the basic analysis that the early kernel needs.
74  * x86_featureset is set based on the return value of cpuid_pass1() of the boot
75  * CPU.
76  *
77  * Pass 1 includes:
78  *
79  *	o Determining vendor/model/family/stepping and setting x86_type and
80  *	  x86_vendor accordingly.
81  *	o Processing the feature flags returned by the cpuid instruction while
82  *	  applying any workarounds or tricks for the specific processor.
83  *	o Mapping the feature flags into Solaris feature bits (X86_*).
84  *	o Processing extended feature flags if supported by the processor,
85  *	  again while applying specific processor knowledge.
86  *	o Determining the CMT characteristics of the system.
87  *
88  * Pass 1 is done on non-boot CPUs during their initialization and the results
89  * are used only as a meager attempt at ensuring that all processors within the
90  * system support the same features.
91  *
92  * Pass 2 of cpuid feature analysis happens just at the beginning
93  * of startup().  It just copies in and corrects the remainder
94  * of the cpuid data we depend on: standard cpuid functions that we didn't
95  * need for pass1 feature analysis, and extended cpuid functions beyond the
96  * simple feature processing done in pass1.
97  *
98  * Pass 3 of cpuid analysis is invoked after basic kernel services; in
99  * particular kernel memory allocation has been made available. It creates a
100  * readable brand string based on the data collected in the first two passes.
101  *
102  * Pass 4 of cpuid analysis is invoked after post_startup() when all
103  * the support infrastructure for various hardware features has been
104  * initialized. It determines which processor features will be reported
105  * to userland via the aux vector.
106  *
107  * All passes are executed on all CPUs, but only the boot CPU determines what
108  * features the kernel will use.
109  *
110  * Much of the worst junk in this file is for the support of processors
111  * that didn't really implement the cpuid instruction properly.
112  *
113  * NOTE: The accessor functions (cpuid_get*) are aware of, and ASSERT upon,
114  * the pass numbers.  Accordingly, changes to the pass code may require changes
115  * to the accessor code.
116  */
117 
118 uint_t x86_vendor = X86_VENDOR_IntelClone;
119 uint_t x86_type = X86_TYPE_OTHER;
120 uint_t x86_clflush_size = 0;
121 
122 uint_t pentiumpro_bug4046376;
123 
124 uchar_t x86_featureset[BT_SIZEOFMAP(NUM_X86_FEATURES)];
125 
126 static char *x86_feature_names[NUM_X86_FEATURES] = {
127 	"lgpg",
128 	"tsc",
129 	"msr",
130 	"mtrr",
131 	"pge",
132 	"de",
133 	"cmov",
134 	"mmx",
135 	"mca",
136 	"pae",
137 	"cv8",
138 	"pat",
139 	"sep",
140 	"sse",
141 	"sse2",
142 	"htt",
143 	"asysc",
144 	"nx",
145 	"sse3",
146 	"cx16",
147 	"cmp",
148 	"tscp",
149 	"mwait",
150 	"sse4a",
151 	"cpuid",
152 	"ssse3",
153 	"sse4_1",
154 	"sse4_2",
155 	"1gpg",
156 	"clfsh",
157 	"64",
158 	"aes",
159 	"pclmulqdq",
160 	"xsave",
161 	"avx",
162 	"vmx",
163 	"svm",
164 	"topoext",
165 	"f16c",
166 	"rdrand"
167 };
168 
169 boolean_t
170 is_x86_feature(void *featureset, uint_t feature)
171 {
172 	ASSERT(feature < NUM_X86_FEATURES);
173 	return (BT_TEST((ulong_t *)featureset, feature));
174 }
175 
176 void
177 add_x86_feature(void *featureset, uint_t feature)
178 {
179 	ASSERT(feature < NUM_X86_FEATURES);
180 	BT_SET((ulong_t *)featureset, feature);
181 }
182 
183 void
184 remove_x86_feature(void *featureset, uint_t feature)
185 {
186 	ASSERT(feature < NUM_X86_FEATURES);
187 	BT_CLEAR((ulong_t *)featureset, feature);
188 }
189 
190 boolean_t
191 compare_x86_featureset(void *setA, void *setB)
192 {
193 	/*
194 	 * We assume that the unused bits of the bitmap are always zero.
195 	 */
196 	if (memcmp(setA, setB, BT_SIZEOFMAP(NUM_X86_FEATURES)) == 0) {
197 		return (B_TRUE);
198 	} else {
199 		return (B_FALSE);
200 	}
201 }
202 
203 void
204 print_x86_featureset(void *featureset)
205 {
206 	uint_t i;
207 
208 	for (i = 0; i < NUM_X86_FEATURES; i++) {
209 		if (is_x86_feature(featureset, i)) {
210 			cmn_err(CE_CONT, "?x86_feature: %s\n",
211 			    x86_feature_names[i]);
212 		}
213 	}
214 }
215 
216 static size_t xsave_state_size = 0;
217 uint64_t xsave_bv_all = (XFEATURE_LEGACY_FP | XFEATURE_SSE);
218 boolean_t xsave_force_disable = B_FALSE;
219 
220 /*
221  * This is set to platform type we are running on.
222  */
223 static int platform_type = -1;
224 
225 #if !defined(__xpv)
226 /*
227  * Variable to patch if hypervisor platform detection needs to be
228  * disabled (e.g. platform_type will always be HW_NATIVE if this is 0).
229  */
230 int enable_platform_detection = 1;
231 #endif
232 
233 /*
234  * monitor/mwait info.
235  *
236  * size_actual and buf_actual are the real address and size allocated to get
237  * proper mwait_buf alignement.  buf_actual and size_actual should be passed
238  * to kmem_free().  Currently kmem_alloc() and mwait happen to both use
239  * processor cache-line alignment, but this is not guarantied in the furture.
240  */
241 struct mwait_info {
242 	size_t		mon_min;	/* min size to avoid missed wakeups */
243 	size_t		mon_max;	/* size to avoid false wakeups */
244 	size_t		size_actual;	/* size actually allocated */
245 	void		*buf_actual;	/* memory actually allocated */
246 	uint32_t	support;	/* processor support of monitor/mwait */
247 };
248 
249 /*
250  * xsave/xrestor info.
251  *
252  * This structure contains HW feature bits and size of the xsave save area.
253  * Note: the kernel will use the maximum size required for all hardware
254  * features. It is not optimize for potential memory savings if features at
255  * the end of the save area are not enabled.
256  */
257 struct xsave_info {
258 	uint32_t	xsav_hw_features_low;   /* Supported HW features */
259 	uint32_t	xsav_hw_features_high;  /* Supported HW features */
260 	size_t		xsav_max_size;  /* max size save area for HW features */
261 	size_t		ymm_size;	/* AVX: size of ymm save area */
262 	size_t		ymm_offset;	/* AVX: offset for ymm save area */
263 };
264 
265 
266 /*
267  * These constants determine how many of the elements of the
268  * cpuid we cache in the cpuid_info data structure; the
269  * remaining elements are accessible via the cpuid instruction.
270  */
271 
272 #define	NMAX_CPI_STD	6		/* eax = 0 .. 5 */
273 #define	NMAX_CPI_EXTD	0x1f		/* eax = 0x80000000 .. 0x8000001e */
274 
275 /*
276  * Some terminology needs to be explained:
277  *  - Socket: Something that can be plugged into a motherboard.
278  *  - Package: Same as socket
279  *  - Chip: Same as socket. Note that AMD's documentation uses term "chip"
280  *    differently: there, chip is the same as processor node (below)
281  *  - Processor node: Some AMD processors have more than one
282  *    "subprocessor" embedded in a package. These subprocessors (nodes)
283  *    are fully-functional processors themselves with cores, caches,
284  *    memory controllers, PCI configuration spaces. They are connected
285  *    inside the package with Hypertransport links. On single-node
286  *    processors, processor node is equivalent to chip/socket/package.
287  *  - Compute Unit: Some AMD processors pair cores in "compute units" that
288  *    share the FPU and the I$ and L2 caches.
289  */
290 
291 struct cpuid_info {
292 	uint_t cpi_pass;		/* last pass completed */
293 	/*
294 	 * standard function information
295 	 */
296 	uint_t cpi_maxeax;		/* fn 0: %eax */
297 	char cpi_vendorstr[13];		/* fn 0: %ebx:%ecx:%edx */
298 	uint_t cpi_vendor;		/* enum of cpi_vendorstr */
299 
300 	uint_t cpi_family;		/* fn 1: extended family */
301 	uint_t cpi_model;		/* fn 1: extended model */
302 	uint_t cpi_step;		/* fn 1: stepping */
303 	chipid_t cpi_chipid;		/* fn 1: %ebx:  Intel: chip # */
304 					/*		AMD: package/socket # */
305 	uint_t cpi_brandid;		/* fn 1: %ebx: brand ID */
306 	int cpi_clogid;			/* fn 1: %ebx: thread # */
307 	uint_t cpi_ncpu_per_chip;	/* fn 1: %ebx: logical cpu count */
308 	uint8_t cpi_cacheinfo[16];	/* fn 2: intel-style cache desc */
309 	uint_t cpi_ncache;		/* fn 2: number of elements */
310 	uint_t cpi_ncpu_shr_last_cache;	/* fn 4: %eax: ncpus sharing cache */
311 	id_t cpi_last_lvl_cacheid;	/* fn 4: %eax: derived cache id */
312 	uint_t cpi_std_4_size;		/* fn 4: number of fn 4 elements */
313 	struct cpuid_regs **cpi_std_4;	/* fn 4: %ecx == 0 .. fn4_size */
314 	struct cpuid_regs cpi_std[NMAX_CPI_STD];	/* 0 .. 5 */
315 	/*
316 	 * extended function information
317 	 */
318 	uint_t cpi_xmaxeax;		/* fn 0x80000000: %eax */
319 	char cpi_brandstr[49];		/* fn 0x8000000[234] */
320 	uint8_t cpi_pabits;		/* fn 0x80000006: %eax */
321 	uint8_t	cpi_vabits;		/* fn 0x80000006: %eax */
322 	struct	cpuid_regs cpi_extd[NMAX_CPI_EXTD];	/* 0x800000XX */
323 
324 	id_t cpi_coreid;		/* same coreid => strands share core */
325 	int cpi_pkgcoreid;		/* core number within single package */
326 	uint_t cpi_ncore_per_chip;	/* AMD: fn 0x80000008: %ecx[7-0] */
327 					/* Intel: fn 4: %eax[31-26] */
328 	/*
329 	 * supported feature information
330 	 */
331 	uint32_t cpi_support[5];
332 #define	STD_EDX_FEATURES	0
333 #define	AMD_EDX_FEATURES	1
334 #define	TM_EDX_FEATURES		2
335 #define	STD_ECX_FEATURES	3
336 #define	AMD_ECX_FEATURES	4
337 	/*
338 	 * Synthesized information, where known.
339 	 */
340 	uint32_t cpi_chiprev;		/* See X86_CHIPREV_* in x86_archext.h */
341 	const char *cpi_chiprevstr;	/* May be NULL if chiprev unknown */
342 	uint32_t cpi_socket;		/* Chip package/socket type */
343 
344 	struct mwait_info cpi_mwait;	/* fn 5: monitor/mwait info */
345 	uint32_t cpi_apicid;
346 	uint_t cpi_procnodeid;		/* AMD: nodeID on HT, Intel: chipid */
347 	uint_t cpi_procnodes_per_pkg;	/* AMD: # of nodes in the package */
348 					/* Intel: 1 */
349 	uint_t cpi_compunitid;		/* AMD: ComputeUnit ID, Intel: coreid */
350 	uint_t cpi_cores_per_compunit;	/* AMD: # of cores in the ComputeUnit */
351 
352 	struct xsave_info cpi_xsave;	/* fn D: xsave/xrestor info */
353 };
354 
355 
356 static struct cpuid_info cpuid_info0;
357 
358 /*
359  * These bit fields are defined by the Intel Application Note AP-485
360  * "Intel Processor Identification and the CPUID Instruction"
361  */
362 #define	CPI_FAMILY_XTD(cpi)	BITX((cpi)->cpi_std[1].cp_eax, 27, 20)
363 #define	CPI_MODEL_XTD(cpi)	BITX((cpi)->cpi_std[1].cp_eax, 19, 16)
364 #define	CPI_TYPE(cpi)		BITX((cpi)->cpi_std[1].cp_eax, 13, 12)
365 #define	CPI_FAMILY(cpi)		BITX((cpi)->cpi_std[1].cp_eax, 11, 8)
366 #define	CPI_STEP(cpi)		BITX((cpi)->cpi_std[1].cp_eax, 3, 0)
367 #define	CPI_MODEL(cpi)		BITX((cpi)->cpi_std[1].cp_eax, 7, 4)
368 
369 #define	CPI_FEATURES_EDX(cpi)		((cpi)->cpi_std[1].cp_edx)
370 #define	CPI_FEATURES_ECX(cpi)		((cpi)->cpi_std[1].cp_ecx)
371 #define	CPI_FEATURES_XTD_EDX(cpi)	((cpi)->cpi_extd[1].cp_edx)
372 #define	CPI_FEATURES_XTD_ECX(cpi)	((cpi)->cpi_extd[1].cp_ecx)
373 
374 #define	CPI_BRANDID(cpi)	BITX((cpi)->cpi_std[1].cp_ebx, 7, 0)
375 #define	CPI_CHUNKS(cpi)		BITX((cpi)->cpi_std[1].cp_ebx, 15, 7)
376 #define	CPI_CPU_COUNT(cpi)	BITX((cpi)->cpi_std[1].cp_ebx, 23, 16)
377 #define	CPI_APIC_ID(cpi)	BITX((cpi)->cpi_std[1].cp_ebx, 31, 24)
378 
379 #define	CPI_MAXEAX_MAX		0x100		/* sanity control */
380 #define	CPI_XMAXEAX_MAX		0x80000100
381 #define	CPI_FN4_ECX_MAX		0x20		/* sanity: max fn 4 levels */
382 #define	CPI_FNB_ECX_MAX		0x20		/* sanity: max fn B levels */
383 
384 /*
385  * Function 4 (Deterministic Cache Parameters) macros
386  * Defined by Intel Application Note AP-485
387  */
388 #define	CPI_NUM_CORES(regs)		BITX((regs)->cp_eax, 31, 26)
389 #define	CPI_NTHR_SHR_CACHE(regs)	BITX((regs)->cp_eax, 25, 14)
390 #define	CPI_FULL_ASSOC_CACHE(regs)	BITX((regs)->cp_eax, 9, 9)
391 #define	CPI_SELF_INIT_CACHE(regs)	BITX((regs)->cp_eax, 8, 8)
392 #define	CPI_CACHE_LVL(regs)		BITX((regs)->cp_eax, 7, 5)
393 #define	CPI_CACHE_TYPE(regs)		BITX((regs)->cp_eax, 4, 0)
394 #define	CPI_CPU_LEVEL_TYPE(regs)	BITX((regs)->cp_ecx, 15, 8)
395 
396 #define	CPI_CACHE_WAYS(regs)		BITX((regs)->cp_ebx, 31, 22)
397 #define	CPI_CACHE_PARTS(regs)		BITX((regs)->cp_ebx, 21, 12)
398 #define	CPI_CACHE_COH_LN_SZ(regs)	BITX((regs)->cp_ebx, 11, 0)
399 
400 #define	CPI_CACHE_SETS(regs)		BITX((regs)->cp_ecx, 31, 0)
401 
402 #define	CPI_PREFCH_STRIDE(regs)		BITX((regs)->cp_edx, 9, 0)
403 
404 
405 /*
406  * A couple of shorthand macros to identify "later" P6-family chips
407  * like the Pentium M and Core.  First, the "older" P6-based stuff
408  * (loosely defined as "pre-Pentium-4"):
409  * P6, PII, Mobile PII, PII Xeon, PIII, Mobile PIII, PIII Xeon
410  */
411 
412 #define	IS_LEGACY_P6(cpi) (			\
413 	cpi->cpi_family == 6 && 		\
414 		(cpi->cpi_model == 1 ||		\
415 		cpi->cpi_model == 3 ||		\
416 		cpi->cpi_model == 5 ||		\
417 		cpi->cpi_model == 6 ||		\
418 		cpi->cpi_model == 7 ||		\
419 		cpi->cpi_model == 8 ||		\
420 		cpi->cpi_model == 0xA ||	\
421 		cpi->cpi_model == 0xB)		\
422 )
423 
424 /* A "new F6" is everything with family 6 that's not the above */
425 #define	IS_NEW_F6(cpi) ((cpi->cpi_family == 6) && !IS_LEGACY_P6(cpi))
426 
427 /* Extended family/model support */
428 #define	IS_EXTENDED_MODEL_INTEL(cpi) (cpi->cpi_family == 0x6 || \
429 	cpi->cpi_family >= 0xf)
430 
431 /*
432  * Info for monitor/mwait idle loop.
433  *
434  * See cpuid section of "Intel 64 and IA-32 Architectures Software Developer's
435  * Manual Volume 2A: Instruction Set Reference, A-M" #25366-022US, November
436  * 2006.
437  * See MONITOR/MWAIT section of "AMD64 Architecture Programmer's Manual
438  * Documentation Updates" #33633, Rev 2.05, December 2006.
439  */
440 #define	MWAIT_SUPPORT		(0x00000001)	/* mwait supported */
441 #define	MWAIT_EXTENSIONS	(0x00000002)	/* extenstion supported */
442 #define	MWAIT_ECX_INT_ENABLE	(0x00000004)	/* ecx 1 extension supported */
443 #define	MWAIT_SUPPORTED(cpi)	((cpi)->cpi_std[1].cp_ecx & CPUID_INTC_ECX_MON)
444 #define	MWAIT_INT_ENABLE(cpi)	((cpi)->cpi_std[5].cp_ecx & 0x2)
445 #define	MWAIT_EXTENSION(cpi)	((cpi)->cpi_std[5].cp_ecx & 0x1)
446 #define	MWAIT_SIZE_MIN(cpi)	BITX((cpi)->cpi_std[5].cp_eax, 15, 0)
447 #define	MWAIT_SIZE_MAX(cpi)	BITX((cpi)->cpi_std[5].cp_ebx, 15, 0)
448 /*
449  * Number of sub-cstates for a given c-state.
450  */
451 #define	MWAIT_NUM_SUBC_STATES(cpi, c_state)			\
452 	BITX((cpi)->cpi_std[5].cp_edx, c_state + 3, c_state)
453 
454 /*
455  * XSAVE leaf 0xD enumeration
456  */
457 #define	CPUID_LEAFD_2_YMM_OFFSET	576
458 #define	CPUID_LEAFD_2_YMM_SIZE		256
459 
460 /*
461  * Functions we consune from cpuid_subr.c;  don't publish these in a header
462  * file to try and keep people using the expected cpuid_* interfaces.
463  */
464 extern uint32_t _cpuid_skt(uint_t, uint_t, uint_t, uint_t);
465 extern const char *_cpuid_sktstr(uint_t, uint_t, uint_t, uint_t);
466 extern uint32_t _cpuid_chiprev(uint_t, uint_t, uint_t, uint_t);
467 extern const char *_cpuid_chiprevstr(uint_t, uint_t, uint_t, uint_t);
468 extern uint_t _cpuid_vendorstr_to_vendorcode(char *);
469 
470 /*
471  * Apply up various platform-dependent restrictions where the
472  * underlying platform restrictions mean the CPU can be marked
473  * as less capable than its cpuid instruction would imply.
474  */
475 #if defined(__xpv)
476 static void
477 platform_cpuid_mangle(uint_t vendor, uint32_t eax, struct cpuid_regs *cp)
478 {
479 	switch (eax) {
480 	case 1: {
481 		uint32_t mcamask = DOMAIN_IS_INITDOMAIN(xen_info) ?
482 		    0 : CPUID_INTC_EDX_MCA;
483 		cp->cp_edx &=
484 		    ~(mcamask |
485 		    CPUID_INTC_EDX_PSE |
486 		    CPUID_INTC_EDX_VME | CPUID_INTC_EDX_DE |
487 		    CPUID_INTC_EDX_SEP | CPUID_INTC_EDX_MTRR |
488 		    CPUID_INTC_EDX_PGE | CPUID_INTC_EDX_PAT |
489 		    CPUID_AMD_EDX_SYSC | CPUID_INTC_EDX_SEP |
490 		    CPUID_INTC_EDX_PSE36 | CPUID_INTC_EDX_HTT);
491 		break;
492 	}
493 
494 	case 0x80000001:
495 		cp->cp_edx &=
496 		    ~(CPUID_AMD_EDX_PSE |
497 		    CPUID_INTC_EDX_VME | CPUID_INTC_EDX_DE |
498 		    CPUID_AMD_EDX_MTRR | CPUID_AMD_EDX_PGE |
499 		    CPUID_AMD_EDX_PAT | CPUID_AMD_EDX_PSE36 |
500 		    CPUID_AMD_EDX_SYSC | CPUID_INTC_EDX_SEP |
501 		    CPUID_AMD_EDX_TSCP);
502 		cp->cp_ecx &= ~CPUID_AMD_ECX_CMP_LGCY;
503 		break;
504 	default:
505 		break;
506 	}
507 
508 	switch (vendor) {
509 	case X86_VENDOR_Intel:
510 		switch (eax) {
511 		case 4:
512 			/*
513 			 * Zero out the (ncores-per-chip - 1) field
514 			 */
515 			cp->cp_eax &= 0x03fffffff;
516 			break;
517 		default:
518 			break;
519 		}
520 		break;
521 	case X86_VENDOR_AMD:
522 		switch (eax) {
523 
524 		case 0x80000001:
525 			cp->cp_ecx &= ~CPUID_AMD_ECX_CR8D;
526 			break;
527 
528 		case 0x80000008:
529 			/*
530 			 * Zero out the (ncores-per-chip - 1) field
531 			 */
532 			cp->cp_ecx &= 0xffffff00;
533 			break;
534 		default:
535 			break;
536 		}
537 		break;
538 	default:
539 		break;
540 	}
541 }
542 #else
543 #define	platform_cpuid_mangle(vendor, eax, cp)	/* nothing */
544 #endif
545 
546 /*
547  *  Some undocumented ways of patching the results of the cpuid
548  *  instruction to permit running Solaris 10 on future cpus that
549  *  we don't currently support.  Could be set to non-zero values
550  *  via settings in eeprom.
551  */
552 
553 uint32_t cpuid_feature_ecx_include;
554 uint32_t cpuid_feature_ecx_exclude;
555 uint32_t cpuid_feature_edx_include;
556 uint32_t cpuid_feature_edx_exclude;
557 
558 /*
559  * Allocate space for mcpu_cpi in the machcpu structure for all non-boot CPUs.
560  */
561 void
562 cpuid_alloc_space(cpu_t *cpu)
563 {
564 	/*
565 	 * By convention, cpu0 is the boot cpu, which is set up
566 	 * before memory allocation is available.  All other cpus get
567 	 * their cpuid_info struct allocated here.
568 	 */
569 	ASSERT(cpu->cpu_id != 0);
570 	ASSERT(cpu->cpu_m.mcpu_cpi == NULL);
571 	cpu->cpu_m.mcpu_cpi =
572 	    kmem_zalloc(sizeof (*cpu->cpu_m.mcpu_cpi), KM_SLEEP);
573 }
574 
575 void
576 cpuid_free_space(cpu_t *cpu)
577 {
578 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
579 	int i;
580 
581 	ASSERT(cpi != NULL);
582 	ASSERT(cpi != &cpuid_info0);
583 
584 	/*
585 	 * Free up any function 4 related dynamic storage
586 	 */
587 	for (i = 1; i < cpi->cpi_std_4_size; i++)
588 		kmem_free(cpi->cpi_std_4[i], sizeof (struct cpuid_regs));
589 	if (cpi->cpi_std_4_size > 0)
590 		kmem_free(cpi->cpi_std_4,
591 		    cpi->cpi_std_4_size * sizeof (struct cpuid_regs *));
592 
593 	kmem_free(cpi, sizeof (*cpi));
594 	cpu->cpu_m.mcpu_cpi = NULL;
595 }
596 
597 #if !defined(__xpv)
598 /*
599  * Determine the type of the underlying platform. This is used to customize
600  * initialization of various subsystems (e.g. TSC). determine_platform() must
601  * only ever be called once to prevent two processors from seeing different
602  * values of platform_type. Must be called before cpuid_pass1(), the earliest
603  * consumer to execute (uses _cpuid_chiprev --> synth_amd_info --> get_hwenv).
604  */
605 void
606 determine_platform(void)
607 {
608 	struct cpuid_regs cp;
609 	uint32_t base;
610 	uint32_t regs[4];
611 	char *hvstr = (char *)regs;
612 
613 	ASSERT(platform_type == -1);
614 
615 	platform_type = HW_NATIVE;
616 
617 	if (!enable_platform_detection)
618 		return;
619 
620 	/*
621 	 * If Hypervisor CPUID bit is set, try to determine hypervisor
622 	 * vendor signature, and set platform type accordingly.
623 	 *
624 	 * References:
625 	 * http://lkml.org/lkml/2008/10/1/246
626 	 * http://kb.vmware.com/kb/1009458
627 	 */
628 	cp.cp_eax = 0x1;
629 	(void) __cpuid_insn(&cp);
630 	if ((cp.cp_ecx & CPUID_INTC_ECX_HV) != 0) {
631 		cp.cp_eax = 0x40000000;
632 		(void) __cpuid_insn(&cp);
633 		regs[0] = cp.cp_ebx;
634 		regs[1] = cp.cp_ecx;
635 		regs[2] = cp.cp_edx;
636 		regs[3] = 0;
637 		if (strcmp(hvstr, HVSIG_XEN_HVM) == 0) {
638 			platform_type = HW_XEN_HVM;
639 			return;
640 		}
641 		if (strcmp(hvstr, HVSIG_VMWARE) == 0) {
642 			platform_type = HW_VMWARE;
643 			return;
644 		}
645 		if (strcmp(hvstr, HVSIG_KVM) == 0) {
646 			platform_type = HW_KVM;
647 			return;
648 		}
649 		if (strcmp(hvstr, HVSIG_MICROSOFT) == 0)
650 			platform_type = HW_MICROSOFT;
651 	} else {
652 		/*
653 		 * Check older VMware hardware versions. VMware hypervisor is
654 		 * detected by performing an IN operation to VMware hypervisor
655 		 * port and checking that value returned in %ebx is VMware
656 		 * hypervisor magic value.
657 		 *
658 		 * References: http://kb.vmware.com/kb/1009458
659 		 */
660 		vmware_port(VMWARE_HVCMD_GETVERSION, regs);
661 		if (regs[1] == VMWARE_HVMAGIC) {
662 			platform_type = HW_VMWARE;
663 			return;
664 		}
665 	}
666 
667 	/*
668 	 * Check Xen hypervisor. In a fully virtualized domain,
669 	 * Xen's pseudo-cpuid function returns a string representing the
670 	 * Xen signature in %ebx, %ecx, and %edx. %eax contains the maximum
671 	 * supported cpuid function. We need at least a (base + 2) leaf value
672 	 * to do what we want to do. Try different base values, since the
673 	 * hypervisor might use a different one depending on whether Hyper-V
674 	 * emulation is switched on by default or not.
675 	 */
676 	for (base = 0x40000000; base < 0x40010000; base += 0x100) {
677 		cp.cp_eax = base;
678 		(void) __cpuid_insn(&cp);
679 		regs[0] = cp.cp_ebx;
680 		regs[1] = cp.cp_ecx;
681 		regs[2] = cp.cp_edx;
682 		regs[3] = 0;
683 		if (strcmp(hvstr, HVSIG_XEN_HVM) == 0 &&
684 		    cp.cp_eax >= (base + 2)) {
685 			platform_type &= ~HW_NATIVE;
686 			platform_type |= HW_XEN_HVM;
687 			return;
688 		}
689 	}
690 }
691 
692 int
693 get_hwenv(void)
694 {
695 	ASSERT(platform_type != -1);
696 	return (platform_type);
697 }
698 
699 int
700 is_controldom(void)
701 {
702 	return (0);
703 }
704 
705 #else
706 
707 int
708 get_hwenv(void)
709 {
710 	return (HW_XEN_PV);
711 }
712 
713 int
714 is_controldom(void)
715 {
716 	return (DOMAIN_IS_INITDOMAIN(xen_info));
717 }
718 
719 #endif	/* __xpv */
720 
721 static void
722 cpuid_intel_getids(cpu_t *cpu, void *feature)
723 {
724 	uint_t i;
725 	uint_t chipid_shift = 0;
726 	uint_t coreid_shift = 0;
727 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
728 
729 	for (i = 1; i < cpi->cpi_ncpu_per_chip; i <<= 1)
730 		chipid_shift++;
731 
732 	cpi->cpi_chipid = cpi->cpi_apicid >> chipid_shift;
733 	cpi->cpi_clogid = cpi->cpi_apicid & ((1 << chipid_shift) - 1);
734 
735 	if (is_x86_feature(feature, X86FSET_CMP)) {
736 		/*
737 		 * Multi-core (and possibly multi-threaded)
738 		 * processors.
739 		 */
740 		uint_t ncpu_per_core;
741 		if (cpi->cpi_ncore_per_chip == 1)
742 			ncpu_per_core = cpi->cpi_ncpu_per_chip;
743 		else if (cpi->cpi_ncore_per_chip > 1)
744 			ncpu_per_core = cpi->cpi_ncpu_per_chip /
745 			    cpi->cpi_ncore_per_chip;
746 		/*
747 		 * 8bit APIC IDs on dual core Pentiums
748 		 * look like this:
749 		 *
750 		 * +-----------------------+------+------+
751 		 * | Physical Package ID   |  MC  |  HT  |
752 		 * +-----------------------+------+------+
753 		 * <------- chipid -------->
754 		 * <------- coreid --------------->
755 		 *			   <--- clogid -->
756 		 *			   <------>
757 		 *			   pkgcoreid
758 		 *
759 		 * Where the number of bits necessary to
760 		 * represent MC and HT fields together equals
761 		 * to the minimum number of bits necessary to
762 		 * store the value of cpi->cpi_ncpu_per_chip.
763 		 * Of those bits, the MC part uses the number
764 		 * of bits necessary to store the value of
765 		 * cpi->cpi_ncore_per_chip.
766 		 */
767 		for (i = 1; i < ncpu_per_core; i <<= 1)
768 			coreid_shift++;
769 		cpi->cpi_coreid = cpi->cpi_apicid >> coreid_shift;
770 		cpi->cpi_pkgcoreid = cpi->cpi_clogid >> coreid_shift;
771 	} else if (is_x86_feature(feature, X86FSET_HTT)) {
772 		/*
773 		 * Single-core multi-threaded processors.
774 		 */
775 		cpi->cpi_coreid = cpi->cpi_chipid;
776 		cpi->cpi_pkgcoreid = 0;
777 	}
778 	cpi->cpi_procnodeid = cpi->cpi_chipid;
779 	cpi->cpi_compunitid = cpi->cpi_coreid;
780 }
781 
782 static void
783 cpuid_amd_getids(cpu_t *cpu)
784 {
785 	int i, first_half, coreidsz;
786 	uint32_t nb_caps_reg;
787 	uint_t node2_1;
788 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
789 	struct cpuid_regs *cp;
790 
791 	/*
792 	 * AMD CMP chips currently have a single thread per core.
793 	 *
794 	 * Since no two cpus share a core we must assign a distinct coreid
795 	 * per cpu, and we do this by using the cpu_id.  This scheme does not,
796 	 * however, guarantee that sibling cores of a chip will have sequential
797 	 * coreids starting at a multiple of the number of cores per chip -
798 	 * that is usually the case, but if the ACPI MADT table is presented
799 	 * in a different order then we need to perform a few more gymnastics
800 	 * for the pkgcoreid.
801 	 *
802 	 * All processors in the system have the same number of enabled
803 	 * cores. Cores within a processor are always numbered sequentially
804 	 * from 0 regardless of how many or which are disabled, and there
805 	 * is no way for operating system to discover the real core id when some
806 	 * are disabled.
807 	 *
808 	 * In family 0x15, the cores come in pairs called compute units. They
809 	 * share I$ and L2 caches and the FPU. Enumeration of this feature is
810 	 * simplified by the new topology extensions CPUID leaf, indicated by
811 	 * the X86 feature X86FSET_TOPOEXT.
812 	 */
813 
814 	cpi->cpi_coreid = cpu->cpu_id;
815 	cpi->cpi_compunitid = cpu->cpu_id;
816 
817 	if (cpi->cpi_xmaxeax >= 0x80000008) {
818 
819 		coreidsz = BITX((cpi)->cpi_extd[8].cp_ecx, 15, 12);
820 
821 		/*
822 		 * In AMD parlance chip is really a node while Solaris
823 		 * sees chip as equivalent to socket/package.
824 		 */
825 		cpi->cpi_ncore_per_chip =
826 		    BITX((cpi)->cpi_extd[8].cp_ecx, 7, 0) + 1;
827 		if (coreidsz == 0) {
828 			/* Use legacy method */
829 			for (i = 1; i < cpi->cpi_ncore_per_chip; i <<= 1)
830 				coreidsz++;
831 			if (coreidsz == 0)
832 				coreidsz = 1;
833 		}
834 	} else {
835 		/* Assume single-core part */
836 		cpi->cpi_ncore_per_chip = 1;
837 		coreidsz = 1;
838 	}
839 
840 	cpi->cpi_clogid = cpi->cpi_pkgcoreid =
841 	    cpi->cpi_apicid & ((1<<coreidsz) - 1);
842 	cpi->cpi_ncpu_per_chip = cpi->cpi_ncore_per_chip;
843 
844 	/* Get node ID, compute unit ID */
845 	if (is_x86_feature(x86_featureset, X86FSET_TOPOEXT) &&
846 	    cpi->cpi_xmaxeax >= 0x8000001e) {
847 		cp = &cpi->cpi_extd[0x1e];
848 		cp->cp_eax = 0x8000001e;
849 		(void) __cpuid_insn(cp);
850 
851 		cpi->cpi_procnodes_per_pkg = BITX(cp->cp_ecx, 10, 8) + 1;
852 		cpi->cpi_procnodeid = BITX(cp->cp_ecx, 7, 0);
853 		cpi->cpi_cores_per_compunit = BITX(cp->cp_ebx, 15, 8) + 1;
854 		cpi->cpi_compunitid = BITX(cp->cp_ebx, 7, 0)
855 		    + (cpi->cpi_ncore_per_chip / cpi->cpi_cores_per_compunit)
856 		    * (cpi->cpi_procnodeid / cpi->cpi_procnodes_per_pkg);
857 	} else if (cpi->cpi_family == 0xf || cpi->cpi_family >= 0x11) {
858 		cpi->cpi_procnodeid = (cpi->cpi_apicid >> coreidsz) & 7;
859 	} else if (cpi->cpi_family == 0x10) {
860 		/*
861 		 * See if we are a multi-node processor.
862 		 * All processors in the system have the same number of nodes
863 		 */
864 		nb_caps_reg =  pci_getl_func(0, 24, 3, 0xe8);
865 		if ((cpi->cpi_model < 8) || BITX(nb_caps_reg, 29, 29) == 0) {
866 			/* Single-node */
867 			cpi->cpi_procnodeid = BITX(cpi->cpi_apicid, 5,
868 			    coreidsz);
869 		} else {
870 
871 			/*
872 			 * Multi-node revision D (2 nodes per package
873 			 * are supported)
874 			 */
875 			cpi->cpi_procnodes_per_pkg = 2;
876 
877 			first_half = (cpi->cpi_pkgcoreid <=
878 			    (cpi->cpi_ncore_per_chip/2 - 1));
879 
880 			if (cpi->cpi_apicid == cpi->cpi_pkgcoreid) {
881 				/* We are BSP */
882 				cpi->cpi_procnodeid = (first_half ? 0 : 1);
883 			} else {
884 
885 				/* We are AP */
886 				/* NodeId[2:1] bits to use for reading F3xe8 */
887 				node2_1 = BITX(cpi->cpi_apicid, 5, 4) << 1;
888 
889 				nb_caps_reg =
890 				    pci_getl_func(0, 24 + node2_1, 3, 0xe8);
891 
892 				/*
893 				 * Check IntNodeNum bit (31:30, but bit 31 is
894 				 * always 0 on dual-node processors)
895 				 */
896 				if (BITX(nb_caps_reg, 30, 30) == 0)
897 					cpi->cpi_procnodeid = node2_1 +
898 					    !first_half;
899 				else
900 					cpi->cpi_procnodeid = node2_1 +
901 					    first_half;
902 			}
903 		}
904 	} else {
905 		cpi->cpi_procnodeid = 0;
906 	}
907 
908 	cpi->cpi_chipid =
909 	    cpi->cpi_procnodeid / cpi->cpi_procnodes_per_pkg;
910 }
911 
912 /*
913  * Setup XFeature_Enabled_Mask register. Required by xsave feature.
914  */
915 void
916 setup_xfem(void)
917 {
918 	uint64_t flags = XFEATURE_LEGACY_FP;
919 
920 	ASSERT(is_x86_feature(x86_featureset, X86FSET_XSAVE));
921 
922 	if (is_x86_feature(x86_featureset, X86FSET_SSE))
923 		flags |= XFEATURE_SSE;
924 
925 	if (is_x86_feature(x86_featureset, X86FSET_AVX))
926 		flags |= XFEATURE_AVX;
927 
928 	set_xcr(XFEATURE_ENABLED_MASK, flags);
929 
930 	xsave_bv_all = flags;
931 }
932 
933 void
934 cpuid_pass1(cpu_t *cpu, uchar_t *featureset)
935 {
936 	uint32_t mask_ecx, mask_edx;
937 	struct cpuid_info *cpi;
938 	struct cpuid_regs *cp;
939 	int xcpuid;
940 #if !defined(__xpv)
941 	extern int idle_cpu_prefer_mwait;
942 #endif
943 
944 	/*
945 	 * Space statically allocated for BSP, ensure pointer is set
946 	 */
947 	if (cpu->cpu_id == 0) {
948 		if (cpu->cpu_m.mcpu_cpi == NULL)
949 			cpu->cpu_m.mcpu_cpi = &cpuid_info0;
950 	}
951 
952 	add_x86_feature(featureset, X86FSET_CPUID);
953 
954 	cpi = cpu->cpu_m.mcpu_cpi;
955 	ASSERT(cpi != NULL);
956 	cp = &cpi->cpi_std[0];
957 	cp->cp_eax = 0;
958 	cpi->cpi_maxeax = __cpuid_insn(cp);
959 	{
960 		uint32_t *iptr = (uint32_t *)cpi->cpi_vendorstr;
961 		*iptr++ = cp->cp_ebx;
962 		*iptr++ = cp->cp_edx;
963 		*iptr++ = cp->cp_ecx;
964 		*(char *)&cpi->cpi_vendorstr[12] = '\0';
965 	}
966 
967 	cpi->cpi_vendor = _cpuid_vendorstr_to_vendorcode(cpi->cpi_vendorstr);
968 	x86_vendor = cpi->cpi_vendor; /* for compatibility */
969 
970 	/*
971 	 * Limit the range in case of weird hardware
972 	 */
973 	if (cpi->cpi_maxeax > CPI_MAXEAX_MAX)
974 		cpi->cpi_maxeax = CPI_MAXEAX_MAX;
975 	if (cpi->cpi_maxeax < 1)
976 		goto pass1_done;
977 
978 	cp = &cpi->cpi_std[1];
979 	cp->cp_eax = 1;
980 	(void) __cpuid_insn(cp);
981 
982 	/*
983 	 * Extract identifying constants for easy access.
984 	 */
985 	cpi->cpi_model = CPI_MODEL(cpi);
986 	cpi->cpi_family = CPI_FAMILY(cpi);
987 
988 	if (cpi->cpi_family == 0xf)
989 		cpi->cpi_family += CPI_FAMILY_XTD(cpi);
990 
991 	/*
992 	 * Beware: AMD uses "extended model" iff base *FAMILY* == 0xf.
993 	 * Intel, and presumably everyone else, uses model == 0xf, as
994 	 * one would expect (max value means possible overflow).  Sigh.
995 	 */
996 
997 	switch (cpi->cpi_vendor) {
998 	case X86_VENDOR_Intel:
999 		if (IS_EXTENDED_MODEL_INTEL(cpi))
1000 			cpi->cpi_model += CPI_MODEL_XTD(cpi) << 4;
1001 		break;
1002 	case X86_VENDOR_AMD:
1003 		if (CPI_FAMILY(cpi) == 0xf)
1004 			cpi->cpi_model += CPI_MODEL_XTD(cpi) << 4;
1005 		break;
1006 	default:
1007 		if (cpi->cpi_model == 0xf)
1008 			cpi->cpi_model += CPI_MODEL_XTD(cpi) << 4;
1009 		break;
1010 	}
1011 
1012 	cpi->cpi_step = CPI_STEP(cpi);
1013 	cpi->cpi_brandid = CPI_BRANDID(cpi);
1014 
1015 	/*
1016 	 * *default* assumptions:
1017 	 * - believe %edx feature word
1018 	 * - ignore %ecx feature word
1019 	 * - 32-bit virtual and physical addressing
1020 	 */
1021 	mask_edx = 0xffffffff;
1022 	mask_ecx = 0;
1023 
1024 	cpi->cpi_pabits = cpi->cpi_vabits = 32;
1025 
1026 	switch (cpi->cpi_vendor) {
1027 	case X86_VENDOR_Intel:
1028 		if (cpi->cpi_family == 5)
1029 			x86_type = X86_TYPE_P5;
1030 		else if (IS_LEGACY_P6(cpi)) {
1031 			x86_type = X86_TYPE_P6;
1032 			pentiumpro_bug4046376 = 1;
1033 			/*
1034 			 * Clear the SEP bit when it was set erroneously
1035 			 */
1036 			if (cpi->cpi_model < 3 && cpi->cpi_step < 3)
1037 				cp->cp_edx &= ~CPUID_INTC_EDX_SEP;
1038 		} else if (IS_NEW_F6(cpi) || cpi->cpi_family == 0xf) {
1039 			x86_type = X86_TYPE_P4;
1040 			/*
1041 			 * We don't currently depend on any of the %ecx
1042 			 * features until Prescott, so we'll only check
1043 			 * this from P4 onwards.  We might want to revisit
1044 			 * that idea later.
1045 			 */
1046 			mask_ecx = 0xffffffff;
1047 		} else if (cpi->cpi_family > 0xf)
1048 			mask_ecx = 0xffffffff;
1049 		/*
1050 		 * We don't support MONITOR/MWAIT if leaf 5 is not available
1051 		 * to obtain the monitor linesize.
1052 		 */
1053 		if (cpi->cpi_maxeax < 5)
1054 			mask_ecx &= ~CPUID_INTC_ECX_MON;
1055 		break;
1056 	case X86_VENDOR_IntelClone:
1057 	default:
1058 		break;
1059 	case X86_VENDOR_AMD:
1060 #if defined(OPTERON_ERRATUM_108)
1061 		if (cpi->cpi_family == 0xf && cpi->cpi_model == 0xe) {
1062 			cp->cp_eax = (0xf0f & cp->cp_eax) | 0xc0;
1063 			cpi->cpi_model = 0xc;
1064 		} else
1065 #endif
1066 		if (cpi->cpi_family == 5) {
1067 			/*
1068 			 * AMD K5 and K6
1069 			 *
1070 			 * These CPUs have an incomplete implementation
1071 			 * of MCA/MCE which we mask away.
1072 			 */
1073 			mask_edx &= ~(CPUID_INTC_EDX_MCE | CPUID_INTC_EDX_MCA);
1074 
1075 			/*
1076 			 * Model 0 uses the wrong (APIC) bit
1077 			 * to indicate PGE.  Fix it here.
1078 			 */
1079 			if (cpi->cpi_model == 0) {
1080 				if (cp->cp_edx & 0x200) {
1081 					cp->cp_edx &= ~0x200;
1082 					cp->cp_edx |= CPUID_INTC_EDX_PGE;
1083 				}
1084 			}
1085 
1086 			/*
1087 			 * Early models had problems w/ MMX; disable.
1088 			 */
1089 			if (cpi->cpi_model < 6)
1090 				mask_edx &= ~CPUID_INTC_EDX_MMX;
1091 		}
1092 
1093 		/*
1094 		 * For newer families, SSE3 and CX16, at least, are valid;
1095 		 * enable all
1096 		 */
1097 		if (cpi->cpi_family >= 0xf)
1098 			mask_ecx = 0xffffffff;
1099 		/*
1100 		 * We don't support MONITOR/MWAIT if leaf 5 is not available
1101 		 * to obtain the monitor linesize.
1102 		 */
1103 		if (cpi->cpi_maxeax < 5)
1104 			mask_ecx &= ~CPUID_INTC_ECX_MON;
1105 
1106 #if !defined(__xpv)
1107 		/*
1108 		 * Do not use MONITOR/MWAIT to halt in the idle loop on any AMD
1109 		 * processors.  AMD does not intend MWAIT to be used in the cpu
1110 		 * idle loop on current and future processors.  10h and future
1111 		 * AMD processors use more power in MWAIT than HLT.
1112 		 * Pre-family-10h Opterons do not have the MWAIT instruction.
1113 		 */
1114 		idle_cpu_prefer_mwait = 0;
1115 #endif
1116 
1117 		break;
1118 	case X86_VENDOR_TM:
1119 		/*
1120 		 * workaround the NT workaround in CMS 4.1
1121 		 */
1122 		if (cpi->cpi_family == 5 && cpi->cpi_model == 4 &&
1123 		    (cpi->cpi_step == 2 || cpi->cpi_step == 3))
1124 			cp->cp_edx |= CPUID_INTC_EDX_CX8;
1125 		break;
1126 	case X86_VENDOR_Centaur:
1127 		/*
1128 		 * workaround the NT workarounds again
1129 		 */
1130 		if (cpi->cpi_family == 6)
1131 			cp->cp_edx |= CPUID_INTC_EDX_CX8;
1132 		break;
1133 	case X86_VENDOR_Cyrix:
1134 		/*
1135 		 * We rely heavily on the probing in locore
1136 		 * to actually figure out what parts, if any,
1137 		 * of the Cyrix cpuid instruction to believe.
1138 		 */
1139 		switch (x86_type) {
1140 		case X86_TYPE_CYRIX_486:
1141 			mask_edx = 0;
1142 			break;
1143 		case X86_TYPE_CYRIX_6x86:
1144 			mask_edx = 0;
1145 			break;
1146 		case X86_TYPE_CYRIX_6x86L:
1147 			mask_edx =
1148 			    CPUID_INTC_EDX_DE |
1149 			    CPUID_INTC_EDX_CX8;
1150 			break;
1151 		case X86_TYPE_CYRIX_6x86MX:
1152 			mask_edx =
1153 			    CPUID_INTC_EDX_DE |
1154 			    CPUID_INTC_EDX_MSR |
1155 			    CPUID_INTC_EDX_CX8 |
1156 			    CPUID_INTC_EDX_PGE |
1157 			    CPUID_INTC_EDX_CMOV |
1158 			    CPUID_INTC_EDX_MMX;
1159 			break;
1160 		case X86_TYPE_CYRIX_GXm:
1161 			mask_edx =
1162 			    CPUID_INTC_EDX_MSR |
1163 			    CPUID_INTC_EDX_CX8 |
1164 			    CPUID_INTC_EDX_CMOV |
1165 			    CPUID_INTC_EDX_MMX;
1166 			break;
1167 		case X86_TYPE_CYRIX_MediaGX:
1168 			break;
1169 		case X86_TYPE_CYRIX_MII:
1170 		case X86_TYPE_VIA_CYRIX_III:
1171 			mask_edx =
1172 			    CPUID_INTC_EDX_DE |
1173 			    CPUID_INTC_EDX_TSC |
1174 			    CPUID_INTC_EDX_MSR |
1175 			    CPUID_INTC_EDX_CX8 |
1176 			    CPUID_INTC_EDX_PGE |
1177 			    CPUID_INTC_EDX_CMOV |
1178 			    CPUID_INTC_EDX_MMX;
1179 			break;
1180 		default:
1181 			break;
1182 		}
1183 		break;
1184 	}
1185 
1186 #if defined(__xpv)
1187 	/*
1188 	 * Do not support MONITOR/MWAIT under a hypervisor
1189 	 */
1190 	mask_ecx &= ~CPUID_INTC_ECX_MON;
1191 	/*
1192 	 * Do not support XSAVE under a hypervisor for now
1193 	 */
1194 	xsave_force_disable = B_TRUE;
1195 
1196 #endif	/* __xpv */
1197 
1198 	if (xsave_force_disable) {
1199 		mask_ecx &= ~CPUID_INTC_ECX_XSAVE;
1200 		mask_ecx &= ~CPUID_INTC_ECX_AVX;
1201 		mask_ecx &= ~CPUID_INTC_ECX_F16C;
1202 	}
1203 
1204 	/*
1205 	 * Now we've figured out the masks that determine
1206 	 * which bits we choose to believe, apply the masks
1207 	 * to the feature words, then map the kernel's view
1208 	 * of these feature words into its feature word.
1209 	 */
1210 	cp->cp_edx &= mask_edx;
1211 	cp->cp_ecx &= mask_ecx;
1212 
1213 	/*
1214 	 * apply any platform restrictions (we don't call this
1215 	 * immediately after __cpuid_insn here, because we need the
1216 	 * workarounds applied above first)
1217 	 */
1218 	platform_cpuid_mangle(cpi->cpi_vendor, 1, cp);
1219 
1220 	/*
1221 	 * fold in overrides from the "eeprom" mechanism
1222 	 */
1223 	cp->cp_edx |= cpuid_feature_edx_include;
1224 	cp->cp_edx &= ~cpuid_feature_edx_exclude;
1225 
1226 	cp->cp_ecx |= cpuid_feature_ecx_include;
1227 	cp->cp_ecx &= ~cpuid_feature_ecx_exclude;
1228 
1229 	if (cp->cp_edx & CPUID_INTC_EDX_PSE) {
1230 		add_x86_feature(featureset, X86FSET_LARGEPAGE);
1231 	}
1232 	if (cp->cp_edx & CPUID_INTC_EDX_TSC) {
1233 		add_x86_feature(featureset, X86FSET_TSC);
1234 	}
1235 	if (cp->cp_edx & CPUID_INTC_EDX_MSR) {
1236 		add_x86_feature(featureset, X86FSET_MSR);
1237 	}
1238 	if (cp->cp_edx & CPUID_INTC_EDX_MTRR) {
1239 		add_x86_feature(featureset, X86FSET_MTRR);
1240 	}
1241 	if (cp->cp_edx & CPUID_INTC_EDX_PGE) {
1242 		add_x86_feature(featureset, X86FSET_PGE);
1243 	}
1244 	if (cp->cp_edx & CPUID_INTC_EDX_CMOV) {
1245 		add_x86_feature(featureset, X86FSET_CMOV);
1246 	}
1247 	if (cp->cp_edx & CPUID_INTC_EDX_MMX) {
1248 		add_x86_feature(featureset, X86FSET_MMX);
1249 	}
1250 	if ((cp->cp_edx & CPUID_INTC_EDX_MCE) != 0 &&
1251 	    (cp->cp_edx & CPUID_INTC_EDX_MCA) != 0) {
1252 		add_x86_feature(featureset, X86FSET_MCA);
1253 	}
1254 	if (cp->cp_edx & CPUID_INTC_EDX_PAE) {
1255 		add_x86_feature(featureset, X86FSET_PAE);
1256 	}
1257 	if (cp->cp_edx & CPUID_INTC_EDX_CX8) {
1258 		add_x86_feature(featureset, X86FSET_CX8);
1259 	}
1260 	if (cp->cp_ecx & CPUID_INTC_ECX_CX16) {
1261 		add_x86_feature(featureset, X86FSET_CX16);
1262 	}
1263 	if (cp->cp_edx & CPUID_INTC_EDX_PAT) {
1264 		add_x86_feature(featureset, X86FSET_PAT);
1265 	}
1266 	if (cp->cp_edx & CPUID_INTC_EDX_SEP) {
1267 		add_x86_feature(featureset, X86FSET_SEP);
1268 	}
1269 	if (cp->cp_edx & CPUID_INTC_EDX_FXSR) {
1270 		/*
1271 		 * In our implementation, fxsave/fxrstor
1272 		 * are prerequisites before we'll even
1273 		 * try and do SSE things.
1274 		 */
1275 		if (cp->cp_edx & CPUID_INTC_EDX_SSE) {
1276 			add_x86_feature(featureset, X86FSET_SSE);
1277 		}
1278 		if (cp->cp_edx & CPUID_INTC_EDX_SSE2) {
1279 			add_x86_feature(featureset, X86FSET_SSE2);
1280 		}
1281 		if (cp->cp_ecx & CPUID_INTC_ECX_SSE3) {
1282 			add_x86_feature(featureset, X86FSET_SSE3);
1283 		}
1284 		if (cp->cp_ecx & CPUID_INTC_ECX_SSSE3) {
1285 			add_x86_feature(featureset, X86FSET_SSSE3);
1286 		}
1287 		if (cp->cp_ecx & CPUID_INTC_ECX_SSE4_1) {
1288 			add_x86_feature(featureset, X86FSET_SSE4_1);
1289 		}
1290 		if (cp->cp_ecx & CPUID_INTC_ECX_SSE4_2) {
1291 			add_x86_feature(featureset, X86FSET_SSE4_2);
1292 		}
1293 		if (cp->cp_ecx & CPUID_INTC_ECX_AES) {
1294 			add_x86_feature(featureset, X86FSET_AES);
1295 		}
1296 		if (cp->cp_ecx & CPUID_INTC_ECX_PCLMULQDQ) {
1297 			add_x86_feature(featureset, X86FSET_PCLMULQDQ);
1298 		}
1299 
1300 		if (cp->cp_ecx & CPUID_INTC_ECX_XSAVE) {
1301 			add_x86_feature(featureset, X86FSET_XSAVE);
1302 
1303 			/* We only test AVX when there is XSAVE */
1304 			if (cp->cp_ecx & CPUID_INTC_ECX_AVX) {
1305 				add_x86_feature(featureset,
1306 				    X86FSET_AVX);
1307 
1308 				if (cp->cp_ecx & CPUID_INTC_ECX_F16C)
1309 					add_x86_feature(featureset,
1310 					    X86FSET_F16C);
1311 			}
1312 		}
1313 	}
1314 	if (cp->cp_edx & CPUID_INTC_EDX_DE) {
1315 		add_x86_feature(featureset, X86FSET_DE);
1316 	}
1317 #if !defined(__xpv)
1318 	if (cp->cp_ecx & CPUID_INTC_ECX_MON) {
1319 
1320 		/*
1321 		 * We require the CLFLUSH instruction for erratum workaround
1322 		 * to use MONITOR/MWAIT.
1323 		 */
1324 		if (cp->cp_edx & CPUID_INTC_EDX_CLFSH) {
1325 			cpi->cpi_mwait.support |= MWAIT_SUPPORT;
1326 			add_x86_feature(featureset, X86FSET_MWAIT);
1327 		} else {
1328 			extern int idle_cpu_assert_cflush_monitor;
1329 
1330 			/*
1331 			 * All processors we are aware of which have
1332 			 * MONITOR/MWAIT also have CLFLUSH.
1333 			 */
1334 			if (idle_cpu_assert_cflush_monitor) {
1335 				ASSERT((cp->cp_ecx & CPUID_INTC_ECX_MON) &&
1336 				    (cp->cp_edx & CPUID_INTC_EDX_CLFSH));
1337 			}
1338 		}
1339 	}
1340 #endif	/* __xpv */
1341 
1342 	if (cp->cp_ecx & CPUID_INTC_ECX_VMX) {
1343 		add_x86_feature(featureset, X86FSET_VMX);
1344 	}
1345 
1346 	if (cp->cp_ecx & CPUID_INTC_ECX_RDRAND)
1347 		add_x86_feature(featureset, X86FSET_RDRAND);
1348 
1349 	/*
1350 	 * Only need it first time, rest of the cpus would follow suit.
1351 	 * we only capture this for the bootcpu.
1352 	 */
1353 	if (cp->cp_edx & CPUID_INTC_EDX_CLFSH) {
1354 		add_x86_feature(featureset, X86FSET_CLFSH);
1355 		x86_clflush_size = (BITX(cp->cp_ebx, 15, 8) * 8);
1356 	}
1357 	if (is_x86_feature(featureset, X86FSET_PAE))
1358 		cpi->cpi_pabits = 36;
1359 
1360 	/*
1361 	 * Hyperthreading configuration is slightly tricky on Intel
1362 	 * and pure clones, and even trickier on AMD.
1363 	 *
1364 	 * (AMD chose to set the HTT bit on their CMP processors,
1365 	 * even though they're not actually hyperthreaded.  Thus it
1366 	 * takes a bit more work to figure out what's really going
1367 	 * on ... see the handling of the CMP_LGCY bit below)
1368 	 */
1369 	if (cp->cp_edx & CPUID_INTC_EDX_HTT) {
1370 		cpi->cpi_ncpu_per_chip = CPI_CPU_COUNT(cpi);
1371 		if (cpi->cpi_ncpu_per_chip > 1)
1372 			add_x86_feature(featureset, X86FSET_HTT);
1373 	} else {
1374 		cpi->cpi_ncpu_per_chip = 1;
1375 	}
1376 
1377 	/*
1378 	 * Work on the "extended" feature information, doing
1379 	 * some basic initialization for cpuid_pass2()
1380 	 */
1381 	xcpuid = 0;
1382 	switch (cpi->cpi_vendor) {
1383 	case X86_VENDOR_Intel:
1384 		if (IS_NEW_F6(cpi) || cpi->cpi_family >= 0xf)
1385 			xcpuid++;
1386 		break;
1387 	case X86_VENDOR_AMD:
1388 		if (cpi->cpi_family > 5 ||
1389 		    (cpi->cpi_family == 5 && cpi->cpi_model >= 1))
1390 			xcpuid++;
1391 		break;
1392 	case X86_VENDOR_Cyrix:
1393 		/*
1394 		 * Only these Cyrix CPUs are -known- to support
1395 		 * extended cpuid operations.
1396 		 */
1397 		if (x86_type == X86_TYPE_VIA_CYRIX_III ||
1398 		    x86_type == X86_TYPE_CYRIX_GXm)
1399 			xcpuid++;
1400 		break;
1401 	case X86_VENDOR_Centaur:
1402 	case X86_VENDOR_TM:
1403 	default:
1404 		xcpuid++;
1405 		break;
1406 	}
1407 
1408 	if (xcpuid) {
1409 		cp = &cpi->cpi_extd[0];
1410 		cp->cp_eax = 0x80000000;
1411 		cpi->cpi_xmaxeax = __cpuid_insn(cp);
1412 	}
1413 
1414 	if (cpi->cpi_xmaxeax & 0x80000000) {
1415 
1416 		if (cpi->cpi_xmaxeax > CPI_XMAXEAX_MAX)
1417 			cpi->cpi_xmaxeax = CPI_XMAXEAX_MAX;
1418 
1419 		switch (cpi->cpi_vendor) {
1420 		case X86_VENDOR_Intel:
1421 		case X86_VENDOR_AMD:
1422 			if (cpi->cpi_xmaxeax < 0x80000001)
1423 				break;
1424 			cp = &cpi->cpi_extd[1];
1425 			cp->cp_eax = 0x80000001;
1426 			(void) __cpuid_insn(cp);
1427 
1428 			if (cpi->cpi_vendor == X86_VENDOR_AMD &&
1429 			    cpi->cpi_family == 5 &&
1430 			    cpi->cpi_model == 6 &&
1431 			    cpi->cpi_step == 6) {
1432 				/*
1433 				 * K6 model 6 uses bit 10 to indicate SYSC
1434 				 * Later models use bit 11. Fix it here.
1435 				 */
1436 				if (cp->cp_edx & 0x400) {
1437 					cp->cp_edx &= ~0x400;
1438 					cp->cp_edx |= CPUID_AMD_EDX_SYSC;
1439 				}
1440 			}
1441 
1442 			platform_cpuid_mangle(cpi->cpi_vendor, 0x80000001, cp);
1443 
1444 			/*
1445 			 * Compute the additions to the kernel's feature word.
1446 			 */
1447 			if (cp->cp_edx & CPUID_AMD_EDX_NX) {
1448 				add_x86_feature(featureset, X86FSET_NX);
1449 			}
1450 
1451 			/*
1452 			 * Regardless whether or not we boot 64-bit,
1453 			 * we should have a way to identify whether
1454 			 * the CPU is capable of running 64-bit.
1455 			 */
1456 			if (cp->cp_edx & CPUID_AMD_EDX_LM) {
1457 				add_x86_feature(featureset, X86FSET_64);
1458 			}
1459 
1460 #if defined(__amd64)
1461 			/* 1 GB large page - enable only for 64 bit kernel */
1462 			if (cp->cp_edx & CPUID_AMD_EDX_1GPG) {
1463 				add_x86_feature(featureset, X86FSET_1GPG);
1464 			}
1465 #endif
1466 
1467 			if ((cpi->cpi_vendor == X86_VENDOR_AMD) &&
1468 			    (cpi->cpi_std[1].cp_edx & CPUID_INTC_EDX_FXSR) &&
1469 			    (cp->cp_ecx & CPUID_AMD_ECX_SSE4A)) {
1470 				add_x86_feature(featureset, X86FSET_SSE4A);
1471 			}
1472 
1473 			/*
1474 			 * If both the HTT and CMP_LGCY bits are set,
1475 			 * then we're not actually HyperThreaded.  Read
1476 			 * "AMD CPUID Specification" for more details.
1477 			 */
1478 			if (cpi->cpi_vendor == X86_VENDOR_AMD &&
1479 			    is_x86_feature(featureset, X86FSET_HTT) &&
1480 			    (cp->cp_ecx & CPUID_AMD_ECX_CMP_LGCY)) {
1481 				remove_x86_feature(featureset, X86FSET_HTT);
1482 				add_x86_feature(featureset, X86FSET_CMP);
1483 			}
1484 #if defined(__amd64)
1485 			/*
1486 			 * It's really tricky to support syscall/sysret in
1487 			 * the i386 kernel; we rely on sysenter/sysexit
1488 			 * instead.  In the amd64 kernel, things are -way-
1489 			 * better.
1490 			 */
1491 			if (cp->cp_edx & CPUID_AMD_EDX_SYSC) {
1492 				add_x86_feature(featureset, X86FSET_ASYSC);
1493 			}
1494 
1495 			/*
1496 			 * While we're thinking about system calls, note
1497 			 * that AMD processors don't support sysenter
1498 			 * in long mode at all, so don't try to program them.
1499 			 */
1500 			if (x86_vendor == X86_VENDOR_AMD) {
1501 				remove_x86_feature(featureset, X86FSET_SEP);
1502 			}
1503 #endif
1504 			if (cp->cp_edx & CPUID_AMD_EDX_TSCP) {
1505 				add_x86_feature(featureset, X86FSET_TSCP);
1506 			}
1507 
1508 			if (cp->cp_ecx & CPUID_AMD_ECX_SVM) {
1509 				add_x86_feature(featureset, X86FSET_SVM);
1510 			}
1511 
1512 			if (cp->cp_ecx & CPUID_AMD_ECX_TOPOEXT) {
1513 				add_x86_feature(featureset, X86FSET_TOPOEXT);
1514 			}
1515 			break;
1516 		default:
1517 			break;
1518 		}
1519 
1520 		/*
1521 		 * Get CPUID data about processor cores and hyperthreads.
1522 		 */
1523 		switch (cpi->cpi_vendor) {
1524 		case X86_VENDOR_Intel:
1525 			if (cpi->cpi_maxeax >= 4) {
1526 				cp = &cpi->cpi_std[4];
1527 				cp->cp_eax = 4;
1528 				cp->cp_ecx = 0;
1529 				(void) __cpuid_insn(cp);
1530 				platform_cpuid_mangle(cpi->cpi_vendor, 4, cp);
1531 			}
1532 			/*FALLTHROUGH*/
1533 		case X86_VENDOR_AMD:
1534 			if (cpi->cpi_xmaxeax < 0x80000008)
1535 				break;
1536 			cp = &cpi->cpi_extd[8];
1537 			cp->cp_eax = 0x80000008;
1538 			(void) __cpuid_insn(cp);
1539 			platform_cpuid_mangle(cpi->cpi_vendor, 0x80000008, cp);
1540 
1541 			/*
1542 			 * Virtual and physical address limits from
1543 			 * cpuid override previously guessed values.
1544 			 */
1545 			cpi->cpi_pabits = BITX(cp->cp_eax, 7, 0);
1546 			cpi->cpi_vabits = BITX(cp->cp_eax, 15, 8);
1547 			break;
1548 		default:
1549 			break;
1550 		}
1551 
1552 		/*
1553 		 * Derive the number of cores per chip
1554 		 */
1555 		switch (cpi->cpi_vendor) {
1556 		case X86_VENDOR_Intel:
1557 			if (cpi->cpi_maxeax < 4) {
1558 				cpi->cpi_ncore_per_chip = 1;
1559 				break;
1560 			} else {
1561 				cpi->cpi_ncore_per_chip =
1562 				    BITX((cpi)->cpi_std[4].cp_eax, 31, 26) + 1;
1563 			}
1564 			break;
1565 		case X86_VENDOR_AMD:
1566 			if (cpi->cpi_xmaxeax < 0x80000008) {
1567 				cpi->cpi_ncore_per_chip = 1;
1568 				break;
1569 			} else {
1570 				/*
1571 				 * On family 0xf cpuid fn 2 ECX[7:0] "NC" is
1572 				 * 1 less than the number of physical cores on
1573 				 * the chip.  In family 0x10 this value can
1574 				 * be affected by "downcoring" - it reflects
1575 				 * 1 less than the number of cores actually
1576 				 * enabled on this node.
1577 				 */
1578 				cpi->cpi_ncore_per_chip =
1579 				    BITX((cpi)->cpi_extd[8].cp_ecx, 7, 0) + 1;
1580 			}
1581 			break;
1582 		default:
1583 			cpi->cpi_ncore_per_chip = 1;
1584 			break;
1585 		}
1586 
1587 		/*
1588 		 * Get CPUID data about TSC Invariance in Deep C-State.
1589 		 */
1590 		switch (cpi->cpi_vendor) {
1591 		case X86_VENDOR_Intel:
1592 			if (cpi->cpi_maxeax >= 7) {
1593 				cp = &cpi->cpi_extd[7];
1594 				cp->cp_eax = 0x80000007;
1595 				cp->cp_ecx = 0;
1596 				(void) __cpuid_insn(cp);
1597 			}
1598 			break;
1599 		default:
1600 			break;
1601 		}
1602 	} else {
1603 		cpi->cpi_ncore_per_chip = 1;
1604 	}
1605 
1606 	/*
1607 	 * If more than one core, then this processor is CMP.
1608 	 */
1609 	if (cpi->cpi_ncore_per_chip > 1) {
1610 		add_x86_feature(featureset, X86FSET_CMP);
1611 	}
1612 
1613 	/*
1614 	 * If the number of cores is the same as the number
1615 	 * of CPUs, then we cannot have HyperThreading.
1616 	 */
1617 	if (cpi->cpi_ncpu_per_chip == cpi->cpi_ncore_per_chip) {
1618 		remove_x86_feature(featureset, X86FSET_HTT);
1619 	}
1620 
1621 	cpi->cpi_apicid = CPI_APIC_ID(cpi);
1622 	cpi->cpi_procnodes_per_pkg = 1;
1623 	cpi->cpi_cores_per_compunit = 1;
1624 	if (is_x86_feature(featureset, X86FSET_HTT) == B_FALSE &&
1625 	    is_x86_feature(featureset, X86FSET_CMP) == B_FALSE) {
1626 		/*
1627 		 * Single-core single-threaded processors.
1628 		 */
1629 		cpi->cpi_chipid = -1;
1630 		cpi->cpi_clogid = 0;
1631 		cpi->cpi_coreid = cpu->cpu_id;
1632 		cpi->cpi_pkgcoreid = 0;
1633 		if (cpi->cpi_vendor == X86_VENDOR_AMD)
1634 			cpi->cpi_procnodeid = BITX(cpi->cpi_apicid, 3, 0);
1635 		else
1636 			cpi->cpi_procnodeid = cpi->cpi_chipid;
1637 	} else if (cpi->cpi_ncpu_per_chip > 1) {
1638 		if (cpi->cpi_vendor == X86_VENDOR_Intel)
1639 			cpuid_intel_getids(cpu, featureset);
1640 		else if (cpi->cpi_vendor == X86_VENDOR_AMD)
1641 			cpuid_amd_getids(cpu);
1642 		else {
1643 			/*
1644 			 * All other processors are currently
1645 			 * assumed to have single cores.
1646 			 */
1647 			cpi->cpi_coreid = cpi->cpi_chipid;
1648 			cpi->cpi_pkgcoreid = 0;
1649 			cpi->cpi_procnodeid = cpi->cpi_chipid;
1650 			cpi->cpi_compunitid = cpi->cpi_chipid;
1651 		}
1652 	}
1653 
1654 	/*
1655 	 * Synthesize chip "revision" and socket type
1656 	 */
1657 	cpi->cpi_chiprev = _cpuid_chiprev(cpi->cpi_vendor, cpi->cpi_family,
1658 	    cpi->cpi_model, cpi->cpi_step);
1659 	cpi->cpi_chiprevstr = _cpuid_chiprevstr(cpi->cpi_vendor,
1660 	    cpi->cpi_family, cpi->cpi_model, cpi->cpi_step);
1661 	cpi->cpi_socket = _cpuid_skt(cpi->cpi_vendor, cpi->cpi_family,
1662 	    cpi->cpi_model, cpi->cpi_step);
1663 
1664 pass1_done:
1665 	cpi->cpi_pass = 1;
1666 }
1667 
1668 /*
1669  * Make copies of the cpuid table entries we depend on, in
1670  * part for ease of parsing now, in part so that we have only
1671  * one place to correct any of it, in part for ease of
1672  * later export to userland, and in part so we can look at
1673  * this stuff in a crash dump.
1674  */
1675 
1676 /*ARGSUSED*/
1677 void
1678 cpuid_pass2(cpu_t *cpu)
1679 {
1680 	uint_t n, nmax;
1681 	int i;
1682 	struct cpuid_regs *cp;
1683 	uint8_t *dp;
1684 	uint32_t *iptr;
1685 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
1686 
1687 	ASSERT(cpi->cpi_pass == 1);
1688 
1689 	if (cpi->cpi_maxeax < 1)
1690 		goto pass2_done;
1691 
1692 	if ((nmax = cpi->cpi_maxeax + 1) > NMAX_CPI_STD)
1693 		nmax = NMAX_CPI_STD;
1694 	/*
1695 	 * (We already handled n == 0 and n == 1 in pass 1)
1696 	 */
1697 	for (n = 2, cp = &cpi->cpi_std[2]; n < nmax; n++, cp++) {
1698 		cp->cp_eax = n;
1699 
1700 		/*
1701 		 * CPUID function 4 expects %ecx to be initialized
1702 		 * with an index which indicates which cache to return
1703 		 * information about. The OS is expected to call function 4
1704 		 * with %ecx set to 0, 1, 2, ... until it returns with
1705 		 * EAX[4:0] set to 0, which indicates there are no more
1706 		 * caches.
1707 		 *
1708 		 * Here, populate cpi_std[4] with the information returned by
1709 		 * function 4 when %ecx == 0, and do the rest in cpuid_pass3()
1710 		 * when dynamic memory allocation becomes available.
1711 		 *
1712 		 * Note: we need to explicitly initialize %ecx here, since
1713 		 * function 4 may have been previously invoked.
1714 		 */
1715 		if (n == 4)
1716 			cp->cp_ecx = 0;
1717 
1718 		(void) __cpuid_insn(cp);
1719 		platform_cpuid_mangle(cpi->cpi_vendor, n, cp);
1720 		switch (n) {
1721 		case 2:
1722 			/*
1723 			 * "the lower 8 bits of the %eax register
1724 			 * contain a value that identifies the number
1725 			 * of times the cpuid [instruction] has to be
1726 			 * executed to obtain a complete image of the
1727 			 * processor's caching systems."
1728 			 *
1729 			 * How *do* they make this stuff up?
1730 			 */
1731 			cpi->cpi_ncache = sizeof (*cp) *
1732 			    BITX(cp->cp_eax, 7, 0);
1733 			if (cpi->cpi_ncache == 0)
1734 				break;
1735 			cpi->cpi_ncache--;	/* skip count byte */
1736 
1737 			/*
1738 			 * Well, for now, rather than attempt to implement
1739 			 * this slightly dubious algorithm, we just look
1740 			 * at the first 15 ..
1741 			 */
1742 			if (cpi->cpi_ncache > (sizeof (*cp) - 1))
1743 				cpi->cpi_ncache = sizeof (*cp) - 1;
1744 
1745 			dp = cpi->cpi_cacheinfo;
1746 			if (BITX(cp->cp_eax, 31, 31) == 0) {
1747 				uint8_t *p = (void *)&cp->cp_eax;
1748 				for (i = 1; i < 4; i++)
1749 					if (p[i] != 0)
1750 						*dp++ = p[i];
1751 			}
1752 			if (BITX(cp->cp_ebx, 31, 31) == 0) {
1753 				uint8_t *p = (void *)&cp->cp_ebx;
1754 				for (i = 0; i < 4; i++)
1755 					if (p[i] != 0)
1756 						*dp++ = p[i];
1757 			}
1758 			if (BITX(cp->cp_ecx, 31, 31) == 0) {
1759 				uint8_t *p = (void *)&cp->cp_ecx;
1760 				for (i = 0; i < 4; i++)
1761 					if (p[i] != 0)
1762 						*dp++ = p[i];
1763 			}
1764 			if (BITX(cp->cp_edx, 31, 31) == 0) {
1765 				uint8_t *p = (void *)&cp->cp_edx;
1766 				for (i = 0; i < 4; i++)
1767 					if (p[i] != 0)
1768 						*dp++ = p[i];
1769 			}
1770 			break;
1771 
1772 		case 3:	/* Processor serial number, if PSN supported */
1773 			break;
1774 
1775 		case 4:	/* Deterministic cache parameters */
1776 			break;
1777 
1778 		case 5:	/* Monitor/Mwait parameters */
1779 		{
1780 			size_t mwait_size;
1781 
1782 			/*
1783 			 * check cpi_mwait.support which was set in cpuid_pass1
1784 			 */
1785 			if (!(cpi->cpi_mwait.support & MWAIT_SUPPORT))
1786 				break;
1787 
1788 			/*
1789 			 * Protect ourself from insane mwait line size.
1790 			 * Workaround for incomplete hardware emulator(s).
1791 			 */
1792 			mwait_size = (size_t)MWAIT_SIZE_MAX(cpi);
1793 			if (mwait_size < sizeof (uint32_t) ||
1794 			    !ISP2(mwait_size)) {
1795 #if DEBUG
1796 				cmn_err(CE_NOTE, "Cannot handle cpu %d mwait "
1797 				    "size %ld", cpu->cpu_id, (long)mwait_size);
1798 #endif
1799 				break;
1800 			}
1801 
1802 			cpi->cpi_mwait.mon_min = (size_t)MWAIT_SIZE_MIN(cpi);
1803 			cpi->cpi_mwait.mon_max = mwait_size;
1804 			if (MWAIT_EXTENSION(cpi)) {
1805 				cpi->cpi_mwait.support |= MWAIT_EXTENSIONS;
1806 				if (MWAIT_INT_ENABLE(cpi))
1807 					cpi->cpi_mwait.support |=
1808 					    MWAIT_ECX_INT_ENABLE;
1809 			}
1810 			break;
1811 		}
1812 		default:
1813 			break;
1814 		}
1815 	}
1816 
1817 	if (cpi->cpi_maxeax >= 0xB && cpi->cpi_vendor == X86_VENDOR_Intel) {
1818 		struct cpuid_regs regs;
1819 
1820 		cp = &regs;
1821 		cp->cp_eax = 0xB;
1822 		cp->cp_edx = cp->cp_ebx = cp->cp_ecx = 0;
1823 
1824 		(void) __cpuid_insn(cp);
1825 
1826 		/*
1827 		 * Check CPUID.EAX=0BH, ECX=0H:EBX is non-zero, which
1828 		 * indicates that the extended topology enumeration leaf is
1829 		 * available.
1830 		 */
1831 		if (cp->cp_ebx) {
1832 			uint32_t x2apic_id;
1833 			uint_t coreid_shift = 0;
1834 			uint_t ncpu_per_core = 1;
1835 			uint_t chipid_shift = 0;
1836 			uint_t ncpu_per_chip = 1;
1837 			uint_t i;
1838 			uint_t level;
1839 
1840 			for (i = 0; i < CPI_FNB_ECX_MAX; i++) {
1841 				cp->cp_eax = 0xB;
1842 				cp->cp_ecx = i;
1843 
1844 				(void) __cpuid_insn(cp);
1845 				level = CPI_CPU_LEVEL_TYPE(cp);
1846 
1847 				if (level == 1) {
1848 					x2apic_id = cp->cp_edx;
1849 					coreid_shift = BITX(cp->cp_eax, 4, 0);
1850 					ncpu_per_core = BITX(cp->cp_ebx, 15, 0);
1851 				} else if (level == 2) {
1852 					x2apic_id = cp->cp_edx;
1853 					chipid_shift = BITX(cp->cp_eax, 4, 0);
1854 					ncpu_per_chip = BITX(cp->cp_ebx, 15, 0);
1855 				}
1856 			}
1857 
1858 			cpi->cpi_apicid = x2apic_id;
1859 			cpi->cpi_ncpu_per_chip = ncpu_per_chip;
1860 			cpi->cpi_ncore_per_chip = ncpu_per_chip /
1861 			    ncpu_per_core;
1862 			cpi->cpi_chipid = x2apic_id >> chipid_shift;
1863 			cpi->cpi_clogid = x2apic_id & ((1 << chipid_shift) - 1);
1864 			cpi->cpi_coreid = x2apic_id >> coreid_shift;
1865 			cpi->cpi_pkgcoreid = cpi->cpi_clogid >> coreid_shift;
1866 		}
1867 
1868 		/* Make cp NULL so that we don't stumble on others */
1869 		cp = NULL;
1870 	}
1871 
1872 	/*
1873 	 * XSAVE enumeration
1874 	 */
1875 	if (cpi->cpi_maxeax >= 0xD) {
1876 		struct cpuid_regs regs;
1877 		boolean_t cpuid_d_valid = B_TRUE;
1878 
1879 		cp = &regs;
1880 		cp->cp_eax = 0xD;
1881 		cp->cp_edx = cp->cp_ebx = cp->cp_ecx = 0;
1882 
1883 		(void) __cpuid_insn(cp);
1884 
1885 		/*
1886 		 * Sanity checks for debug
1887 		 */
1888 		if ((cp->cp_eax & XFEATURE_LEGACY_FP) == 0 ||
1889 		    (cp->cp_eax & XFEATURE_SSE) == 0) {
1890 			cpuid_d_valid = B_FALSE;
1891 		}
1892 
1893 		cpi->cpi_xsave.xsav_hw_features_low = cp->cp_eax;
1894 		cpi->cpi_xsave.xsav_hw_features_high = cp->cp_edx;
1895 		cpi->cpi_xsave.xsav_max_size = cp->cp_ecx;
1896 
1897 		/*
1898 		 * If the hw supports AVX, get the size and offset in the save
1899 		 * area for the ymm state.
1900 		 */
1901 		if (cpi->cpi_xsave.xsav_hw_features_low & XFEATURE_AVX) {
1902 			cp->cp_eax = 0xD;
1903 			cp->cp_ecx = 2;
1904 			cp->cp_edx = cp->cp_ebx = 0;
1905 
1906 			(void) __cpuid_insn(cp);
1907 
1908 			if (cp->cp_ebx != CPUID_LEAFD_2_YMM_OFFSET ||
1909 			    cp->cp_eax != CPUID_LEAFD_2_YMM_SIZE) {
1910 				cpuid_d_valid = B_FALSE;
1911 			}
1912 
1913 			cpi->cpi_xsave.ymm_size = cp->cp_eax;
1914 			cpi->cpi_xsave.ymm_offset = cp->cp_ebx;
1915 		}
1916 
1917 		if (is_x86_feature(x86_featureset, X86FSET_XSAVE)) {
1918 			xsave_state_size = 0;
1919 		} else if (cpuid_d_valid) {
1920 			xsave_state_size = cpi->cpi_xsave.xsav_max_size;
1921 		} else {
1922 			/* Broken CPUID 0xD, probably in HVM */
1923 			cmn_err(CE_WARN, "cpu%d: CPUID.0xD returns invalid "
1924 			    "value: hw_low = %d, hw_high = %d, xsave_size = %d"
1925 			    ", ymm_size = %d, ymm_offset = %d\n",
1926 			    cpu->cpu_id, cpi->cpi_xsave.xsav_hw_features_low,
1927 			    cpi->cpi_xsave.xsav_hw_features_high,
1928 			    (int)cpi->cpi_xsave.xsav_max_size,
1929 			    (int)cpi->cpi_xsave.ymm_size,
1930 			    (int)cpi->cpi_xsave.ymm_offset);
1931 
1932 			if (xsave_state_size != 0) {
1933 				/*
1934 				 * This must be a non-boot CPU. We cannot
1935 				 * continue, because boot cpu has already
1936 				 * enabled XSAVE.
1937 				 */
1938 				ASSERT(cpu->cpu_id != 0);
1939 				cmn_err(CE_PANIC, "cpu%d: we have already "
1940 				    "enabled XSAVE on boot cpu, cannot "
1941 				    "continue.", cpu->cpu_id);
1942 			} else {
1943 				/*
1944 				 * Must be from boot CPU, OK to disable XSAVE.
1945 				 */
1946 				ASSERT(cpu->cpu_id == 0);
1947 				remove_x86_feature(x86_featureset,
1948 				    X86FSET_XSAVE);
1949 				remove_x86_feature(x86_featureset, X86FSET_AVX);
1950 				CPI_FEATURES_ECX(cpi) &= ~CPUID_INTC_ECX_XSAVE;
1951 				CPI_FEATURES_ECX(cpi) &= ~CPUID_INTC_ECX_AVX;
1952 				CPI_FEATURES_ECX(cpi) &= ~CPUID_INTC_ECX_F16C;
1953 				xsave_force_disable = B_TRUE;
1954 			}
1955 		}
1956 	}
1957 
1958 
1959 	if ((cpi->cpi_xmaxeax & 0x80000000) == 0)
1960 		goto pass2_done;
1961 
1962 	if ((nmax = cpi->cpi_xmaxeax - 0x80000000 + 1) > NMAX_CPI_EXTD)
1963 		nmax = NMAX_CPI_EXTD;
1964 	/*
1965 	 * Copy the extended properties, fixing them as we go.
1966 	 * (We already handled n == 0 and n == 1 in pass 1)
1967 	 */
1968 	iptr = (void *)cpi->cpi_brandstr;
1969 	for (n = 2, cp = &cpi->cpi_extd[2]; n < nmax; cp++, n++) {
1970 		cp->cp_eax = 0x80000000 + n;
1971 		(void) __cpuid_insn(cp);
1972 		platform_cpuid_mangle(cpi->cpi_vendor, 0x80000000 + n, cp);
1973 		switch (n) {
1974 		case 2:
1975 		case 3:
1976 		case 4:
1977 			/*
1978 			 * Extract the brand string
1979 			 */
1980 			*iptr++ = cp->cp_eax;
1981 			*iptr++ = cp->cp_ebx;
1982 			*iptr++ = cp->cp_ecx;
1983 			*iptr++ = cp->cp_edx;
1984 			break;
1985 		case 5:
1986 			switch (cpi->cpi_vendor) {
1987 			case X86_VENDOR_AMD:
1988 				/*
1989 				 * The Athlon and Duron were the first
1990 				 * parts to report the sizes of the
1991 				 * TLB for large pages. Before then,
1992 				 * we don't trust the data.
1993 				 */
1994 				if (cpi->cpi_family < 6 ||
1995 				    (cpi->cpi_family == 6 &&
1996 				    cpi->cpi_model < 1))
1997 					cp->cp_eax = 0;
1998 				break;
1999 			default:
2000 				break;
2001 			}
2002 			break;
2003 		case 6:
2004 			switch (cpi->cpi_vendor) {
2005 			case X86_VENDOR_AMD:
2006 				/*
2007 				 * The Athlon and Duron were the first
2008 				 * AMD parts with L2 TLB's.
2009 				 * Before then, don't trust the data.
2010 				 */
2011 				if (cpi->cpi_family < 6 ||
2012 				    cpi->cpi_family == 6 &&
2013 				    cpi->cpi_model < 1)
2014 					cp->cp_eax = cp->cp_ebx = 0;
2015 				/*
2016 				 * AMD Duron rev A0 reports L2
2017 				 * cache size incorrectly as 1K
2018 				 * when it is really 64K
2019 				 */
2020 				if (cpi->cpi_family == 6 &&
2021 				    cpi->cpi_model == 3 &&
2022 				    cpi->cpi_step == 0) {
2023 					cp->cp_ecx &= 0xffff;
2024 					cp->cp_ecx |= 0x400000;
2025 				}
2026 				break;
2027 			case X86_VENDOR_Cyrix:	/* VIA C3 */
2028 				/*
2029 				 * VIA C3 processors are a bit messed
2030 				 * up w.r.t. encoding cache sizes in %ecx
2031 				 */
2032 				if (cpi->cpi_family != 6)
2033 					break;
2034 				/*
2035 				 * model 7 and 8 were incorrectly encoded
2036 				 *
2037 				 * xxx is model 8 really broken?
2038 				 */
2039 				if (cpi->cpi_model == 7 ||
2040 				    cpi->cpi_model == 8)
2041 					cp->cp_ecx =
2042 					    BITX(cp->cp_ecx, 31, 24) << 16 |
2043 					    BITX(cp->cp_ecx, 23, 16) << 12 |
2044 					    BITX(cp->cp_ecx, 15, 8) << 8 |
2045 					    BITX(cp->cp_ecx, 7, 0);
2046 				/*
2047 				 * model 9 stepping 1 has wrong associativity
2048 				 */
2049 				if (cpi->cpi_model == 9 && cpi->cpi_step == 1)
2050 					cp->cp_ecx |= 8 << 12;
2051 				break;
2052 			case X86_VENDOR_Intel:
2053 				/*
2054 				 * Extended L2 Cache features function.
2055 				 * First appeared on Prescott.
2056 				 */
2057 			default:
2058 				break;
2059 			}
2060 			break;
2061 		default:
2062 			break;
2063 		}
2064 	}
2065 
2066 pass2_done:
2067 	cpi->cpi_pass = 2;
2068 }
2069 
2070 static const char *
2071 intel_cpubrand(const struct cpuid_info *cpi)
2072 {
2073 	int i;
2074 
2075 	if (!is_x86_feature(x86_featureset, X86FSET_CPUID) ||
2076 	    cpi->cpi_maxeax < 1 || cpi->cpi_family < 5)
2077 		return ("i486");
2078 
2079 	switch (cpi->cpi_family) {
2080 	case 5:
2081 		return ("Intel Pentium(r)");
2082 	case 6:
2083 		switch (cpi->cpi_model) {
2084 			uint_t celeron, xeon;
2085 			const struct cpuid_regs *cp;
2086 		case 0:
2087 		case 1:
2088 		case 2:
2089 			return ("Intel Pentium(r) Pro");
2090 		case 3:
2091 		case 4:
2092 			return ("Intel Pentium(r) II");
2093 		case 6:
2094 			return ("Intel Celeron(r)");
2095 		case 5:
2096 		case 7:
2097 			celeron = xeon = 0;
2098 			cp = &cpi->cpi_std[2];	/* cache info */
2099 
2100 			for (i = 1; i < 4; i++) {
2101 				uint_t tmp;
2102 
2103 				tmp = (cp->cp_eax >> (8 * i)) & 0xff;
2104 				if (tmp == 0x40)
2105 					celeron++;
2106 				if (tmp >= 0x44 && tmp <= 0x45)
2107 					xeon++;
2108 			}
2109 
2110 			for (i = 0; i < 2; i++) {
2111 				uint_t tmp;
2112 
2113 				tmp = (cp->cp_ebx >> (8 * i)) & 0xff;
2114 				if (tmp == 0x40)
2115 					celeron++;
2116 				else if (tmp >= 0x44 && tmp <= 0x45)
2117 					xeon++;
2118 			}
2119 
2120 			for (i = 0; i < 4; i++) {
2121 				uint_t tmp;
2122 
2123 				tmp = (cp->cp_ecx >> (8 * i)) & 0xff;
2124 				if (tmp == 0x40)
2125 					celeron++;
2126 				else if (tmp >= 0x44 && tmp <= 0x45)
2127 					xeon++;
2128 			}
2129 
2130 			for (i = 0; i < 4; i++) {
2131 				uint_t tmp;
2132 
2133 				tmp = (cp->cp_edx >> (8 * i)) & 0xff;
2134 				if (tmp == 0x40)
2135 					celeron++;
2136 				else if (tmp >= 0x44 && tmp <= 0x45)
2137 					xeon++;
2138 			}
2139 
2140 			if (celeron)
2141 				return ("Intel Celeron(r)");
2142 			if (xeon)
2143 				return (cpi->cpi_model == 5 ?
2144 				    "Intel Pentium(r) II Xeon(tm)" :
2145 				    "Intel Pentium(r) III Xeon(tm)");
2146 			return (cpi->cpi_model == 5 ?
2147 			    "Intel Pentium(r) II or Pentium(r) II Xeon(tm)" :
2148 			    "Intel Pentium(r) III or Pentium(r) III Xeon(tm)");
2149 		default:
2150 			break;
2151 		}
2152 	default:
2153 		break;
2154 	}
2155 
2156 	/* BrandID is present if the field is nonzero */
2157 	if (cpi->cpi_brandid != 0) {
2158 		static const struct {
2159 			uint_t bt_bid;
2160 			const char *bt_str;
2161 		} brand_tbl[] = {
2162 			{ 0x1,	"Intel(r) Celeron(r)" },
2163 			{ 0x2,	"Intel(r) Pentium(r) III" },
2164 			{ 0x3,	"Intel(r) Pentium(r) III Xeon(tm)" },
2165 			{ 0x4,	"Intel(r) Pentium(r) III" },
2166 			{ 0x6,	"Mobile Intel(r) Pentium(r) III" },
2167 			{ 0x7,	"Mobile Intel(r) Celeron(r)" },
2168 			{ 0x8,	"Intel(r) Pentium(r) 4" },
2169 			{ 0x9,	"Intel(r) Pentium(r) 4" },
2170 			{ 0xa,	"Intel(r) Celeron(r)" },
2171 			{ 0xb,	"Intel(r) Xeon(tm)" },
2172 			{ 0xc,	"Intel(r) Xeon(tm) MP" },
2173 			{ 0xe,	"Mobile Intel(r) Pentium(r) 4" },
2174 			{ 0xf,	"Mobile Intel(r) Celeron(r)" },
2175 			{ 0x11, "Mobile Genuine Intel(r)" },
2176 			{ 0x12, "Intel(r) Celeron(r) M" },
2177 			{ 0x13, "Mobile Intel(r) Celeron(r)" },
2178 			{ 0x14, "Intel(r) Celeron(r)" },
2179 			{ 0x15, "Mobile Genuine Intel(r)" },
2180 			{ 0x16,	"Intel(r) Pentium(r) M" },
2181 			{ 0x17, "Mobile Intel(r) Celeron(r)" }
2182 		};
2183 		uint_t btblmax = sizeof (brand_tbl) / sizeof (brand_tbl[0]);
2184 		uint_t sgn;
2185 
2186 		sgn = (cpi->cpi_family << 8) |
2187 		    (cpi->cpi_model << 4) | cpi->cpi_step;
2188 
2189 		for (i = 0; i < btblmax; i++)
2190 			if (brand_tbl[i].bt_bid == cpi->cpi_brandid)
2191 				break;
2192 		if (i < btblmax) {
2193 			if (sgn == 0x6b1 && cpi->cpi_brandid == 3)
2194 				return ("Intel(r) Celeron(r)");
2195 			if (sgn < 0xf13 && cpi->cpi_brandid == 0xb)
2196 				return ("Intel(r) Xeon(tm) MP");
2197 			if (sgn < 0xf13 && cpi->cpi_brandid == 0xe)
2198 				return ("Intel(r) Xeon(tm)");
2199 			return (brand_tbl[i].bt_str);
2200 		}
2201 	}
2202 
2203 	return (NULL);
2204 }
2205 
2206 static const char *
2207 amd_cpubrand(const struct cpuid_info *cpi)
2208 {
2209 	if (!is_x86_feature(x86_featureset, X86FSET_CPUID) ||
2210 	    cpi->cpi_maxeax < 1 || cpi->cpi_family < 5)
2211 		return ("i486 compatible");
2212 
2213 	switch (cpi->cpi_family) {
2214 	case 5:
2215 		switch (cpi->cpi_model) {
2216 		case 0:
2217 		case 1:
2218 		case 2:
2219 		case 3:
2220 		case 4:
2221 		case 5:
2222 			return ("AMD-K5(r)");
2223 		case 6:
2224 		case 7:
2225 			return ("AMD-K6(r)");
2226 		case 8:
2227 			return ("AMD-K6(r)-2");
2228 		case 9:
2229 			return ("AMD-K6(r)-III");
2230 		default:
2231 			return ("AMD (family 5)");
2232 		}
2233 	case 6:
2234 		switch (cpi->cpi_model) {
2235 		case 1:
2236 			return ("AMD-K7(tm)");
2237 		case 0:
2238 		case 2:
2239 		case 4:
2240 			return ("AMD Athlon(tm)");
2241 		case 3:
2242 		case 7:
2243 			return ("AMD Duron(tm)");
2244 		case 6:
2245 		case 8:
2246 		case 10:
2247 			/*
2248 			 * Use the L2 cache size to distinguish
2249 			 */
2250 			return ((cpi->cpi_extd[6].cp_ecx >> 16) >= 256 ?
2251 			    "AMD Athlon(tm)" : "AMD Duron(tm)");
2252 		default:
2253 			return ("AMD (family 6)");
2254 		}
2255 	default:
2256 		break;
2257 	}
2258 
2259 	if (cpi->cpi_family == 0xf && cpi->cpi_model == 5 &&
2260 	    cpi->cpi_brandid != 0) {
2261 		switch (BITX(cpi->cpi_brandid, 7, 5)) {
2262 		case 3:
2263 			return ("AMD Opteron(tm) UP 1xx");
2264 		case 4:
2265 			return ("AMD Opteron(tm) DP 2xx");
2266 		case 5:
2267 			return ("AMD Opteron(tm) MP 8xx");
2268 		default:
2269 			return ("AMD Opteron(tm)");
2270 		}
2271 	}
2272 
2273 	return (NULL);
2274 }
2275 
2276 static const char *
2277 cyrix_cpubrand(struct cpuid_info *cpi, uint_t type)
2278 {
2279 	if (!is_x86_feature(x86_featureset, X86FSET_CPUID) ||
2280 	    cpi->cpi_maxeax < 1 || cpi->cpi_family < 5 ||
2281 	    type == X86_TYPE_CYRIX_486)
2282 		return ("i486 compatible");
2283 
2284 	switch (type) {
2285 	case X86_TYPE_CYRIX_6x86:
2286 		return ("Cyrix 6x86");
2287 	case X86_TYPE_CYRIX_6x86L:
2288 		return ("Cyrix 6x86L");
2289 	case X86_TYPE_CYRIX_6x86MX:
2290 		return ("Cyrix 6x86MX");
2291 	case X86_TYPE_CYRIX_GXm:
2292 		return ("Cyrix GXm");
2293 	case X86_TYPE_CYRIX_MediaGX:
2294 		return ("Cyrix MediaGX");
2295 	case X86_TYPE_CYRIX_MII:
2296 		return ("Cyrix M2");
2297 	case X86_TYPE_VIA_CYRIX_III:
2298 		return ("VIA Cyrix M3");
2299 	default:
2300 		/*
2301 		 * Have another wild guess ..
2302 		 */
2303 		if (cpi->cpi_family == 4 && cpi->cpi_model == 9)
2304 			return ("Cyrix 5x86");
2305 		else if (cpi->cpi_family == 5) {
2306 			switch (cpi->cpi_model) {
2307 			case 2:
2308 				return ("Cyrix 6x86");	/* Cyrix M1 */
2309 			case 4:
2310 				return ("Cyrix MediaGX");
2311 			default:
2312 				break;
2313 			}
2314 		} else if (cpi->cpi_family == 6) {
2315 			switch (cpi->cpi_model) {
2316 			case 0:
2317 				return ("Cyrix 6x86MX"); /* Cyrix M2? */
2318 			case 5:
2319 			case 6:
2320 			case 7:
2321 			case 8:
2322 			case 9:
2323 				return ("VIA C3");
2324 			default:
2325 				break;
2326 			}
2327 		}
2328 		break;
2329 	}
2330 	return (NULL);
2331 }
2332 
2333 /*
2334  * This only gets called in the case that the CPU extended
2335  * feature brand string (0x80000002, 0x80000003, 0x80000004)
2336  * aren't available, or contain null bytes for some reason.
2337  */
2338 static void
2339 fabricate_brandstr(struct cpuid_info *cpi)
2340 {
2341 	const char *brand = NULL;
2342 
2343 	switch (cpi->cpi_vendor) {
2344 	case X86_VENDOR_Intel:
2345 		brand = intel_cpubrand(cpi);
2346 		break;
2347 	case X86_VENDOR_AMD:
2348 		brand = amd_cpubrand(cpi);
2349 		break;
2350 	case X86_VENDOR_Cyrix:
2351 		brand = cyrix_cpubrand(cpi, x86_type);
2352 		break;
2353 	case X86_VENDOR_NexGen:
2354 		if (cpi->cpi_family == 5 && cpi->cpi_model == 0)
2355 			brand = "NexGen Nx586";
2356 		break;
2357 	case X86_VENDOR_Centaur:
2358 		if (cpi->cpi_family == 5)
2359 			switch (cpi->cpi_model) {
2360 			case 4:
2361 				brand = "Centaur C6";
2362 				break;
2363 			case 8:
2364 				brand = "Centaur C2";
2365 				break;
2366 			case 9:
2367 				brand = "Centaur C3";
2368 				break;
2369 			default:
2370 				break;
2371 			}
2372 		break;
2373 	case X86_VENDOR_Rise:
2374 		if (cpi->cpi_family == 5 &&
2375 		    (cpi->cpi_model == 0 || cpi->cpi_model == 2))
2376 			brand = "Rise mP6";
2377 		break;
2378 	case X86_VENDOR_SiS:
2379 		if (cpi->cpi_family == 5 && cpi->cpi_model == 0)
2380 			brand = "SiS 55x";
2381 		break;
2382 	case X86_VENDOR_TM:
2383 		if (cpi->cpi_family == 5 && cpi->cpi_model == 4)
2384 			brand = "Transmeta Crusoe TM3x00 or TM5x00";
2385 		break;
2386 	case X86_VENDOR_NSC:
2387 	case X86_VENDOR_UMC:
2388 	default:
2389 		break;
2390 	}
2391 	if (brand) {
2392 		(void) strcpy((char *)cpi->cpi_brandstr, brand);
2393 		return;
2394 	}
2395 
2396 	/*
2397 	 * If all else fails ...
2398 	 */
2399 	(void) snprintf(cpi->cpi_brandstr, sizeof (cpi->cpi_brandstr),
2400 	    "%s %d.%d.%d", cpi->cpi_vendorstr, cpi->cpi_family,
2401 	    cpi->cpi_model, cpi->cpi_step);
2402 }
2403 
2404 /*
2405  * This routine is called just after kernel memory allocation
2406  * becomes available on cpu0, and as part of mp_startup() on
2407  * the other cpus.
2408  *
2409  * Fixup the brand string, and collect any information from cpuid
2410  * that requires dynamically allocated storage to represent.
2411  */
2412 /*ARGSUSED*/
2413 void
2414 cpuid_pass3(cpu_t *cpu)
2415 {
2416 	int	i, max, shft, level, size;
2417 	struct cpuid_regs regs;
2418 	struct cpuid_regs *cp;
2419 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
2420 
2421 	ASSERT(cpi->cpi_pass == 2);
2422 
2423 	/*
2424 	 * Function 4: Deterministic cache parameters
2425 	 *
2426 	 * Take this opportunity to detect the number of threads
2427 	 * sharing the last level cache, and construct a corresponding
2428 	 * cache id. The respective cpuid_info members are initialized
2429 	 * to the default case of "no last level cache sharing".
2430 	 */
2431 	cpi->cpi_ncpu_shr_last_cache = 1;
2432 	cpi->cpi_last_lvl_cacheid = cpu->cpu_id;
2433 
2434 	if (cpi->cpi_maxeax >= 4 && cpi->cpi_vendor == X86_VENDOR_Intel) {
2435 
2436 		/*
2437 		 * Find the # of elements (size) returned by fn 4, and along
2438 		 * the way detect last level cache sharing details.
2439 		 */
2440 		bzero(&regs, sizeof (regs));
2441 		cp = &regs;
2442 		for (i = 0, max = 0; i < CPI_FN4_ECX_MAX; i++) {
2443 			cp->cp_eax = 4;
2444 			cp->cp_ecx = i;
2445 
2446 			(void) __cpuid_insn(cp);
2447 
2448 			if (CPI_CACHE_TYPE(cp) == 0)
2449 				break;
2450 			level = CPI_CACHE_LVL(cp);
2451 			if (level > max) {
2452 				max = level;
2453 				cpi->cpi_ncpu_shr_last_cache =
2454 				    CPI_NTHR_SHR_CACHE(cp) + 1;
2455 			}
2456 		}
2457 		cpi->cpi_std_4_size = size = i;
2458 
2459 		/*
2460 		 * Allocate the cpi_std_4 array. The first element
2461 		 * references the regs for fn 4, %ecx == 0, which
2462 		 * cpuid_pass2() stashed in cpi->cpi_std[4].
2463 		 */
2464 		if (size > 0) {
2465 			cpi->cpi_std_4 =
2466 			    kmem_alloc(size * sizeof (cp), KM_SLEEP);
2467 			cpi->cpi_std_4[0] = &cpi->cpi_std[4];
2468 
2469 			/*
2470 			 * Allocate storage to hold the additional regs
2471 			 * for function 4, %ecx == 1 .. cpi_std_4_size.
2472 			 *
2473 			 * The regs for fn 4, %ecx == 0 has already
2474 			 * been allocated as indicated above.
2475 			 */
2476 			for (i = 1; i < size; i++) {
2477 				cp = cpi->cpi_std_4[i] =
2478 				    kmem_zalloc(sizeof (regs), KM_SLEEP);
2479 				cp->cp_eax = 4;
2480 				cp->cp_ecx = i;
2481 
2482 				(void) __cpuid_insn(cp);
2483 			}
2484 		}
2485 		/*
2486 		 * Determine the number of bits needed to represent
2487 		 * the number of CPUs sharing the last level cache.
2488 		 *
2489 		 * Shift off that number of bits from the APIC id to
2490 		 * derive the cache id.
2491 		 */
2492 		shft = 0;
2493 		for (i = 1; i < cpi->cpi_ncpu_shr_last_cache; i <<= 1)
2494 			shft++;
2495 		cpi->cpi_last_lvl_cacheid = cpi->cpi_apicid >> shft;
2496 	}
2497 
2498 	/*
2499 	 * Now fixup the brand string
2500 	 */
2501 	if ((cpi->cpi_xmaxeax & 0x80000000) == 0) {
2502 		fabricate_brandstr(cpi);
2503 	} else {
2504 
2505 		/*
2506 		 * If we successfully extracted a brand string from the cpuid
2507 		 * instruction, clean it up by removing leading spaces and
2508 		 * similar junk.
2509 		 */
2510 		if (cpi->cpi_brandstr[0]) {
2511 			size_t maxlen = sizeof (cpi->cpi_brandstr);
2512 			char *src, *dst;
2513 
2514 			dst = src = (char *)cpi->cpi_brandstr;
2515 			src[maxlen - 1] = '\0';
2516 			/*
2517 			 * strip leading spaces
2518 			 */
2519 			while (*src == ' ')
2520 				src++;
2521 			/*
2522 			 * Remove any 'Genuine' or "Authentic" prefixes
2523 			 */
2524 			if (strncmp(src, "Genuine ", 8) == 0)
2525 				src += 8;
2526 			if (strncmp(src, "Authentic ", 10) == 0)
2527 				src += 10;
2528 
2529 			/*
2530 			 * Now do an in-place copy.
2531 			 * Map (R) to (r) and (TM) to (tm).
2532 			 * The era of teletypes is long gone, and there's
2533 			 * -really- no need to shout.
2534 			 */
2535 			while (*src != '\0') {
2536 				if (src[0] == '(') {
2537 					if (strncmp(src + 1, "R)", 2) == 0) {
2538 						(void) strncpy(dst, "(r)", 3);
2539 						src += 3;
2540 						dst += 3;
2541 						continue;
2542 					}
2543 					if (strncmp(src + 1, "TM)", 3) == 0) {
2544 						(void) strncpy(dst, "(tm)", 4);
2545 						src += 4;
2546 						dst += 4;
2547 						continue;
2548 					}
2549 				}
2550 				*dst++ = *src++;
2551 			}
2552 			*dst = '\0';
2553 
2554 			/*
2555 			 * Finally, remove any trailing spaces
2556 			 */
2557 			while (--dst > cpi->cpi_brandstr)
2558 				if (*dst == ' ')
2559 					*dst = '\0';
2560 				else
2561 					break;
2562 		} else
2563 			fabricate_brandstr(cpi);
2564 	}
2565 	cpi->cpi_pass = 3;
2566 }
2567 
2568 /*
2569  * This routine is called out of bind_hwcap() much later in the life
2570  * of the kernel (post_startup()).  The job of this routine is to resolve
2571  * the hardware feature support and kernel support for those features into
2572  * what we're actually going to tell applications via the aux vector.
2573  */
2574 void
2575 cpuid_pass4(cpu_t *cpu, uint_t *hwcap_out)
2576 {
2577 	struct cpuid_info *cpi;
2578 	uint_t hwcap_flags = 0, hwcap_flags_2 = 0;
2579 
2580 	if (cpu == NULL)
2581 		cpu = CPU;
2582 	cpi = cpu->cpu_m.mcpu_cpi;
2583 
2584 	ASSERT(cpi->cpi_pass == 3);
2585 
2586 	if (cpi->cpi_maxeax >= 1) {
2587 		uint32_t *edx = &cpi->cpi_support[STD_EDX_FEATURES];
2588 		uint32_t *ecx = &cpi->cpi_support[STD_ECX_FEATURES];
2589 
2590 		*edx = CPI_FEATURES_EDX(cpi);
2591 		*ecx = CPI_FEATURES_ECX(cpi);
2592 
2593 		/*
2594 		 * [these require explicit kernel support]
2595 		 */
2596 		if (!is_x86_feature(x86_featureset, X86FSET_SEP))
2597 			*edx &= ~CPUID_INTC_EDX_SEP;
2598 
2599 		if (!is_x86_feature(x86_featureset, X86FSET_SSE))
2600 			*edx &= ~(CPUID_INTC_EDX_FXSR|CPUID_INTC_EDX_SSE);
2601 		if (!is_x86_feature(x86_featureset, X86FSET_SSE2))
2602 			*edx &= ~CPUID_INTC_EDX_SSE2;
2603 
2604 		if (!is_x86_feature(x86_featureset, X86FSET_HTT))
2605 			*edx &= ~CPUID_INTC_EDX_HTT;
2606 
2607 		if (!is_x86_feature(x86_featureset, X86FSET_SSE3))
2608 			*ecx &= ~CPUID_INTC_ECX_SSE3;
2609 
2610 		if (!is_x86_feature(x86_featureset, X86FSET_SSSE3))
2611 			*ecx &= ~CPUID_INTC_ECX_SSSE3;
2612 		if (!is_x86_feature(x86_featureset, X86FSET_SSE4_1))
2613 			*ecx &= ~CPUID_INTC_ECX_SSE4_1;
2614 		if (!is_x86_feature(x86_featureset, X86FSET_SSE4_2))
2615 			*ecx &= ~CPUID_INTC_ECX_SSE4_2;
2616 		if (!is_x86_feature(x86_featureset, X86FSET_AES))
2617 			*ecx &= ~CPUID_INTC_ECX_AES;
2618 		if (!is_x86_feature(x86_featureset, X86FSET_PCLMULQDQ))
2619 			*ecx &= ~CPUID_INTC_ECX_PCLMULQDQ;
2620 		if (!is_x86_feature(x86_featureset, X86FSET_XSAVE))
2621 			*ecx &= ~(CPUID_INTC_ECX_XSAVE |
2622 			    CPUID_INTC_ECX_OSXSAVE);
2623 		if (!is_x86_feature(x86_featureset, X86FSET_AVX))
2624 			*ecx &= ~CPUID_INTC_ECX_AVX;
2625 		if (!is_x86_feature(x86_featureset, X86FSET_F16C))
2626 			*ecx &= ~CPUID_INTC_ECX_F16C;
2627 
2628 		/*
2629 		 * [no explicit support required beyond x87 fp context]
2630 		 */
2631 		if (!fpu_exists)
2632 			*edx &= ~(CPUID_INTC_EDX_FPU | CPUID_INTC_EDX_MMX);
2633 
2634 		/*
2635 		 * Now map the supported feature vector to things that we
2636 		 * think userland will care about.
2637 		 */
2638 		if (*edx & CPUID_INTC_EDX_SEP)
2639 			hwcap_flags |= AV_386_SEP;
2640 		if (*edx & CPUID_INTC_EDX_SSE)
2641 			hwcap_flags |= AV_386_FXSR | AV_386_SSE;
2642 		if (*edx & CPUID_INTC_EDX_SSE2)
2643 			hwcap_flags |= AV_386_SSE2;
2644 		if (*ecx & CPUID_INTC_ECX_SSE3)
2645 			hwcap_flags |= AV_386_SSE3;
2646 		if (*ecx & CPUID_INTC_ECX_SSSE3)
2647 			hwcap_flags |= AV_386_SSSE3;
2648 		if (*ecx & CPUID_INTC_ECX_SSE4_1)
2649 			hwcap_flags |= AV_386_SSE4_1;
2650 		if (*ecx & CPUID_INTC_ECX_SSE4_2)
2651 			hwcap_flags |= AV_386_SSE4_2;
2652 		if (*ecx & CPUID_INTC_ECX_MOVBE)
2653 			hwcap_flags |= AV_386_MOVBE;
2654 		if (*ecx & CPUID_INTC_ECX_AES)
2655 			hwcap_flags |= AV_386_AES;
2656 		if (*ecx & CPUID_INTC_ECX_PCLMULQDQ)
2657 			hwcap_flags |= AV_386_PCLMULQDQ;
2658 		if ((*ecx & CPUID_INTC_ECX_XSAVE) &&
2659 		    (*ecx & CPUID_INTC_ECX_OSXSAVE)) {
2660 			hwcap_flags |= AV_386_XSAVE;
2661 
2662 			if (*ecx & CPUID_INTC_ECX_AVX) {
2663 				hwcap_flags |= AV_386_AVX;
2664 				if (*ecx & CPUID_INTC_ECX_F16C)
2665 					hwcap_flags_2 |= AV_386_2_F16C;
2666 			}
2667 		}
2668 		if (*ecx & CPUID_INTC_ECX_VMX)
2669 			hwcap_flags |= AV_386_VMX;
2670 		if (*ecx & CPUID_INTC_ECX_POPCNT)
2671 			hwcap_flags |= AV_386_POPCNT;
2672 		if (*edx & CPUID_INTC_EDX_FPU)
2673 			hwcap_flags |= AV_386_FPU;
2674 		if (*edx & CPUID_INTC_EDX_MMX)
2675 			hwcap_flags |= AV_386_MMX;
2676 
2677 		if (*edx & CPUID_INTC_EDX_TSC)
2678 			hwcap_flags |= AV_386_TSC;
2679 		if (*edx & CPUID_INTC_EDX_CX8)
2680 			hwcap_flags |= AV_386_CX8;
2681 		if (*edx & CPUID_INTC_EDX_CMOV)
2682 			hwcap_flags |= AV_386_CMOV;
2683 		if (*ecx & CPUID_INTC_ECX_CX16)
2684 			hwcap_flags |= AV_386_CX16;
2685 
2686 		if (*ecx & CPUID_INTC_ECX_RDRAND)
2687 			hwcap_flags_2 |= AV_386_2_RDRAND;
2688 	}
2689 
2690 	if (cpi->cpi_xmaxeax < 0x80000001)
2691 		goto pass4_done;
2692 
2693 	switch (cpi->cpi_vendor) {
2694 		struct cpuid_regs cp;
2695 		uint32_t *edx, *ecx;
2696 
2697 	case X86_VENDOR_Intel:
2698 		/*
2699 		 * Seems like Intel duplicated what we necessary
2700 		 * here to make the initial crop of 64-bit OS's work.
2701 		 * Hopefully, those are the only "extended" bits
2702 		 * they'll add.
2703 		 */
2704 		/*FALLTHROUGH*/
2705 
2706 	case X86_VENDOR_AMD:
2707 		edx = &cpi->cpi_support[AMD_EDX_FEATURES];
2708 		ecx = &cpi->cpi_support[AMD_ECX_FEATURES];
2709 
2710 		*edx = CPI_FEATURES_XTD_EDX(cpi);
2711 		*ecx = CPI_FEATURES_XTD_ECX(cpi);
2712 
2713 		/*
2714 		 * [these features require explicit kernel support]
2715 		 */
2716 		switch (cpi->cpi_vendor) {
2717 		case X86_VENDOR_Intel:
2718 			if (!is_x86_feature(x86_featureset, X86FSET_TSCP))
2719 				*edx &= ~CPUID_AMD_EDX_TSCP;
2720 			break;
2721 
2722 		case X86_VENDOR_AMD:
2723 			if (!is_x86_feature(x86_featureset, X86FSET_TSCP))
2724 				*edx &= ~CPUID_AMD_EDX_TSCP;
2725 			if (!is_x86_feature(x86_featureset, X86FSET_SSE4A))
2726 				*ecx &= ~CPUID_AMD_ECX_SSE4A;
2727 			break;
2728 
2729 		default:
2730 			break;
2731 		}
2732 
2733 		/*
2734 		 * [no explicit support required beyond
2735 		 * x87 fp context and exception handlers]
2736 		 */
2737 		if (!fpu_exists)
2738 			*edx &= ~(CPUID_AMD_EDX_MMXamd |
2739 			    CPUID_AMD_EDX_3DNow | CPUID_AMD_EDX_3DNowx);
2740 
2741 		if (!is_x86_feature(x86_featureset, X86FSET_NX))
2742 			*edx &= ~CPUID_AMD_EDX_NX;
2743 #if !defined(__amd64)
2744 		*edx &= ~CPUID_AMD_EDX_LM;
2745 #endif
2746 		/*
2747 		 * Now map the supported feature vector to
2748 		 * things that we think userland will care about.
2749 		 */
2750 #if defined(__amd64)
2751 		if (*edx & CPUID_AMD_EDX_SYSC)
2752 			hwcap_flags |= AV_386_AMD_SYSC;
2753 #endif
2754 		if (*edx & CPUID_AMD_EDX_MMXamd)
2755 			hwcap_flags |= AV_386_AMD_MMX;
2756 		if (*edx & CPUID_AMD_EDX_3DNow)
2757 			hwcap_flags |= AV_386_AMD_3DNow;
2758 		if (*edx & CPUID_AMD_EDX_3DNowx)
2759 			hwcap_flags |= AV_386_AMD_3DNowx;
2760 		if (*ecx & CPUID_AMD_ECX_SVM)
2761 			hwcap_flags |= AV_386_AMD_SVM;
2762 
2763 		switch (cpi->cpi_vendor) {
2764 		case X86_VENDOR_AMD:
2765 			if (*edx & CPUID_AMD_EDX_TSCP)
2766 				hwcap_flags |= AV_386_TSCP;
2767 			if (*ecx & CPUID_AMD_ECX_AHF64)
2768 				hwcap_flags |= AV_386_AHF;
2769 			if (*ecx & CPUID_AMD_ECX_SSE4A)
2770 				hwcap_flags |= AV_386_AMD_SSE4A;
2771 			if (*ecx & CPUID_AMD_ECX_LZCNT)
2772 				hwcap_flags |= AV_386_AMD_LZCNT;
2773 			break;
2774 
2775 		case X86_VENDOR_Intel:
2776 			if (*edx & CPUID_AMD_EDX_TSCP)
2777 				hwcap_flags |= AV_386_TSCP;
2778 			/*
2779 			 * Aarrgh.
2780 			 * Intel uses a different bit in the same word.
2781 			 */
2782 			if (*ecx & CPUID_INTC_ECX_AHF64)
2783 				hwcap_flags |= AV_386_AHF;
2784 			break;
2785 
2786 		default:
2787 			break;
2788 		}
2789 		break;
2790 
2791 	case X86_VENDOR_TM:
2792 		cp.cp_eax = 0x80860001;
2793 		(void) __cpuid_insn(&cp);
2794 		cpi->cpi_support[TM_EDX_FEATURES] = cp.cp_edx;
2795 		break;
2796 
2797 	default:
2798 		break;
2799 	}
2800 
2801 pass4_done:
2802 	cpi->cpi_pass = 4;
2803 	if (hwcap_out != NULL) {
2804 		hwcap_out[0] = hwcap_flags;
2805 		hwcap_out[1] = hwcap_flags_2;
2806 	}
2807 }
2808 
2809 
2810 /*
2811  * Simulate the cpuid instruction using the data we previously
2812  * captured about this CPU.  We try our best to return the truth
2813  * about the hardware, independently of kernel support.
2814  */
2815 uint32_t
2816 cpuid_insn(cpu_t *cpu, struct cpuid_regs *cp)
2817 {
2818 	struct cpuid_info *cpi;
2819 	struct cpuid_regs *xcp;
2820 
2821 	if (cpu == NULL)
2822 		cpu = CPU;
2823 	cpi = cpu->cpu_m.mcpu_cpi;
2824 
2825 	ASSERT(cpuid_checkpass(cpu, 3));
2826 
2827 	/*
2828 	 * CPUID data is cached in two separate places: cpi_std for standard
2829 	 * CPUID functions, and cpi_extd for extended CPUID functions.
2830 	 */
2831 	if (cp->cp_eax <= cpi->cpi_maxeax && cp->cp_eax < NMAX_CPI_STD)
2832 		xcp = &cpi->cpi_std[cp->cp_eax];
2833 	else if (cp->cp_eax >= 0x80000000 && cp->cp_eax <= cpi->cpi_xmaxeax &&
2834 	    cp->cp_eax < 0x80000000 + NMAX_CPI_EXTD)
2835 		xcp = &cpi->cpi_extd[cp->cp_eax - 0x80000000];
2836 	else
2837 		/*
2838 		 * The caller is asking for data from an input parameter which
2839 		 * the kernel has not cached.  In this case we go fetch from
2840 		 * the hardware and return the data directly to the user.
2841 		 */
2842 		return (__cpuid_insn(cp));
2843 
2844 	cp->cp_eax = xcp->cp_eax;
2845 	cp->cp_ebx = xcp->cp_ebx;
2846 	cp->cp_ecx = xcp->cp_ecx;
2847 	cp->cp_edx = xcp->cp_edx;
2848 	return (cp->cp_eax);
2849 }
2850 
2851 int
2852 cpuid_checkpass(cpu_t *cpu, int pass)
2853 {
2854 	return (cpu != NULL && cpu->cpu_m.mcpu_cpi != NULL &&
2855 	    cpu->cpu_m.mcpu_cpi->cpi_pass >= pass);
2856 }
2857 
2858 int
2859 cpuid_getbrandstr(cpu_t *cpu, char *s, size_t n)
2860 {
2861 	ASSERT(cpuid_checkpass(cpu, 3));
2862 
2863 	return (snprintf(s, n, "%s", cpu->cpu_m.mcpu_cpi->cpi_brandstr));
2864 }
2865 
2866 int
2867 cpuid_is_cmt(cpu_t *cpu)
2868 {
2869 	if (cpu == NULL)
2870 		cpu = CPU;
2871 
2872 	ASSERT(cpuid_checkpass(cpu, 1));
2873 
2874 	return (cpu->cpu_m.mcpu_cpi->cpi_chipid >= 0);
2875 }
2876 
2877 /*
2878  * AMD and Intel both implement the 64-bit variant of the syscall
2879  * instruction (syscallq), so if there's -any- support for syscall,
2880  * cpuid currently says "yes, we support this".
2881  *
2882  * However, Intel decided to -not- implement the 32-bit variant of the
2883  * syscall instruction, so we provide a predicate to allow our caller
2884  * to test that subtlety here.
2885  *
2886  * XXPV	Currently, 32-bit syscall instructions don't work via the hypervisor,
2887  *	even in the case where the hardware would in fact support it.
2888  */
2889 /*ARGSUSED*/
2890 int
2891 cpuid_syscall32_insn(cpu_t *cpu)
2892 {
2893 	ASSERT(cpuid_checkpass((cpu == NULL ? CPU : cpu), 1));
2894 
2895 #if !defined(__xpv)
2896 	if (cpu == NULL)
2897 		cpu = CPU;
2898 
2899 	/*CSTYLED*/
2900 	{
2901 		struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
2902 
2903 		if (cpi->cpi_vendor == X86_VENDOR_AMD &&
2904 		    cpi->cpi_xmaxeax >= 0x80000001 &&
2905 		    (CPI_FEATURES_XTD_EDX(cpi) & CPUID_AMD_EDX_SYSC))
2906 			return (1);
2907 	}
2908 #endif
2909 	return (0);
2910 }
2911 
2912 int
2913 cpuid_getidstr(cpu_t *cpu, char *s, size_t n)
2914 {
2915 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
2916 
2917 	static const char fmt[] =
2918 	    "x86 (%s %X family %d model %d step %d clock %d MHz)";
2919 	static const char fmt_ht[] =
2920 	    "x86 (chipid 0x%x %s %X family %d model %d step %d clock %d MHz)";
2921 
2922 	ASSERT(cpuid_checkpass(cpu, 1));
2923 
2924 	if (cpuid_is_cmt(cpu))
2925 		return (snprintf(s, n, fmt_ht, cpi->cpi_chipid,
2926 		    cpi->cpi_vendorstr, cpi->cpi_std[1].cp_eax,
2927 		    cpi->cpi_family, cpi->cpi_model,
2928 		    cpi->cpi_step, cpu->cpu_type_info.pi_clock));
2929 	return (snprintf(s, n, fmt,
2930 	    cpi->cpi_vendorstr, cpi->cpi_std[1].cp_eax,
2931 	    cpi->cpi_family, cpi->cpi_model,
2932 	    cpi->cpi_step, cpu->cpu_type_info.pi_clock));
2933 }
2934 
2935 const char *
2936 cpuid_getvendorstr(cpu_t *cpu)
2937 {
2938 	ASSERT(cpuid_checkpass(cpu, 1));
2939 	return ((const char *)cpu->cpu_m.mcpu_cpi->cpi_vendorstr);
2940 }
2941 
2942 uint_t
2943 cpuid_getvendor(cpu_t *cpu)
2944 {
2945 	ASSERT(cpuid_checkpass(cpu, 1));
2946 	return (cpu->cpu_m.mcpu_cpi->cpi_vendor);
2947 }
2948 
2949 uint_t
2950 cpuid_getfamily(cpu_t *cpu)
2951 {
2952 	ASSERT(cpuid_checkpass(cpu, 1));
2953 	return (cpu->cpu_m.mcpu_cpi->cpi_family);
2954 }
2955 
2956 uint_t
2957 cpuid_getmodel(cpu_t *cpu)
2958 {
2959 	ASSERT(cpuid_checkpass(cpu, 1));
2960 	return (cpu->cpu_m.mcpu_cpi->cpi_model);
2961 }
2962 
2963 uint_t
2964 cpuid_get_ncpu_per_chip(cpu_t *cpu)
2965 {
2966 	ASSERT(cpuid_checkpass(cpu, 1));
2967 	return (cpu->cpu_m.mcpu_cpi->cpi_ncpu_per_chip);
2968 }
2969 
2970 uint_t
2971 cpuid_get_ncore_per_chip(cpu_t *cpu)
2972 {
2973 	ASSERT(cpuid_checkpass(cpu, 1));
2974 	return (cpu->cpu_m.mcpu_cpi->cpi_ncore_per_chip);
2975 }
2976 
2977 uint_t
2978 cpuid_get_ncpu_sharing_last_cache(cpu_t *cpu)
2979 {
2980 	ASSERT(cpuid_checkpass(cpu, 2));
2981 	return (cpu->cpu_m.mcpu_cpi->cpi_ncpu_shr_last_cache);
2982 }
2983 
2984 id_t
2985 cpuid_get_last_lvl_cacheid(cpu_t *cpu)
2986 {
2987 	ASSERT(cpuid_checkpass(cpu, 2));
2988 	return (cpu->cpu_m.mcpu_cpi->cpi_last_lvl_cacheid);
2989 }
2990 
2991 uint_t
2992 cpuid_getstep(cpu_t *cpu)
2993 {
2994 	ASSERT(cpuid_checkpass(cpu, 1));
2995 	return (cpu->cpu_m.mcpu_cpi->cpi_step);
2996 }
2997 
2998 uint_t
2999 cpuid_getsig(struct cpu *cpu)
3000 {
3001 	ASSERT(cpuid_checkpass(cpu, 1));
3002 	return (cpu->cpu_m.mcpu_cpi->cpi_std[1].cp_eax);
3003 }
3004 
3005 uint32_t
3006 cpuid_getchiprev(struct cpu *cpu)
3007 {
3008 	ASSERT(cpuid_checkpass(cpu, 1));
3009 	return (cpu->cpu_m.mcpu_cpi->cpi_chiprev);
3010 }
3011 
3012 const char *
3013 cpuid_getchiprevstr(struct cpu *cpu)
3014 {
3015 	ASSERT(cpuid_checkpass(cpu, 1));
3016 	return (cpu->cpu_m.mcpu_cpi->cpi_chiprevstr);
3017 }
3018 
3019 uint32_t
3020 cpuid_getsockettype(struct cpu *cpu)
3021 {
3022 	ASSERT(cpuid_checkpass(cpu, 1));
3023 	return (cpu->cpu_m.mcpu_cpi->cpi_socket);
3024 }
3025 
3026 const char *
3027 cpuid_getsocketstr(cpu_t *cpu)
3028 {
3029 	static const char *socketstr = NULL;
3030 	struct cpuid_info *cpi;
3031 
3032 	ASSERT(cpuid_checkpass(cpu, 1));
3033 	cpi = cpu->cpu_m.mcpu_cpi;
3034 
3035 	/* Assume that socket types are the same across the system */
3036 	if (socketstr == NULL)
3037 		socketstr = _cpuid_sktstr(cpi->cpi_vendor, cpi->cpi_family,
3038 		    cpi->cpi_model, cpi->cpi_step);
3039 
3040 
3041 	return (socketstr);
3042 }
3043 
3044 int
3045 cpuid_get_chipid(cpu_t *cpu)
3046 {
3047 	ASSERT(cpuid_checkpass(cpu, 1));
3048 
3049 	if (cpuid_is_cmt(cpu))
3050 		return (cpu->cpu_m.mcpu_cpi->cpi_chipid);
3051 	return (cpu->cpu_id);
3052 }
3053 
3054 id_t
3055 cpuid_get_coreid(cpu_t *cpu)
3056 {
3057 	ASSERT(cpuid_checkpass(cpu, 1));
3058 	return (cpu->cpu_m.mcpu_cpi->cpi_coreid);
3059 }
3060 
3061 int
3062 cpuid_get_pkgcoreid(cpu_t *cpu)
3063 {
3064 	ASSERT(cpuid_checkpass(cpu, 1));
3065 	return (cpu->cpu_m.mcpu_cpi->cpi_pkgcoreid);
3066 }
3067 
3068 int
3069 cpuid_get_clogid(cpu_t *cpu)
3070 {
3071 	ASSERT(cpuid_checkpass(cpu, 1));
3072 	return (cpu->cpu_m.mcpu_cpi->cpi_clogid);
3073 }
3074 
3075 int
3076 cpuid_get_cacheid(cpu_t *cpu)
3077 {
3078 	ASSERT(cpuid_checkpass(cpu, 1));
3079 	return (cpu->cpu_m.mcpu_cpi->cpi_last_lvl_cacheid);
3080 }
3081 
3082 uint_t
3083 cpuid_get_procnodeid(cpu_t *cpu)
3084 {
3085 	ASSERT(cpuid_checkpass(cpu, 1));
3086 	return (cpu->cpu_m.mcpu_cpi->cpi_procnodeid);
3087 }
3088 
3089 uint_t
3090 cpuid_get_procnodes_per_pkg(cpu_t *cpu)
3091 {
3092 	ASSERT(cpuid_checkpass(cpu, 1));
3093 	return (cpu->cpu_m.mcpu_cpi->cpi_procnodes_per_pkg);
3094 }
3095 
3096 uint_t
3097 cpuid_get_compunitid(cpu_t *cpu)
3098 {
3099 	ASSERT(cpuid_checkpass(cpu, 1));
3100 	return (cpu->cpu_m.mcpu_cpi->cpi_compunitid);
3101 }
3102 
3103 uint_t
3104 cpuid_get_cores_per_compunit(cpu_t *cpu)
3105 {
3106 	ASSERT(cpuid_checkpass(cpu, 1));
3107 	return (cpu->cpu_m.mcpu_cpi->cpi_cores_per_compunit);
3108 }
3109 
3110 /*ARGSUSED*/
3111 int
3112 cpuid_have_cr8access(cpu_t *cpu)
3113 {
3114 #if defined(__amd64)
3115 	return (1);
3116 #else
3117 	struct cpuid_info *cpi;
3118 
3119 	ASSERT(cpu != NULL);
3120 	cpi = cpu->cpu_m.mcpu_cpi;
3121 	if (cpi->cpi_vendor == X86_VENDOR_AMD && cpi->cpi_maxeax >= 1 &&
3122 	    (CPI_FEATURES_XTD_ECX(cpi) & CPUID_AMD_ECX_CR8D) != 0)
3123 		return (1);
3124 	return (0);
3125 #endif
3126 }
3127 
3128 uint32_t
3129 cpuid_get_apicid(cpu_t *cpu)
3130 {
3131 	ASSERT(cpuid_checkpass(cpu, 1));
3132 	if (cpu->cpu_m.mcpu_cpi->cpi_maxeax < 1) {
3133 		return (UINT32_MAX);
3134 	} else {
3135 		return (cpu->cpu_m.mcpu_cpi->cpi_apicid);
3136 	}
3137 }
3138 
3139 void
3140 cpuid_get_addrsize(cpu_t *cpu, uint_t *pabits, uint_t *vabits)
3141 {
3142 	struct cpuid_info *cpi;
3143 
3144 	if (cpu == NULL)
3145 		cpu = CPU;
3146 	cpi = cpu->cpu_m.mcpu_cpi;
3147 
3148 	ASSERT(cpuid_checkpass(cpu, 1));
3149 
3150 	if (pabits)
3151 		*pabits = cpi->cpi_pabits;
3152 	if (vabits)
3153 		*vabits = cpi->cpi_vabits;
3154 }
3155 
3156 /*
3157  * Returns the number of data TLB entries for a corresponding
3158  * pagesize.  If it can't be computed, or isn't known, the
3159  * routine returns zero.  If you ask about an architecturally
3160  * impossible pagesize, the routine will panic (so that the
3161  * hat implementor knows that things are inconsistent.)
3162  */
3163 uint_t
3164 cpuid_get_dtlb_nent(cpu_t *cpu, size_t pagesize)
3165 {
3166 	struct cpuid_info *cpi;
3167 	uint_t dtlb_nent = 0;
3168 
3169 	if (cpu == NULL)
3170 		cpu = CPU;
3171 	cpi = cpu->cpu_m.mcpu_cpi;
3172 
3173 	ASSERT(cpuid_checkpass(cpu, 1));
3174 
3175 	/*
3176 	 * Check the L2 TLB info
3177 	 */
3178 	if (cpi->cpi_xmaxeax >= 0x80000006) {
3179 		struct cpuid_regs *cp = &cpi->cpi_extd[6];
3180 
3181 		switch (pagesize) {
3182 
3183 		case 4 * 1024:
3184 			/*
3185 			 * All zero in the top 16 bits of the register
3186 			 * indicates a unified TLB. Size is in low 16 bits.
3187 			 */
3188 			if ((cp->cp_ebx & 0xffff0000) == 0)
3189 				dtlb_nent = cp->cp_ebx & 0x0000ffff;
3190 			else
3191 				dtlb_nent = BITX(cp->cp_ebx, 27, 16);
3192 			break;
3193 
3194 		case 2 * 1024 * 1024:
3195 			if ((cp->cp_eax & 0xffff0000) == 0)
3196 				dtlb_nent = cp->cp_eax & 0x0000ffff;
3197 			else
3198 				dtlb_nent = BITX(cp->cp_eax, 27, 16);
3199 			break;
3200 
3201 		default:
3202 			panic("unknown L2 pagesize");
3203 			/*NOTREACHED*/
3204 		}
3205 	}
3206 
3207 	if (dtlb_nent != 0)
3208 		return (dtlb_nent);
3209 
3210 	/*
3211 	 * No L2 TLB support for this size, try L1.
3212 	 */
3213 	if (cpi->cpi_xmaxeax >= 0x80000005) {
3214 		struct cpuid_regs *cp = &cpi->cpi_extd[5];
3215 
3216 		switch (pagesize) {
3217 		case 4 * 1024:
3218 			dtlb_nent = BITX(cp->cp_ebx, 23, 16);
3219 			break;
3220 		case 2 * 1024 * 1024:
3221 			dtlb_nent = BITX(cp->cp_eax, 23, 16);
3222 			break;
3223 		default:
3224 			panic("unknown L1 d-TLB pagesize");
3225 			/*NOTREACHED*/
3226 		}
3227 	}
3228 
3229 	return (dtlb_nent);
3230 }
3231 
3232 /*
3233  * Return 0 if the erratum is not present or not applicable, positive
3234  * if it is, and negative if the status of the erratum is unknown.
3235  *
3236  * See "Revision Guide for AMD Athlon(tm) 64 and AMD Opteron(tm)
3237  * Processors" #25759, Rev 3.57, August 2005
3238  */
3239 int
3240 cpuid_opteron_erratum(cpu_t *cpu, uint_t erratum)
3241 {
3242 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
3243 	uint_t eax;
3244 
3245 	/*
3246 	 * Bail out if this CPU isn't an AMD CPU, or if it's
3247 	 * a legacy (32-bit) AMD CPU.
3248 	 */
3249 	if (cpi->cpi_vendor != X86_VENDOR_AMD ||
3250 	    cpi->cpi_family == 4 || cpi->cpi_family == 5 ||
3251 	    cpi->cpi_family == 6)
3252 
3253 		return (0);
3254 
3255 	eax = cpi->cpi_std[1].cp_eax;
3256 
3257 #define	SH_B0(eax)	(eax == 0xf40 || eax == 0xf50)
3258 #define	SH_B3(eax) 	(eax == 0xf51)
3259 #define	B(eax)		(SH_B0(eax) || SH_B3(eax))
3260 
3261 #define	SH_C0(eax)	(eax == 0xf48 || eax == 0xf58)
3262 
3263 #define	SH_CG(eax)	(eax == 0xf4a || eax == 0xf5a || eax == 0xf7a)
3264 #define	DH_CG(eax)	(eax == 0xfc0 || eax == 0xfe0 || eax == 0xff0)
3265 #define	CH_CG(eax)	(eax == 0xf82 || eax == 0xfb2)
3266 #define	CG(eax)		(SH_CG(eax) || DH_CG(eax) || CH_CG(eax))
3267 
3268 #define	SH_D0(eax)	(eax == 0x10f40 || eax == 0x10f50 || eax == 0x10f70)
3269 #define	DH_D0(eax)	(eax == 0x10fc0 || eax == 0x10ff0)
3270 #define	CH_D0(eax)	(eax == 0x10f80 || eax == 0x10fb0)
3271 #define	D0(eax)		(SH_D0(eax) || DH_D0(eax) || CH_D0(eax))
3272 
3273 #define	SH_E0(eax)	(eax == 0x20f50 || eax == 0x20f40 || eax == 0x20f70)
3274 #define	JH_E1(eax)	(eax == 0x20f10)	/* JH8_E0 had 0x20f30 */
3275 #define	DH_E3(eax)	(eax == 0x20fc0 || eax == 0x20ff0)
3276 #define	SH_E4(eax)	(eax == 0x20f51 || eax == 0x20f71)
3277 #define	BH_E4(eax)	(eax == 0x20fb1)
3278 #define	SH_E5(eax)	(eax == 0x20f42)
3279 #define	DH_E6(eax)	(eax == 0x20ff2 || eax == 0x20fc2)
3280 #define	JH_E6(eax)	(eax == 0x20f12 || eax == 0x20f32)
3281 #define	EX(eax)		(SH_E0(eax) || JH_E1(eax) || DH_E3(eax) || \
3282 			    SH_E4(eax) || BH_E4(eax) || SH_E5(eax) || \
3283 			    DH_E6(eax) || JH_E6(eax))
3284 
3285 #define	DR_AX(eax)	(eax == 0x100f00 || eax == 0x100f01 || eax == 0x100f02)
3286 #define	DR_B0(eax)	(eax == 0x100f20)
3287 #define	DR_B1(eax)	(eax == 0x100f21)
3288 #define	DR_BA(eax)	(eax == 0x100f2a)
3289 #define	DR_B2(eax)	(eax == 0x100f22)
3290 #define	DR_B3(eax)	(eax == 0x100f23)
3291 #define	RB_C0(eax)	(eax == 0x100f40)
3292 
3293 	switch (erratum) {
3294 	case 1:
3295 		return (cpi->cpi_family < 0x10);
3296 	case 51:	/* what does the asterisk mean? */
3297 		return (B(eax) || SH_C0(eax) || CG(eax));
3298 	case 52:
3299 		return (B(eax));
3300 	case 57:
3301 		return (cpi->cpi_family <= 0x11);
3302 	case 58:
3303 		return (B(eax));
3304 	case 60:
3305 		return (cpi->cpi_family <= 0x11);
3306 	case 61:
3307 	case 62:
3308 	case 63:
3309 	case 64:
3310 	case 65:
3311 	case 66:
3312 	case 68:
3313 	case 69:
3314 	case 70:
3315 	case 71:
3316 		return (B(eax));
3317 	case 72:
3318 		return (SH_B0(eax));
3319 	case 74:
3320 		return (B(eax));
3321 	case 75:
3322 		return (cpi->cpi_family < 0x10);
3323 	case 76:
3324 		return (B(eax));
3325 	case 77:
3326 		return (cpi->cpi_family <= 0x11);
3327 	case 78:
3328 		return (B(eax) || SH_C0(eax));
3329 	case 79:
3330 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax) || EX(eax));
3331 	case 80:
3332 	case 81:
3333 	case 82:
3334 		return (B(eax));
3335 	case 83:
3336 		return (B(eax) || SH_C0(eax) || CG(eax));
3337 	case 85:
3338 		return (cpi->cpi_family < 0x10);
3339 	case 86:
3340 		return (SH_C0(eax) || CG(eax));
3341 	case 88:
3342 #if !defined(__amd64)
3343 		return (0);
3344 #else
3345 		return (B(eax) || SH_C0(eax));
3346 #endif
3347 	case 89:
3348 		return (cpi->cpi_family < 0x10);
3349 	case 90:
3350 		return (B(eax) || SH_C0(eax) || CG(eax));
3351 	case 91:
3352 	case 92:
3353 		return (B(eax) || SH_C0(eax));
3354 	case 93:
3355 		return (SH_C0(eax));
3356 	case 94:
3357 		return (B(eax) || SH_C0(eax) || CG(eax));
3358 	case 95:
3359 #if !defined(__amd64)
3360 		return (0);
3361 #else
3362 		return (B(eax) || SH_C0(eax));
3363 #endif
3364 	case 96:
3365 		return (B(eax) || SH_C0(eax) || CG(eax));
3366 	case 97:
3367 	case 98:
3368 		return (SH_C0(eax) || CG(eax));
3369 	case 99:
3370 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax));
3371 	case 100:
3372 		return (B(eax) || SH_C0(eax));
3373 	case 101:
3374 	case 103:
3375 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax));
3376 	case 104:
3377 		return (SH_C0(eax) || CG(eax) || D0(eax));
3378 	case 105:
3379 	case 106:
3380 	case 107:
3381 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax));
3382 	case 108:
3383 		return (DH_CG(eax));
3384 	case 109:
3385 		return (SH_C0(eax) || CG(eax) || D0(eax));
3386 	case 110:
3387 		return (D0(eax) || EX(eax));
3388 	case 111:
3389 		return (CG(eax));
3390 	case 112:
3391 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax) || EX(eax));
3392 	case 113:
3393 		return (eax == 0x20fc0);
3394 	case 114:
3395 		return (SH_E0(eax) || JH_E1(eax) || DH_E3(eax));
3396 	case 115:
3397 		return (SH_E0(eax) || JH_E1(eax));
3398 	case 116:
3399 		return (SH_E0(eax) || JH_E1(eax) || DH_E3(eax));
3400 	case 117:
3401 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax));
3402 	case 118:
3403 		return (SH_E0(eax) || JH_E1(eax) || SH_E4(eax) || BH_E4(eax) ||
3404 		    JH_E6(eax));
3405 	case 121:
3406 		return (B(eax) || SH_C0(eax) || CG(eax) || D0(eax) || EX(eax));
3407 	case 122:
3408 		return (cpi->cpi_family < 0x10 || cpi->cpi_family == 0x11);
3409 	case 123:
3410 		return (JH_E1(eax) || BH_E4(eax) || JH_E6(eax));
3411 	case 131:
3412 		return (cpi->cpi_family < 0x10);
3413 	case 6336786:
3414 		/*
3415 		 * Test for AdvPowerMgmtInfo.TscPStateInvariant
3416 		 * if this is a K8 family or newer processor
3417 		 */
3418 		if (CPI_FAMILY(cpi) == 0xf) {
3419 			struct cpuid_regs regs;
3420 			regs.cp_eax = 0x80000007;
3421 			(void) __cpuid_insn(&regs);
3422 			return (!(regs.cp_edx & 0x100));
3423 		}
3424 		return (0);
3425 	case 6323525:
3426 		return (((((eax >> 12) & 0xff00) + (eax & 0xf00)) |
3427 		    (((eax >> 4) & 0xf) | ((eax >> 12) & 0xf0))) < 0xf40);
3428 
3429 	case 6671130:
3430 		/*
3431 		 * check for processors (pre-Shanghai) that do not provide
3432 		 * optimal management of 1gb ptes in its tlb.
3433 		 */
3434 		return (cpi->cpi_family == 0x10 && cpi->cpi_model < 4);
3435 
3436 	case 298:
3437 		return (DR_AX(eax) || DR_B0(eax) || DR_B1(eax) || DR_BA(eax) ||
3438 		    DR_B2(eax) || RB_C0(eax));
3439 
3440 	case 721:
3441 #if defined(__amd64)
3442 		return (cpi->cpi_family == 0x10 || cpi->cpi_family == 0x12);
3443 #else
3444 		return (0);
3445 #endif
3446 
3447 	default:
3448 		return (-1);
3449 
3450 	}
3451 }
3452 
3453 /*
3454  * Determine if specified erratum is present via OSVW (OS Visible Workaround).
3455  * Return 1 if erratum is present, 0 if not present and -1 if indeterminate.
3456  */
3457 int
3458 osvw_opteron_erratum(cpu_t *cpu, uint_t erratum)
3459 {
3460 	struct cpuid_info	*cpi;
3461 	uint_t			osvwid;
3462 	static int		osvwfeature = -1;
3463 	uint64_t		osvwlength;
3464 
3465 
3466 	cpi = cpu->cpu_m.mcpu_cpi;
3467 
3468 	/* confirm OSVW supported */
3469 	if (osvwfeature == -1) {
3470 		osvwfeature = cpi->cpi_extd[1].cp_ecx & CPUID_AMD_ECX_OSVW;
3471 	} else {
3472 		/* assert that osvw feature setting is consistent on all cpus */
3473 		ASSERT(osvwfeature ==
3474 		    (cpi->cpi_extd[1].cp_ecx & CPUID_AMD_ECX_OSVW));
3475 	}
3476 	if (!osvwfeature)
3477 		return (-1);
3478 
3479 	osvwlength = rdmsr(MSR_AMD_OSVW_ID_LEN) & OSVW_ID_LEN_MASK;
3480 
3481 	switch (erratum) {
3482 	case 298:	/* osvwid is 0 */
3483 		osvwid = 0;
3484 		if (osvwlength <= (uint64_t)osvwid) {
3485 			/* osvwid 0 is unknown */
3486 			return (-1);
3487 		}
3488 
3489 		/*
3490 		 * Check the OSVW STATUS MSR to determine the state
3491 		 * of the erratum where:
3492 		 *   0 - fixed by HW
3493 		 *   1 - BIOS has applied the workaround when BIOS
3494 		 *   workaround is available. (Or for other errata,
3495 		 *   OS workaround is required.)
3496 		 * For a value of 1, caller will confirm that the
3497 		 * erratum 298 workaround has indeed been applied by BIOS.
3498 		 *
3499 		 * A 1 may be set in cpus that have a HW fix
3500 		 * in a mixed cpu system. Regarding erratum 298:
3501 		 *   In a multiprocessor platform, the workaround above
3502 		 *   should be applied to all processors regardless of
3503 		 *   silicon revision when an affected processor is
3504 		 *   present.
3505 		 */
3506 
3507 		return (rdmsr(MSR_AMD_OSVW_STATUS +
3508 		    (osvwid / OSVW_ID_CNT_PER_MSR)) &
3509 		    (1ULL << (osvwid % OSVW_ID_CNT_PER_MSR)));
3510 
3511 	default:
3512 		return (-1);
3513 	}
3514 }
3515 
3516 static const char assoc_str[] = "associativity";
3517 static const char line_str[] = "line-size";
3518 static const char size_str[] = "size";
3519 
3520 static void
3521 add_cache_prop(dev_info_t *devi, const char *label, const char *type,
3522     uint32_t val)
3523 {
3524 	char buf[128];
3525 
3526 	/*
3527 	 * ndi_prop_update_int() is used because it is desirable for
3528 	 * DDI_PROP_HW_DEF and DDI_PROP_DONTSLEEP to be set.
3529 	 */
3530 	if (snprintf(buf, sizeof (buf), "%s-%s", label, type) < sizeof (buf))
3531 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, devi, buf, val);
3532 }
3533 
3534 /*
3535  * Intel-style cache/tlb description
3536  *
3537  * Standard cpuid level 2 gives a randomly ordered
3538  * selection of tags that index into a table that describes
3539  * cache and tlb properties.
3540  */
3541 
3542 static const char l1_icache_str[] = "l1-icache";
3543 static const char l1_dcache_str[] = "l1-dcache";
3544 static const char l2_cache_str[] = "l2-cache";
3545 static const char l3_cache_str[] = "l3-cache";
3546 static const char itlb4k_str[] = "itlb-4K";
3547 static const char dtlb4k_str[] = "dtlb-4K";
3548 static const char itlb2M_str[] = "itlb-2M";
3549 static const char itlb4M_str[] = "itlb-4M";
3550 static const char dtlb4M_str[] = "dtlb-4M";
3551 static const char dtlb24_str[] = "dtlb0-2M-4M";
3552 static const char itlb424_str[] = "itlb-4K-2M-4M";
3553 static const char itlb24_str[] = "itlb-2M-4M";
3554 static const char dtlb44_str[] = "dtlb-4K-4M";
3555 static const char sl1_dcache_str[] = "sectored-l1-dcache";
3556 static const char sl2_cache_str[] = "sectored-l2-cache";
3557 static const char itrace_str[] = "itrace-cache";
3558 static const char sl3_cache_str[] = "sectored-l3-cache";
3559 static const char sh_l2_tlb4k_str[] = "shared-l2-tlb-4k";
3560 
3561 static const struct cachetab {
3562 	uint8_t 	ct_code;
3563 	uint8_t		ct_assoc;
3564 	uint16_t 	ct_line_size;
3565 	size_t		ct_size;
3566 	const char	*ct_label;
3567 } intel_ctab[] = {
3568 	/*
3569 	 * maintain descending order!
3570 	 *
3571 	 * Codes ignored - Reason
3572 	 * ----------------------
3573 	 * 40H - intel_cpuid_4_cache_info() disambiguates l2/l3 cache
3574 	 * f0H/f1H - Currently we do not interpret prefetch size by design
3575 	 */
3576 	{ 0xe4, 16, 64, 8*1024*1024, l3_cache_str},
3577 	{ 0xe3, 16, 64, 4*1024*1024, l3_cache_str},
3578 	{ 0xe2, 16, 64, 2*1024*1024, l3_cache_str},
3579 	{ 0xde, 12, 64, 6*1024*1024, l3_cache_str},
3580 	{ 0xdd, 12, 64, 3*1024*1024, l3_cache_str},
3581 	{ 0xdc, 12, 64, ((1*1024*1024)+(512*1024)), l3_cache_str},
3582 	{ 0xd8, 8, 64, 4*1024*1024, l3_cache_str},
3583 	{ 0xd7, 8, 64, 2*1024*1024, l3_cache_str},
3584 	{ 0xd6, 8, 64, 1*1024*1024, l3_cache_str},
3585 	{ 0xd2, 4, 64, 2*1024*1024, l3_cache_str},
3586 	{ 0xd1, 4, 64, 1*1024*1024, l3_cache_str},
3587 	{ 0xd0, 4, 64, 512*1024, l3_cache_str},
3588 	{ 0xca, 4, 0, 512, sh_l2_tlb4k_str},
3589 	{ 0xc0, 4, 0, 8, dtlb44_str },
3590 	{ 0xba, 4, 0, 64, dtlb4k_str },
3591 	{ 0xb4, 4, 0, 256, dtlb4k_str },
3592 	{ 0xb3, 4, 0, 128, dtlb4k_str },
3593 	{ 0xb2, 4, 0, 64, itlb4k_str },
3594 	{ 0xb0, 4, 0, 128, itlb4k_str },
3595 	{ 0x87, 8, 64, 1024*1024, l2_cache_str},
3596 	{ 0x86, 4, 64, 512*1024, l2_cache_str},
3597 	{ 0x85, 8, 32, 2*1024*1024, l2_cache_str},
3598 	{ 0x84, 8, 32, 1024*1024, l2_cache_str},
3599 	{ 0x83, 8, 32, 512*1024, l2_cache_str},
3600 	{ 0x82, 8, 32, 256*1024, l2_cache_str},
3601 	{ 0x80, 8, 64, 512*1024, l2_cache_str},
3602 	{ 0x7f, 2, 64, 512*1024, l2_cache_str},
3603 	{ 0x7d, 8, 64, 2*1024*1024, sl2_cache_str},
3604 	{ 0x7c, 8, 64, 1024*1024, sl2_cache_str},
3605 	{ 0x7b, 8, 64, 512*1024, sl2_cache_str},
3606 	{ 0x7a, 8, 64, 256*1024, sl2_cache_str},
3607 	{ 0x79, 8, 64, 128*1024, sl2_cache_str},
3608 	{ 0x78, 8, 64, 1024*1024, l2_cache_str},
3609 	{ 0x73, 8, 0, 64*1024, itrace_str},
3610 	{ 0x72, 8, 0, 32*1024, itrace_str},
3611 	{ 0x71, 8, 0, 16*1024, itrace_str},
3612 	{ 0x70, 8, 0, 12*1024, itrace_str},
3613 	{ 0x68, 4, 64, 32*1024, sl1_dcache_str},
3614 	{ 0x67, 4, 64, 16*1024, sl1_dcache_str},
3615 	{ 0x66, 4, 64, 8*1024, sl1_dcache_str},
3616 	{ 0x60, 8, 64, 16*1024, sl1_dcache_str},
3617 	{ 0x5d, 0, 0, 256, dtlb44_str},
3618 	{ 0x5c, 0, 0, 128, dtlb44_str},
3619 	{ 0x5b, 0, 0, 64, dtlb44_str},
3620 	{ 0x5a, 4, 0, 32, dtlb24_str},
3621 	{ 0x59, 0, 0, 16, dtlb4k_str},
3622 	{ 0x57, 4, 0, 16, dtlb4k_str},
3623 	{ 0x56, 4, 0, 16, dtlb4M_str},
3624 	{ 0x55, 0, 0, 7, itlb24_str},
3625 	{ 0x52, 0, 0, 256, itlb424_str},
3626 	{ 0x51, 0, 0, 128, itlb424_str},
3627 	{ 0x50, 0, 0, 64, itlb424_str},
3628 	{ 0x4f, 0, 0, 32, itlb4k_str},
3629 	{ 0x4e, 24, 64, 6*1024*1024, l2_cache_str},
3630 	{ 0x4d, 16, 64, 16*1024*1024, l3_cache_str},
3631 	{ 0x4c, 12, 64, 12*1024*1024, l3_cache_str},
3632 	{ 0x4b, 16, 64, 8*1024*1024, l3_cache_str},
3633 	{ 0x4a, 12, 64, 6*1024*1024, l3_cache_str},
3634 	{ 0x49, 16, 64, 4*1024*1024, l3_cache_str},
3635 	{ 0x48, 12, 64, 3*1024*1024, l2_cache_str},
3636 	{ 0x47, 8, 64, 8*1024*1024, l3_cache_str},
3637 	{ 0x46, 4, 64, 4*1024*1024, l3_cache_str},
3638 	{ 0x45, 4, 32, 2*1024*1024, l2_cache_str},
3639 	{ 0x44, 4, 32, 1024*1024, l2_cache_str},
3640 	{ 0x43, 4, 32, 512*1024, l2_cache_str},
3641 	{ 0x42, 4, 32, 256*1024, l2_cache_str},
3642 	{ 0x41, 4, 32, 128*1024, l2_cache_str},
3643 	{ 0x3e, 4, 64, 512*1024, sl2_cache_str},
3644 	{ 0x3d, 6, 64, 384*1024, sl2_cache_str},
3645 	{ 0x3c, 4, 64, 256*1024, sl2_cache_str},
3646 	{ 0x3b, 2, 64, 128*1024, sl2_cache_str},
3647 	{ 0x3a, 6, 64, 192*1024, sl2_cache_str},
3648 	{ 0x39, 4, 64, 128*1024, sl2_cache_str},
3649 	{ 0x30, 8, 64, 32*1024, l1_icache_str},
3650 	{ 0x2c, 8, 64, 32*1024, l1_dcache_str},
3651 	{ 0x29, 8, 64, 4096*1024, sl3_cache_str},
3652 	{ 0x25, 8, 64, 2048*1024, sl3_cache_str},
3653 	{ 0x23, 8, 64, 1024*1024, sl3_cache_str},
3654 	{ 0x22, 4, 64, 512*1024, sl3_cache_str},
3655 	{ 0x0e, 6, 64, 24*1024, l1_dcache_str},
3656 	{ 0x0d, 4, 32, 16*1024, l1_dcache_str},
3657 	{ 0x0c, 4, 32, 16*1024, l1_dcache_str},
3658 	{ 0x0b, 4, 0, 4, itlb4M_str},
3659 	{ 0x0a, 2, 32, 8*1024, l1_dcache_str},
3660 	{ 0x08, 4, 32, 16*1024, l1_icache_str},
3661 	{ 0x06, 4, 32, 8*1024, l1_icache_str},
3662 	{ 0x05, 4, 0, 32, dtlb4M_str},
3663 	{ 0x04, 4, 0, 8, dtlb4M_str},
3664 	{ 0x03, 4, 0, 64, dtlb4k_str},
3665 	{ 0x02, 4, 0, 2, itlb4M_str},
3666 	{ 0x01, 4, 0, 32, itlb4k_str},
3667 	{ 0 }
3668 };
3669 
3670 static const struct cachetab cyrix_ctab[] = {
3671 	{ 0x70, 4, 0, 32, "tlb-4K" },
3672 	{ 0x80, 4, 16, 16*1024, "l1-cache" },
3673 	{ 0 }
3674 };
3675 
3676 /*
3677  * Search a cache table for a matching entry
3678  */
3679 static const struct cachetab *
3680 find_cacheent(const struct cachetab *ct, uint_t code)
3681 {
3682 	if (code != 0) {
3683 		for (; ct->ct_code != 0; ct++)
3684 			if (ct->ct_code <= code)
3685 				break;
3686 		if (ct->ct_code == code)
3687 			return (ct);
3688 	}
3689 	return (NULL);
3690 }
3691 
3692 /*
3693  * Populate cachetab entry with L2 or L3 cache-information using
3694  * cpuid function 4. This function is called from intel_walk_cacheinfo()
3695  * when descriptor 0x49 is encountered. It returns 0 if no such cache
3696  * information is found.
3697  */
3698 static int
3699 intel_cpuid_4_cache_info(struct cachetab *ct, struct cpuid_info *cpi)
3700 {
3701 	uint32_t level, i;
3702 	int ret = 0;
3703 
3704 	for (i = 0; i < cpi->cpi_std_4_size; i++) {
3705 		level = CPI_CACHE_LVL(cpi->cpi_std_4[i]);
3706 
3707 		if (level == 2 || level == 3) {
3708 			ct->ct_assoc = CPI_CACHE_WAYS(cpi->cpi_std_4[i]) + 1;
3709 			ct->ct_line_size =
3710 			    CPI_CACHE_COH_LN_SZ(cpi->cpi_std_4[i]) + 1;
3711 			ct->ct_size = ct->ct_assoc *
3712 			    (CPI_CACHE_PARTS(cpi->cpi_std_4[i]) + 1) *
3713 			    ct->ct_line_size *
3714 			    (cpi->cpi_std_4[i]->cp_ecx + 1);
3715 
3716 			if (level == 2) {
3717 				ct->ct_label = l2_cache_str;
3718 			} else if (level == 3) {
3719 				ct->ct_label = l3_cache_str;
3720 			}
3721 			ret = 1;
3722 		}
3723 	}
3724 
3725 	return (ret);
3726 }
3727 
3728 /*
3729  * Walk the cacheinfo descriptor, applying 'func' to every valid element
3730  * The walk is terminated if the walker returns non-zero.
3731  */
3732 static void
3733 intel_walk_cacheinfo(struct cpuid_info *cpi,
3734     void *arg, int (*func)(void *, const struct cachetab *))
3735 {
3736 	const struct cachetab *ct;
3737 	struct cachetab des_49_ct, des_b1_ct;
3738 	uint8_t *dp;
3739 	int i;
3740 
3741 	if ((dp = cpi->cpi_cacheinfo) == NULL)
3742 		return;
3743 	for (i = 0; i < cpi->cpi_ncache; i++, dp++) {
3744 		/*
3745 		 * For overloaded descriptor 0x49 we use cpuid function 4
3746 		 * if supported by the current processor, to create
3747 		 * cache information.
3748 		 * For overloaded descriptor 0xb1 we use X86_PAE flag
3749 		 * to disambiguate the cache information.
3750 		 */
3751 		if (*dp == 0x49 && cpi->cpi_maxeax >= 0x4 &&
3752 		    intel_cpuid_4_cache_info(&des_49_ct, cpi) == 1) {
3753 				ct = &des_49_ct;
3754 		} else if (*dp == 0xb1) {
3755 			des_b1_ct.ct_code = 0xb1;
3756 			des_b1_ct.ct_assoc = 4;
3757 			des_b1_ct.ct_line_size = 0;
3758 			if (is_x86_feature(x86_featureset, X86FSET_PAE)) {
3759 				des_b1_ct.ct_size = 8;
3760 				des_b1_ct.ct_label = itlb2M_str;
3761 			} else {
3762 				des_b1_ct.ct_size = 4;
3763 				des_b1_ct.ct_label = itlb4M_str;
3764 			}
3765 			ct = &des_b1_ct;
3766 		} else {
3767 			if ((ct = find_cacheent(intel_ctab, *dp)) == NULL) {
3768 				continue;
3769 			}
3770 		}
3771 
3772 		if (func(arg, ct) != 0) {
3773 			break;
3774 		}
3775 	}
3776 }
3777 
3778 /*
3779  * (Like the Intel one, except for Cyrix CPUs)
3780  */
3781 static void
3782 cyrix_walk_cacheinfo(struct cpuid_info *cpi,
3783     void *arg, int (*func)(void *, const struct cachetab *))
3784 {
3785 	const struct cachetab *ct;
3786 	uint8_t *dp;
3787 	int i;
3788 
3789 	if ((dp = cpi->cpi_cacheinfo) == NULL)
3790 		return;
3791 	for (i = 0; i < cpi->cpi_ncache; i++, dp++) {
3792 		/*
3793 		 * Search Cyrix-specific descriptor table first ..
3794 		 */
3795 		if ((ct = find_cacheent(cyrix_ctab, *dp)) != NULL) {
3796 			if (func(arg, ct) != 0)
3797 				break;
3798 			continue;
3799 		}
3800 		/*
3801 		 * .. else fall back to the Intel one
3802 		 */
3803 		if ((ct = find_cacheent(intel_ctab, *dp)) != NULL) {
3804 			if (func(arg, ct) != 0)
3805 				break;
3806 			continue;
3807 		}
3808 	}
3809 }
3810 
3811 /*
3812  * A cacheinfo walker that adds associativity, line-size, and size properties
3813  * to the devinfo node it is passed as an argument.
3814  */
3815 static int
3816 add_cacheent_props(void *arg, const struct cachetab *ct)
3817 {
3818 	dev_info_t *devi = arg;
3819 
3820 	add_cache_prop(devi, ct->ct_label, assoc_str, ct->ct_assoc);
3821 	if (ct->ct_line_size != 0)
3822 		add_cache_prop(devi, ct->ct_label, line_str,
3823 		    ct->ct_line_size);
3824 	add_cache_prop(devi, ct->ct_label, size_str, ct->ct_size);
3825 	return (0);
3826 }
3827 
3828 
3829 static const char fully_assoc[] = "fully-associative?";
3830 
3831 /*
3832  * AMD style cache/tlb description
3833  *
3834  * Extended functions 5 and 6 directly describe properties of
3835  * tlbs and various cache levels.
3836  */
3837 static void
3838 add_amd_assoc(dev_info_t *devi, const char *label, uint_t assoc)
3839 {
3840 	switch (assoc) {
3841 	case 0:	/* reserved; ignore */
3842 		break;
3843 	default:
3844 		add_cache_prop(devi, label, assoc_str, assoc);
3845 		break;
3846 	case 0xff:
3847 		add_cache_prop(devi, label, fully_assoc, 1);
3848 		break;
3849 	}
3850 }
3851 
3852 static void
3853 add_amd_tlb(dev_info_t *devi, const char *label, uint_t assoc, uint_t size)
3854 {
3855 	if (size == 0)
3856 		return;
3857 	add_cache_prop(devi, label, size_str, size);
3858 	add_amd_assoc(devi, label, assoc);
3859 }
3860 
3861 static void
3862 add_amd_cache(dev_info_t *devi, const char *label,
3863     uint_t size, uint_t assoc, uint_t lines_per_tag, uint_t line_size)
3864 {
3865 	if (size == 0 || line_size == 0)
3866 		return;
3867 	add_amd_assoc(devi, label, assoc);
3868 	/*
3869 	 * Most AMD parts have a sectored cache. Multiple cache lines are
3870 	 * associated with each tag. A sector consists of all cache lines
3871 	 * associated with a tag. For example, the AMD K6-III has a sector
3872 	 * size of 2 cache lines per tag.
3873 	 */
3874 	if (lines_per_tag != 0)
3875 		add_cache_prop(devi, label, "lines-per-tag", lines_per_tag);
3876 	add_cache_prop(devi, label, line_str, line_size);
3877 	add_cache_prop(devi, label, size_str, size * 1024);
3878 }
3879 
3880 static void
3881 add_amd_l2_assoc(dev_info_t *devi, const char *label, uint_t assoc)
3882 {
3883 	switch (assoc) {
3884 	case 0:	/* off */
3885 		break;
3886 	case 1:
3887 	case 2:
3888 	case 4:
3889 		add_cache_prop(devi, label, assoc_str, assoc);
3890 		break;
3891 	case 6:
3892 		add_cache_prop(devi, label, assoc_str, 8);
3893 		break;
3894 	case 8:
3895 		add_cache_prop(devi, label, assoc_str, 16);
3896 		break;
3897 	case 0xf:
3898 		add_cache_prop(devi, label, fully_assoc, 1);
3899 		break;
3900 	default: /* reserved; ignore */
3901 		break;
3902 	}
3903 }
3904 
3905 static void
3906 add_amd_l2_tlb(dev_info_t *devi, const char *label, uint_t assoc, uint_t size)
3907 {
3908 	if (size == 0 || assoc == 0)
3909 		return;
3910 	add_amd_l2_assoc(devi, label, assoc);
3911 	add_cache_prop(devi, label, size_str, size);
3912 }
3913 
3914 static void
3915 add_amd_l2_cache(dev_info_t *devi, const char *label,
3916     uint_t size, uint_t assoc, uint_t lines_per_tag, uint_t line_size)
3917 {
3918 	if (size == 0 || assoc == 0 || line_size == 0)
3919 		return;
3920 	add_amd_l2_assoc(devi, label, assoc);
3921 	if (lines_per_tag != 0)
3922 		add_cache_prop(devi, label, "lines-per-tag", lines_per_tag);
3923 	add_cache_prop(devi, label, line_str, line_size);
3924 	add_cache_prop(devi, label, size_str, size * 1024);
3925 }
3926 
3927 static void
3928 amd_cache_info(struct cpuid_info *cpi, dev_info_t *devi)
3929 {
3930 	struct cpuid_regs *cp;
3931 
3932 	if (cpi->cpi_xmaxeax < 0x80000005)
3933 		return;
3934 	cp = &cpi->cpi_extd[5];
3935 
3936 	/*
3937 	 * 4M/2M L1 TLB configuration
3938 	 *
3939 	 * We report the size for 2M pages because AMD uses two
3940 	 * TLB entries for one 4M page.
3941 	 */
3942 	add_amd_tlb(devi, "dtlb-2M",
3943 	    BITX(cp->cp_eax, 31, 24), BITX(cp->cp_eax, 23, 16));
3944 	add_amd_tlb(devi, "itlb-2M",
3945 	    BITX(cp->cp_eax, 15, 8), BITX(cp->cp_eax, 7, 0));
3946 
3947 	/*
3948 	 * 4K L1 TLB configuration
3949 	 */
3950 
3951 	switch (cpi->cpi_vendor) {
3952 		uint_t nentries;
3953 	case X86_VENDOR_TM:
3954 		if (cpi->cpi_family >= 5) {
3955 			/*
3956 			 * Crusoe processors have 256 TLB entries, but
3957 			 * cpuid data format constrains them to only
3958 			 * reporting 255 of them.
3959 			 */
3960 			if ((nentries = BITX(cp->cp_ebx, 23, 16)) == 255)
3961 				nentries = 256;
3962 			/*
3963 			 * Crusoe processors also have a unified TLB
3964 			 */
3965 			add_amd_tlb(devi, "tlb-4K", BITX(cp->cp_ebx, 31, 24),
3966 			    nentries);
3967 			break;
3968 		}
3969 		/*FALLTHROUGH*/
3970 	default:
3971 		add_amd_tlb(devi, itlb4k_str,
3972 		    BITX(cp->cp_ebx, 31, 24), BITX(cp->cp_ebx, 23, 16));
3973 		add_amd_tlb(devi, dtlb4k_str,
3974 		    BITX(cp->cp_ebx, 15, 8), BITX(cp->cp_ebx, 7, 0));
3975 		break;
3976 	}
3977 
3978 	/*
3979 	 * data L1 cache configuration
3980 	 */
3981 
3982 	add_amd_cache(devi, l1_dcache_str,
3983 	    BITX(cp->cp_ecx, 31, 24), BITX(cp->cp_ecx, 23, 16),
3984 	    BITX(cp->cp_ecx, 15, 8), BITX(cp->cp_ecx, 7, 0));
3985 
3986 	/*
3987 	 * code L1 cache configuration
3988 	 */
3989 
3990 	add_amd_cache(devi, l1_icache_str,
3991 	    BITX(cp->cp_edx, 31, 24), BITX(cp->cp_edx, 23, 16),
3992 	    BITX(cp->cp_edx, 15, 8), BITX(cp->cp_edx, 7, 0));
3993 
3994 	if (cpi->cpi_xmaxeax < 0x80000006)
3995 		return;
3996 	cp = &cpi->cpi_extd[6];
3997 
3998 	/* Check for a unified L2 TLB for large pages */
3999 
4000 	if (BITX(cp->cp_eax, 31, 16) == 0)
4001 		add_amd_l2_tlb(devi, "l2-tlb-2M",
4002 		    BITX(cp->cp_eax, 15, 12), BITX(cp->cp_eax, 11, 0));
4003 	else {
4004 		add_amd_l2_tlb(devi, "l2-dtlb-2M",
4005 		    BITX(cp->cp_eax, 31, 28), BITX(cp->cp_eax, 27, 16));
4006 		add_amd_l2_tlb(devi, "l2-itlb-2M",
4007 		    BITX(cp->cp_eax, 15, 12), BITX(cp->cp_eax, 11, 0));
4008 	}
4009 
4010 	/* Check for a unified L2 TLB for 4K pages */
4011 
4012 	if (BITX(cp->cp_ebx, 31, 16) == 0) {
4013 		add_amd_l2_tlb(devi, "l2-tlb-4K",
4014 		    BITX(cp->cp_eax, 15, 12), BITX(cp->cp_eax, 11, 0));
4015 	} else {
4016 		add_amd_l2_tlb(devi, "l2-dtlb-4K",
4017 		    BITX(cp->cp_eax, 31, 28), BITX(cp->cp_eax, 27, 16));
4018 		add_amd_l2_tlb(devi, "l2-itlb-4K",
4019 		    BITX(cp->cp_eax, 15, 12), BITX(cp->cp_eax, 11, 0));
4020 	}
4021 
4022 	add_amd_l2_cache(devi, l2_cache_str,
4023 	    BITX(cp->cp_ecx, 31, 16), BITX(cp->cp_ecx, 15, 12),
4024 	    BITX(cp->cp_ecx, 11, 8), BITX(cp->cp_ecx, 7, 0));
4025 }
4026 
4027 /*
4028  * There are two basic ways that the x86 world describes it cache
4029  * and tlb architecture - Intel's way and AMD's way.
4030  *
4031  * Return which flavor of cache architecture we should use
4032  */
4033 static int
4034 x86_which_cacheinfo(struct cpuid_info *cpi)
4035 {
4036 	switch (cpi->cpi_vendor) {
4037 	case X86_VENDOR_Intel:
4038 		if (cpi->cpi_maxeax >= 2)
4039 			return (X86_VENDOR_Intel);
4040 		break;
4041 	case X86_VENDOR_AMD:
4042 		/*
4043 		 * The K5 model 1 was the first part from AMD that reported
4044 		 * cache sizes via extended cpuid functions.
4045 		 */
4046 		if (cpi->cpi_family > 5 ||
4047 		    (cpi->cpi_family == 5 && cpi->cpi_model >= 1))
4048 			return (X86_VENDOR_AMD);
4049 		break;
4050 	case X86_VENDOR_TM:
4051 		if (cpi->cpi_family >= 5)
4052 			return (X86_VENDOR_AMD);
4053 		/*FALLTHROUGH*/
4054 	default:
4055 		/*
4056 		 * If they have extended CPU data for 0x80000005
4057 		 * then we assume they have AMD-format cache
4058 		 * information.
4059 		 *
4060 		 * If not, and the vendor happens to be Cyrix,
4061 		 * then try our-Cyrix specific handler.
4062 		 *
4063 		 * If we're not Cyrix, then assume we're using Intel's
4064 		 * table-driven format instead.
4065 		 */
4066 		if (cpi->cpi_xmaxeax >= 0x80000005)
4067 			return (X86_VENDOR_AMD);
4068 		else if (cpi->cpi_vendor == X86_VENDOR_Cyrix)
4069 			return (X86_VENDOR_Cyrix);
4070 		else if (cpi->cpi_maxeax >= 2)
4071 			return (X86_VENDOR_Intel);
4072 		break;
4073 	}
4074 	return (-1);
4075 }
4076 
4077 void
4078 cpuid_set_cpu_properties(void *dip, processorid_t cpu_id,
4079     struct cpuid_info *cpi)
4080 {
4081 	dev_info_t *cpu_devi;
4082 	int create;
4083 
4084 	cpu_devi = (dev_info_t *)dip;
4085 
4086 	/* device_type */
4087 	(void) ndi_prop_update_string(DDI_DEV_T_NONE, cpu_devi,
4088 	    "device_type", "cpu");
4089 
4090 	/* reg */
4091 	(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4092 	    "reg", cpu_id);
4093 
4094 	/* cpu-mhz, and clock-frequency */
4095 	if (cpu_freq > 0) {
4096 		long long mul;
4097 
4098 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4099 		    "cpu-mhz", cpu_freq);
4100 		if ((mul = cpu_freq * 1000000LL) <= INT_MAX)
4101 			(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4102 			    "clock-frequency", (int)mul);
4103 	}
4104 
4105 	if (!is_x86_feature(x86_featureset, X86FSET_CPUID)) {
4106 		return;
4107 	}
4108 
4109 	/* vendor-id */
4110 	(void) ndi_prop_update_string(DDI_DEV_T_NONE, cpu_devi,
4111 	    "vendor-id", cpi->cpi_vendorstr);
4112 
4113 	if (cpi->cpi_maxeax == 0) {
4114 		return;
4115 	}
4116 
4117 	/*
4118 	 * family, model, and step
4119 	 */
4120 	(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4121 	    "family", CPI_FAMILY(cpi));
4122 	(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4123 	    "cpu-model", CPI_MODEL(cpi));
4124 	(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4125 	    "stepping-id", CPI_STEP(cpi));
4126 
4127 	/* type */
4128 	switch (cpi->cpi_vendor) {
4129 	case X86_VENDOR_Intel:
4130 		create = 1;
4131 		break;
4132 	default:
4133 		create = 0;
4134 		break;
4135 	}
4136 	if (create)
4137 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4138 		    "type", CPI_TYPE(cpi));
4139 
4140 	/* ext-family */
4141 	switch (cpi->cpi_vendor) {
4142 	case X86_VENDOR_Intel:
4143 	case X86_VENDOR_AMD:
4144 		create = cpi->cpi_family >= 0xf;
4145 		break;
4146 	default:
4147 		create = 0;
4148 		break;
4149 	}
4150 	if (create)
4151 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4152 		    "ext-family", CPI_FAMILY_XTD(cpi));
4153 
4154 	/* ext-model */
4155 	switch (cpi->cpi_vendor) {
4156 	case X86_VENDOR_Intel:
4157 		create = IS_EXTENDED_MODEL_INTEL(cpi);
4158 		break;
4159 	case X86_VENDOR_AMD:
4160 		create = CPI_FAMILY(cpi) == 0xf;
4161 		break;
4162 	default:
4163 		create = 0;
4164 		break;
4165 	}
4166 	if (create)
4167 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4168 		    "ext-model", CPI_MODEL_XTD(cpi));
4169 
4170 	/* generation */
4171 	switch (cpi->cpi_vendor) {
4172 	case X86_VENDOR_AMD:
4173 		/*
4174 		 * AMD K5 model 1 was the first part to support this
4175 		 */
4176 		create = cpi->cpi_xmaxeax >= 0x80000001;
4177 		break;
4178 	default:
4179 		create = 0;
4180 		break;
4181 	}
4182 	if (create)
4183 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4184 		    "generation", BITX((cpi)->cpi_extd[1].cp_eax, 11, 8));
4185 
4186 	/* brand-id */
4187 	switch (cpi->cpi_vendor) {
4188 	case X86_VENDOR_Intel:
4189 		/*
4190 		 * brand id first appeared on Pentium III Xeon model 8,
4191 		 * and Celeron model 8 processors and Opteron
4192 		 */
4193 		create = cpi->cpi_family > 6 ||
4194 		    (cpi->cpi_family == 6 && cpi->cpi_model >= 8);
4195 		break;
4196 	case X86_VENDOR_AMD:
4197 		create = cpi->cpi_family >= 0xf;
4198 		break;
4199 	default:
4200 		create = 0;
4201 		break;
4202 	}
4203 	if (create && cpi->cpi_brandid != 0) {
4204 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4205 		    "brand-id", cpi->cpi_brandid);
4206 	}
4207 
4208 	/* chunks, and apic-id */
4209 	switch (cpi->cpi_vendor) {
4210 		/*
4211 		 * first available on Pentium IV and Opteron (K8)
4212 		 */
4213 	case X86_VENDOR_Intel:
4214 		create = IS_NEW_F6(cpi) || cpi->cpi_family >= 0xf;
4215 		break;
4216 	case X86_VENDOR_AMD:
4217 		create = cpi->cpi_family >= 0xf;
4218 		break;
4219 	default:
4220 		create = 0;
4221 		break;
4222 	}
4223 	if (create) {
4224 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4225 		    "chunks", CPI_CHUNKS(cpi));
4226 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4227 		    "apic-id", cpi->cpi_apicid);
4228 		if (cpi->cpi_chipid >= 0) {
4229 			(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4230 			    "chip#", cpi->cpi_chipid);
4231 			(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4232 			    "clog#", cpi->cpi_clogid);
4233 		}
4234 	}
4235 
4236 	/* cpuid-features */
4237 	(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4238 	    "cpuid-features", CPI_FEATURES_EDX(cpi));
4239 
4240 
4241 	/* cpuid-features-ecx */
4242 	switch (cpi->cpi_vendor) {
4243 	case X86_VENDOR_Intel:
4244 		create = IS_NEW_F6(cpi) || cpi->cpi_family >= 0xf;
4245 		break;
4246 	case X86_VENDOR_AMD:
4247 		create = cpi->cpi_family >= 0xf;
4248 		break;
4249 	default:
4250 		create = 0;
4251 		break;
4252 	}
4253 	if (create)
4254 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4255 		    "cpuid-features-ecx", CPI_FEATURES_ECX(cpi));
4256 
4257 	/* ext-cpuid-features */
4258 	switch (cpi->cpi_vendor) {
4259 	case X86_VENDOR_Intel:
4260 	case X86_VENDOR_AMD:
4261 	case X86_VENDOR_Cyrix:
4262 	case X86_VENDOR_TM:
4263 	case X86_VENDOR_Centaur:
4264 		create = cpi->cpi_xmaxeax >= 0x80000001;
4265 		break;
4266 	default:
4267 		create = 0;
4268 		break;
4269 	}
4270 	if (create) {
4271 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4272 		    "ext-cpuid-features", CPI_FEATURES_XTD_EDX(cpi));
4273 		(void) ndi_prop_update_int(DDI_DEV_T_NONE, cpu_devi,
4274 		    "ext-cpuid-features-ecx", CPI_FEATURES_XTD_ECX(cpi));
4275 	}
4276 
4277 	/*
4278 	 * Brand String first appeared in Intel Pentium IV, AMD K5
4279 	 * model 1, and Cyrix GXm.  On earlier models we try and
4280 	 * simulate something similar .. so this string should always
4281 	 * same -something- about the processor, however lame.
4282 	 */
4283 	(void) ndi_prop_update_string(DDI_DEV_T_NONE, cpu_devi,
4284 	    "brand-string", cpi->cpi_brandstr);
4285 
4286 	/*
4287 	 * Finally, cache and tlb information
4288 	 */
4289 	switch (x86_which_cacheinfo(cpi)) {
4290 	case X86_VENDOR_Intel:
4291 		intel_walk_cacheinfo(cpi, cpu_devi, add_cacheent_props);
4292 		break;
4293 	case X86_VENDOR_Cyrix:
4294 		cyrix_walk_cacheinfo(cpi, cpu_devi, add_cacheent_props);
4295 		break;
4296 	case X86_VENDOR_AMD:
4297 		amd_cache_info(cpi, cpu_devi);
4298 		break;
4299 	default:
4300 		break;
4301 	}
4302 }
4303 
4304 struct l2info {
4305 	int *l2i_csz;
4306 	int *l2i_lsz;
4307 	int *l2i_assoc;
4308 	int l2i_ret;
4309 };
4310 
4311 /*
4312  * A cacheinfo walker that fetches the size, line-size and associativity
4313  * of the L2 cache
4314  */
4315 static int
4316 intel_l2cinfo(void *arg, const struct cachetab *ct)
4317 {
4318 	struct l2info *l2i = arg;
4319 	int *ip;
4320 
4321 	if (ct->ct_label != l2_cache_str &&
4322 	    ct->ct_label != sl2_cache_str)
4323 		return (0);	/* not an L2 -- keep walking */
4324 
4325 	if ((ip = l2i->l2i_csz) != NULL)
4326 		*ip = ct->ct_size;
4327 	if ((ip = l2i->l2i_lsz) != NULL)
4328 		*ip = ct->ct_line_size;
4329 	if ((ip = l2i->l2i_assoc) != NULL)
4330 		*ip = ct->ct_assoc;
4331 	l2i->l2i_ret = ct->ct_size;
4332 	return (1);		/* was an L2 -- terminate walk */
4333 }
4334 
4335 /*
4336  * AMD L2/L3 Cache and TLB Associativity Field Definition:
4337  *
4338  *	Unlike the associativity for the L1 cache and tlb where the 8 bit
4339  *	value is the associativity, the associativity for the L2 cache and
4340  *	tlb is encoded in the following table. The 4 bit L2 value serves as
4341  *	an index into the amd_afd[] array to determine the associativity.
4342  *	-1 is undefined. 0 is fully associative.
4343  */
4344 
4345 static int amd_afd[] =
4346 	{-1, 1, 2, -1, 4, -1, 8, -1, 16, -1, 32, 48, 64, 96, 128, 0};
4347 
4348 static void
4349 amd_l2cacheinfo(struct cpuid_info *cpi, struct l2info *l2i)
4350 {
4351 	struct cpuid_regs *cp;
4352 	uint_t size, assoc;
4353 	int i;
4354 	int *ip;
4355 
4356 	if (cpi->cpi_xmaxeax < 0x80000006)
4357 		return;
4358 	cp = &cpi->cpi_extd[6];
4359 
4360 	if ((i = BITX(cp->cp_ecx, 15, 12)) != 0 &&
4361 	    (size = BITX(cp->cp_ecx, 31, 16)) != 0) {
4362 		uint_t cachesz = size * 1024;
4363 		assoc = amd_afd[i];
4364 
4365 		ASSERT(assoc != -1);
4366 
4367 		if ((ip = l2i->l2i_csz) != NULL)
4368 			*ip = cachesz;
4369 		if ((ip = l2i->l2i_lsz) != NULL)
4370 			*ip = BITX(cp->cp_ecx, 7, 0);
4371 		if ((ip = l2i->l2i_assoc) != NULL)
4372 			*ip = assoc;
4373 		l2i->l2i_ret = cachesz;
4374 	}
4375 }
4376 
4377 int
4378 getl2cacheinfo(cpu_t *cpu, int *csz, int *lsz, int *assoc)
4379 {
4380 	struct cpuid_info *cpi = cpu->cpu_m.mcpu_cpi;
4381 	struct l2info __l2info, *l2i = &__l2info;
4382 
4383 	l2i->l2i_csz = csz;
4384 	l2i->l2i_lsz = lsz;
4385 	l2i->l2i_assoc = assoc;
4386 	l2i->l2i_ret = -1;
4387 
4388 	switch (x86_which_cacheinfo(cpi)) {
4389 	case X86_VENDOR_Intel:
4390 		intel_walk_cacheinfo(cpi, l2i, intel_l2cinfo);
4391 		break;
4392 	case X86_VENDOR_Cyrix:
4393 		cyrix_walk_cacheinfo(cpi, l2i, intel_l2cinfo);
4394 		break;
4395 	case X86_VENDOR_AMD:
4396 		amd_l2cacheinfo(cpi, l2i);
4397 		break;
4398 	default:
4399 		break;
4400 	}
4401 	return (l2i->l2i_ret);
4402 }
4403 
4404 #if !defined(__xpv)
4405 
4406 uint32_t *
4407 cpuid_mwait_alloc(cpu_t *cpu)
4408 {
4409 	uint32_t	*ret;
4410 	size_t		mwait_size;
4411 
4412 	ASSERT(cpuid_checkpass(CPU, 2));
4413 
4414 	mwait_size = CPU->cpu_m.mcpu_cpi->cpi_mwait.mon_max;
4415 	if (mwait_size == 0)
4416 		return (NULL);
4417 
4418 	/*
4419 	 * kmem_alloc() returns cache line size aligned data for mwait_size
4420 	 * allocations.  mwait_size is currently cache line sized.  Neither
4421 	 * of these implementation details are guarantied to be true in the
4422 	 * future.
4423 	 *
4424 	 * First try allocating mwait_size as kmem_alloc() currently returns
4425 	 * correctly aligned memory.  If kmem_alloc() does not return
4426 	 * mwait_size aligned memory, then use mwait_size ROUNDUP.
4427 	 *
4428 	 * Set cpi_mwait.buf_actual and cpi_mwait.size_actual in case we
4429 	 * decide to free this memory.
4430 	 */
4431 	ret = kmem_zalloc(mwait_size, KM_SLEEP);
4432 	if (ret == (uint32_t *)P2ROUNDUP((uintptr_t)ret, mwait_size)) {
4433 		cpu->cpu_m.mcpu_cpi->cpi_mwait.buf_actual = ret;
4434 		cpu->cpu_m.mcpu_cpi->cpi_mwait.size_actual = mwait_size;
4435 		*ret = MWAIT_RUNNING;
4436 		return (ret);
4437 	} else {
4438 		kmem_free(ret, mwait_size);
4439 		ret = kmem_zalloc(mwait_size * 2, KM_SLEEP);
4440 		cpu->cpu_m.mcpu_cpi->cpi_mwait.buf_actual = ret;
4441 		cpu->cpu_m.mcpu_cpi->cpi_mwait.size_actual = mwait_size * 2;
4442 		ret = (uint32_t *)P2ROUNDUP((uintptr_t)ret, mwait_size);
4443 		*ret = MWAIT_RUNNING;
4444 		return (ret);
4445 	}
4446 }
4447 
4448 void
4449 cpuid_mwait_free(cpu_t *cpu)
4450 {
4451 	if (cpu->cpu_m.mcpu_cpi == NULL) {
4452 		return;
4453 	}
4454 
4455 	if (cpu->cpu_m.mcpu_cpi->cpi_mwait.buf_actual != NULL &&
4456 	    cpu->cpu_m.mcpu_cpi->cpi_mwait.size_actual > 0) {
4457 		kmem_free(cpu->cpu_m.mcpu_cpi->cpi_mwait.buf_actual,
4458 		    cpu->cpu_m.mcpu_cpi->cpi_mwait.size_actual);
4459 	}
4460 
4461 	cpu->cpu_m.mcpu_cpi->cpi_mwait.buf_actual = NULL;
4462 	cpu->cpu_m.mcpu_cpi->cpi_mwait.size_actual = 0;
4463 }
4464 
4465 void
4466 patch_tsc_read(int flag)
4467 {
4468 	size_t cnt;
4469 
4470 	switch (flag) {
4471 	case X86_NO_TSC:
4472 		cnt = &_no_rdtsc_end - &_no_rdtsc_start;
4473 		(void) memcpy((void *)tsc_read, (void *)&_no_rdtsc_start, cnt);
4474 		break;
4475 	case X86_HAVE_TSCP:
4476 		cnt = &_tscp_end - &_tscp_start;
4477 		(void) memcpy((void *)tsc_read, (void *)&_tscp_start, cnt);
4478 		break;
4479 	case X86_TSC_MFENCE:
4480 		cnt = &_tsc_mfence_end - &_tsc_mfence_start;
4481 		(void) memcpy((void *)tsc_read,
4482 		    (void *)&_tsc_mfence_start, cnt);
4483 		break;
4484 	case X86_TSC_LFENCE:
4485 		cnt = &_tsc_lfence_end - &_tsc_lfence_start;
4486 		(void) memcpy((void *)tsc_read,
4487 		    (void *)&_tsc_lfence_start, cnt);
4488 		break;
4489 	default:
4490 		break;
4491 	}
4492 }
4493 
4494 int
4495 cpuid_deep_cstates_supported(void)
4496 {
4497 	struct cpuid_info *cpi;
4498 	struct cpuid_regs regs;
4499 
4500 	ASSERT(cpuid_checkpass(CPU, 1));
4501 
4502 	cpi = CPU->cpu_m.mcpu_cpi;
4503 
4504 	if (!is_x86_feature(x86_featureset, X86FSET_CPUID))
4505 		return (0);
4506 
4507 	switch (cpi->cpi_vendor) {
4508 	case X86_VENDOR_Intel:
4509 		if (cpi->cpi_xmaxeax < 0x80000007)
4510 			return (0);
4511 
4512 		/*
4513 		 * TSC run at a constant rate in all ACPI C-states?
4514 		 */
4515 		regs.cp_eax = 0x80000007;
4516 		(void) __cpuid_insn(&regs);
4517 		return (regs.cp_edx & CPUID_TSC_CSTATE_INVARIANCE);
4518 
4519 	default:
4520 		return (0);
4521 	}
4522 }
4523 
4524 #endif	/* !__xpv */
4525 
4526 void
4527 post_startup_cpu_fixups(void)
4528 {
4529 #ifndef __xpv
4530 	/*
4531 	 * Some AMD processors support C1E state. Entering this state will
4532 	 * cause the local APIC timer to stop, which we can't deal with at
4533 	 * this time.
4534 	 */
4535 	if (cpuid_getvendor(CPU) == X86_VENDOR_AMD) {
4536 		on_trap_data_t otd;
4537 		uint64_t reg;
4538 
4539 		if (!on_trap(&otd, OT_DATA_ACCESS)) {
4540 			reg = rdmsr(MSR_AMD_INT_PENDING_CMP_HALT);
4541 			/* Disable C1E state if it is enabled by BIOS */
4542 			if ((reg >> AMD_ACTONCMPHALT_SHIFT) &
4543 			    AMD_ACTONCMPHALT_MASK) {
4544 				reg &= ~(AMD_ACTONCMPHALT_MASK <<
4545 				    AMD_ACTONCMPHALT_SHIFT);
4546 				wrmsr(MSR_AMD_INT_PENDING_CMP_HALT, reg);
4547 			}
4548 		}
4549 		no_trap();
4550 	}
4551 #endif	/* !__xpv */
4552 }
4553 
4554 /*
4555  * Setup necessary registers to enable XSAVE feature on this processor.
4556  * This function needs to be called early enough, so that no xsave/xrstor
4557  * ops will execute on the processor before the MSRs are properly set up.
4558  *
4559  * Current implementation has the following assumption:
4560  * - cpuid_pass1() is done, so that X86 features are known.
4561  * - fpu_probe() is done, so that fp_save_mech is chosen.
4562  */
4563 void
4564 xsave_setup_msr(cpu_t *cpu)
4565 {
4566 	ASSERT(fp_save_mech == FP_XSAVE);
4567 	ASSERT(is_x86_feature(x86_featureset, X86FSET_XSAVE));
4568 
4569 	/* Enable OSXSAVE in CR4. */
4570 	setcr4(getcr4() | CR4_OSXSAVE);
4571 	/*
4572 	 * Update SW copy of ECX, so that /dev/cpu/self/cpuid will report
4573 	 * correct value.
4574 	 */
4575 	cpu->cpu_m.mcpu_cpi->cpi_std[1].cp_ecx |= CPUID_INTC_ECX_OSXSAVE;
4576 	setup_xfem();
4577 }
4578 
4579 /*
4580  * Starting with the Westmere processor the local
4581  * APIC timer will continue running in all C-states,
4582  * including the deepest C-states.
4583  */
4584 int
4585 cpuid_arat_supported(void)
4586 {
4587 	struct cpuid_info *cpi;
4588 	struct cpuid_regs regs;
4589 
4590 	ASSERT(cpuid_checkpass(CPU, 1));
4591 	ASSERT(is_x86_feature(x86_featureset, X86FSET_CPUID));
4592 
4593 	cpi = CPU->cpu_m.mcpu_cpi;
4594 
4595 	switch (cpi->cpi_vendor) {
4596 	case X86_VENDOR_Intel:
4597 		/*
4598 		 * Always-running Local APIC Timer is
4599 		 * indicated by CPUID.6.EAX[2].
4600 		 */
4601 		if (cpi->cpi_maxeax >= 6) {
4602 			regs.cp_eax = 6;
4603 			(void) cpuid_insn(NULL, &regs);
4604 			return (regs.cp_eax & CPUID_CSTATE_ARAT);
4605 		} else {
4606 			return (0);
4607 		}
4608 	default:
4609 		return (0);
4610 	}
4611 }
4612 
4613 /*
4614  * Check support for Intel ENERGY_PERF_BIAS feature
4615  */
4616 int
4617 cpuid_iepb_supported(struct cpu *cp)
4618 {
4619 	struct cpuid_info *cpi = cp->cpu_m.mcpu_cpi;
4620 	struct cpuid_regs regs;
4621 
4622 	ASSERT(cpuid_checkpass(cp, 1));
4623 
4624 	if (!(is_x86_feature(x86_featureset, X86FSET_CPUID)) ||
4625 	    !(is_x86_feature(x86_featureset, X86FSET_MSR))) {
4626 		return (0);
4627 	}
4628 
4629 	/*
4630 	 * Intel ENERGY_PERF_BIAS MSR is indicated by
4631 	 * capability bit CPUID.6.ECX.3
4632 	 */
4633 	if ((cpi->cpi_vendor != X86_VENDOR_Intel) || (cpi->cpi_maxeax < 6))
4634 		return (0);
4635 
4636 	regs.cp_eax = 0x6;
4637 	(void) cpuid_insn(NULL, &regs);
4638 	return (regs.cp_ecx & CPUID_EPB_SUPPORT);
4639 }
4640 
4641 /*
4642  * Check support for TSC deadline timer
4643  *
4644  * TSC deadline timer provides a superior software programming
4645  * model over local APIC timer that eliminates "time drifts".
4646  * Instead of specifying a relative time, software specifies an
4647  * absolute time as the target at which the processor should
4648  * generate a timer event.
4649  */
4650 int
4651 cpuid_deadline_tsc_supported(void)
4652 {
4653 	struct cpuid_info *cpi = CPU->cpu_m.mcpu_cpi;
4654 	struct cpuid_regs regs;
4655 
4656 	ASSERT(cpuid_checkpass(CPU, 1));
4657 	ASSERT(is_x86_feature(x86_featureset, X86FSET_CPUID));
4658 
4659 	switch (cpi->cpi_vendor) {
4660 	case X86_VENDOR_Intel:
4661 		if (cpi->cpi_maxeax >= 1) {
4662 			regs.cp_eax = 1;
4663 			(void) cpuid_insn(NULL, &regs);
4664 			return (regs.cp_ecx & CPUID_DEADLINE_TSC);
4665 		} else {
4666 			return (0);
4667 		}
4668 	default:
4669 		return (0);
4670 	}
4671 }
4672 
4673 #if defined(__amd64) && !defined(__xpv)
4674 /*
4675  * Patch in versions of bcopy for high performance Intel Nhm processors
4676  * and later...
4677  */
4678 void
4679 patch_memops(uint_t vendor)
4680 {
4681 	size_t cnt, i;
4682 	caddr_t to, from;
4683 
4684 	if ((vendor == X86_VENDOR_Intel) &&
4685 	    is_x86_feature(x86_featureset, X86FSET_SSE4_2)) {
4686 		cnt = &bcopy_patch_end - &bcopy_patch_start;
4687 		to = &bcopy_ck_size;
4688 		from = &bcopy_patch_start;
4689 		for (i = 0; i < cnt; i++) {
4690 			*to++ = *from++;
4691 		}
4692 	}
4693 }
4694 #endif  /* __amd64 && !__xpv */
4695 
4696 /*
4697  * This function finds the number of bits to represent the number of cores per
4698  * chip and the number of strands per core for the Intel platforms.
4699  * It re-uses the x2APIC cpuid code of the cpuid_pass2().
4700  */
4701 void
4702 cpuid_get_ext_topo(uint_t vendor, uint_t *core_nbits, uint_t *strand_nbits)
4703 {
4704 	struct cpuid_regs regs;
4705 	struct cpuid_regs *cp = &regs;
4706 
4707 	if (vendor != X86_VENDOR_Intel) {
4708 		return;
4709 	}
4710 
4711 	/* if the cpuid level is 0xB, extended topo is available. */
4712 	cp->cp_eax = 0;
4713 	if (__cpuid_insn(cp) >= 0xB) {
4714 
4715 		cp->cp_eax = 0xB;
4716 		cp->cp_edx = cp->cp_ebx = cp->cp_ecx = 0;
4717 		(void) __cpuid_insn(cp);
4718 
4719 		/*
4720 		 * Check CPUID.EAX=0BH, ECX=0H:EBX is non-zero, which
4721 		 * indicates that the extended topology enumeration leaf is
4722 		 * available.
4723 		 */
4724 		if (cp->cp_ebx) {
4725 			uint_t coreid_shift = 0;
4726 			uint_t chipid_shift = 0;
4727 			uint_t i;
4728 			uint_t level;
4729 
4730 			for (i = 0; i < CPI_FNB_ECX_MAX; i++) {
4731 				cp->cp_eax = 0xB;
4732 				cp->cp_ecx = i;
4733 
4734 				(void) __cpuid_insn(cp);
4735 				level = CPI_CPU_LEVEL_TYPE(cp);
4736 
4737 				if (level == 1) {
4738 					/*
4739 					 * Thread level processor topology
4740 					 * Number of bits shift right APIC ID
4741 					 * to get the coreid.
4742 					 */
4743 					coreid_shift = BITX(cp->cp_eax, 4, 0);
4744 				} else if (level == 2) {
4745 					/*
4746 					 * Core level processor topology
4747 					 * Number of bits shift right APIC ID
4748 					 * to get the chipid.
4749 					 */
4750 					chipid_shift = BITX(cp->cp_eax, 4, 0);
4751 				}
4752 			}
4753 
4754 			if (coreid_shift > 0 && chipid_shift > coreid_shift) {
4755 				*strand_nbits = coreid_shift;
4756 				*core_nbits = chipid_shift - coreid_shift;
4757 			}
4758 		}
4759 	}
4760 }
4761