aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/include/asm
diff options
context:
space:
mode:
authorMichael Ellerman <mpe@ellerman.id.au>2014-05-23 04:15:30 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2014-05-27 23:35:37 -0400
commite2186023f2d81ee7bb42d2a7dec3d889df7cdace (patch)
treefdc949d0563aeabdce47ab8b49ee25c760e0ca7b /arch/powerpc/include/asm
parent3102f7843c75014fa15d3e6fda3b49f61bc467b4 (diff)
powerpc/powernv: Add support for POWER8 split core on powernv
Upcoming POWER8 chips support a concept called split core. This is where the core can be split into subcores that although not full cores, are able to appear as full cores to a guest. The splitting & unsplitting procedure is mildly complicated, and explained at length in the comments within the patch. One notable detail is that when splitting or unsplitting we need to pull offline cpus out of their offline state to do work as part of the procedure. The interface for changing the split mode is via a sysfs file, eg: $ echo 2 > /sys/devices/system/cpu/subcores_per_core Currently supported values are '1', '2' and '4'. And indicate respectively that the core should be unsplit, split in half, and split in quarters. These modes correspond to threads_per_subcore of 8, 4 and 2. We do not allow changing the split mode while KVM VMs are active. This is to prevent the value changing while userspace is configuring the VM, and also to prevent the mode being changed in such a way that existing guests are unable to be run. CPU hotplug fixes by Srivatsa. max_cpus fixes by Mahesh. cpuset fixes by benh. Fix for irq race by paulus. The rest by mikey and mpe. Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Signed-off-by: Michael Neuling <mikey@neuling.org> Signed-off-by: Srivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com> Signed-off-by: Mahesh Salgaonkar <mahesh@linux.vnet.ibm.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/include/asm')
-rw-r--r--arch/powerpc/include/asm/reg.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/reg.h b/arch/powerpc/include/asm/reg.h
index 29de0152878f..2cd799b382ec 100644
--- a/arch/powerpc/include/asm/reg.h
+++ b/arch/powerpc/include/asm/reg.h
@@ -225,6 +225,7 @@
225#define CTRL_TE 0x00c00000 /* thread enable */ 225#define CTRL_TE 0x00c00000 /* thread enable */
226#define CTRL_RUNLATCH 0x1 226#define CTRL_RUNLATCH 0x1
227#define SPRN_DAWR 0xB4 227#define SPRN_DAWR 0xB4
228#define SPRN_RPR 0xBA /* Relative Priority Register */
228#define SPRN_CIABR 0xBB 229#define SPRN_CIABR 0xBB
229#define CIABR_PRIV 0x3 230#define CIABR_PRIV 0x3
230#define CIABR_PRIV_USER 1 231#define CIABR_PRIV_USER 1
@@ -273,8 +274,10 @@
273#define SPRN_HSRR1 0x13B /* Hypervisor Save/Restore 1 */ 274#define SPRN_HSRR1 0x13B /* Hypervisor Save/Restore 1 */
274#define SPRN_IC 0x350 /* Virtual Instruction Count */ 275#define SPRN_IC 0x350 /* Virtual Instruction Count */
275#define SPRN_VTB 0x351 /* Virtual Time Base */ 276#define SPRN_VTB 0x351 /* Virtual Time Base */
277#define SPRN_LDBAR 0x352 /* LD Base Address Register */
276#define SPRN_PMICR 0x354 /* Power Management Idle Control Reg */ 278#define SPRN_PMICR 0x354 /* Power Management Idle Control Reg */
277#define SPRN_PMSR 0x355 /* Power Management Status Reg */ 279#define SPRN_PMSR 0x355 /* Power Management Status Reg */
280#define SPRN_PMMAR 0x356 /* Power Management Memory Activity Register */
278#define SPRN_PMCR 0x374 /* Power Management Control Register */ 281#define SPRN_PMCR 0x374 /* Power Management Control Register */
279 282
280/* HFSCR and FSCR bit numbers are the same */ 283/* HFSCR and FSCR bit numbers are the same */
@@ -434,6 +437,12 @@
434#define HID0_BTCD (1<<1) /* Branch target cache disable */ 437#define HID0_BTCD (1<<1) /* Branch target cache disable */
435#define HID0_NOPDST (1<<1) /* No-op dst, dstt, etc. instr. */ 438#define HID0_NOPDST (1<<1) /* No-op dst, dstt, etc. instr. */
436#define HID0_NOPTI (1<<0) /* No-op dcbt and dcbst instr. */ 439#define HID0_NOPTI (1<<0) /* No-op dcbt and dcbst instr. */
440/* POWER8 HID0 bits */
441#define HID0_POWER8_4LPARMODE __MASK(61)
442#define HID0_POWER8_2LPARMODE __MASK(57)
443#define HID0_POWER8_1TO2LPAR __MASK(52)
444#define HID0_POWER8_1TO4LPAR __MASK(51)
445#define HID0_POWER8_DYNLPARDIS __MASK(48)
437 446
438#define SPRN_HID1 0x3F1 /* Hardware Implementation Register 1 */ 447#define SPRN_HID1 0x3F1 /* Hardware Implementation Register 1 */
439#ifdef CONFIG_6xx 448#ifdef CONFIG_6xx