diff options
author | Michael Ellerman <mpe@ellerman.id.au> | 2014-05-23 04:15:30 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2014-05-27 23:35:37 -0400 |
commit | e2186023f2d81ee7bb42d2a7dec3d889df7cdace (patch) | |
tree | fdc949d0563aeabdce47ab8b49ee25c760e0ca7b /arch/powerpc/include/asm | |
parent | 3102f7843c75014fa15d3e6fda3b49f61bc467b4 (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.h | 9 |
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 |