mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 23:00:21 +00:00
powerpc fixes for 4.12 #4
Fix running SPU programs on Cell, and a few other minor fixes. Thanks to: Alistair Popple, Jeremy Kerr, Michael Neuling, Nicholas Piggin. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJZKURPAAoJEFHr6jzI4aWAhckQAJxZZHt2OMbdNu0PxHdhZgxo +eSODIF0jvzBnYs/Pe9aqqrxuONxW+ioclyUIVYLUlHwLjCGf7x2Y5tJe0OmEff6 ZOaUUcwECKw4cy2UJY6NCGv0nw/8INTDN5xPcQq9M8gExmX6plTmbnQg8Y10ONdQ LYu36GWyXF4ygblvLo7kXs8tuZYKozO6kPRqxiQ3zML2dOAyqWqPwpnoWSc6c7oR W+z/Vuxe3lTR+QHbfvnSpQhmdVi+WEnwFvgNmIise5R9Jd30Q1f1vES5E089ifmN b0Qi5/gkb6YWBkROvxTARFRdmU0/YPNDFWUsuyHJB/Nz1MnqqXx5X+5KpqqinPya azVoYW010x2zawm0aX+BF/WeH5ymsl++R84/aO8UR0fA2AIwEOQeLGWZvaZb8CMl 9vd3NqCJ+diBhgCHiHp80pjD978bqt7Ls1nfbHhYTJ31HRT8Yz/ympWOhLE6rp+t kGR+UOHduaZWK3KHoE2WIoUFJuQMvRgFmjoy2G+YaK/PcUc8OA+90v1665fnbk+N wmZyAirP39gveHkHXDywqbEjN4CSMgsqrRW/KwPo0b4mf2m3rsIAshO9pBbZRv+P evhrAkCYRv5zGbGIYJ/TiEyball+8NQzxzoYmMzq62pjE27gyIe94Sqy80U4zyOC RqqUxflOBgMDC8Ufc30u =EM32 -----END PGP SIGNATURE----- Merge tag 'powerpc-4.12-4' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux Pull powerpc fixes from Michael Ellerman: "Fix running SPU programs on Cell, and a few other minor fixes. Thanks to Alistair Popple, Jeremy Kerr, Michael Neuling, Nicholas Piggin" * tag 'powerpc-4.12-4' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux: powerpc: Add PPC_FEATURE userspace bits for SCV and DARN instructions powerpc/spufs: Fix hash faults for kernel regions powerpc: Fix booting P9 hash with CONFIG_PPC_RADIX_MMU=N powerpc/powernv/npu-dma.c: Fix opal_npu_destroy_context() call selftests/powerpc: Fix TM resched DSCR test with some compilers
This commit is contained in:
commit
6f68a6ae1f
@ -46,6 +46,8 @@
|
|||||||
#define PPC_FEATURE2_HTM_NOSC 0x01000000
|
#define PPC_FEATURE2_HTM_NOSC 0x01000000
|
||||||
#define PPC_FEATURE2_ARCH_3_00 0x00800000 /* ISA 3.00 */
|
#define PPC_FEATURE2_ARCH_3_00 0x00800000 /* ISA 3.00 */
|
||||||
#define PPC_FEATURE2_HAS_IEEE128 0x00400000 /* VSX IEEE Binary Float 128-bit */
|
#define PPC_FEATURE2_HAS_IEEE128 0x00400000 /* VSX IEEE Binary Float 128-bit */
|
||||||
|
#define PPC_FEATURE2_DARN 0x00200000 /* darn random number insn */
|
||||||
|
#define PPC_FEATURE2_SCV 0x00100000 /* scv syscall */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* IMPORTANT!
|
* IMPORTANT!
|
||||||
|
@ -124,7 +124,8 @@ extern void __restore_cpu_e6500(void);
|
|||||||
#define COMMON_USER_POWER9 COMMON_USER_POWER8
|
#define COMMON_USER_POWER9 COMMON_USER_POWER8
|
||||||
#define COMMON_USER2_POWER9 (COMMON_USER2_POWER8 | \
|
#define COMMON_USER2_POWER9 (COMMON_USER2_POWER8 | \
|
||||||
PPC_FEATURE2_ARCH_3_00 | \
|
PPC_FEATURE2_ARCH_3_00 | \
|
||||||
PPC_FEATURE2_HAS_IEEE128)
|
PPC_FEATURE2_HAS_IEEE128 | \
|
||||||
|
PPC_FEATURE2_DARN )
|
||||||
|
|
||||||
#ifdef CONFIG_PPC_BOOK3E_64
|
#ifdef CONFIG_PPC_BOOK3E_64
|
||||||
#define COMMON_USER_BOOKE (COMMON_USER_PPC64 | PPC_FEATURE_BOOKE)
|
#define COMMON_USER_BOOKE (COMMON_USER_PPC64 | PPC_FEATURE_BOOKE)
|
||||||
|
@ -161,7 +161,9 @@ static struct ibm_pa_feature {
|
|||||||
{ .pabyte = 0, .pabit = 3, .cpu_features = CPU_FTR_CTRL },
|
{ .pabyte = 0, .pabit = 3, .cpu_features = CPU_FTR_CTRL },
|
||||||
{ .pabyte = 0, .pabit = 6, .cpu_features = CPU_FTR_NOEXECUTE },
|
{ .pabyte = 0, .pabit = 6, .cpu_features = CPU_FTR_NOEXECUTE },
|
||||||
{ .pabyte = 1, .pabit = 2, .mmu_features = MMU_FTR_CI_LARGE_PAGE },
|
{ .pabyte = 1, .pabit = 2, .mmu_features = MMU_FTR_CI_LARGE_PAGE },
|
||||||
|
#ifdef CONFIG_PPC_RADIX_MMU
|
||||||
{ .pabyte = 40, .pabit = 0, .mmu_features = MMU_FTR_TYPE_RADIX },
|
{ .pabyte = 40, .pabit = 0, .mmu_features = MMU_FTR_TYPE_RADIX },
|
||||||
|
#endif
|
||||||
{ .pabyte = 1, .pabit = 1, .invert = 1, .cpu_features = CPU_FTR_NODSISRALIGN },
|
{ .pabyte = 1, .pabit = 1, .invert = 1, .cpu_features = CPU_FTR_NODSISRALIGN },
|
||||||
{ .pabyte = 5, .pabit = 0, .cpu_features = CPU_FTR_REAL_LE,
|
{ .pabyte = 5, .pabit = 0, .cpu_features = CPU_FTR_REAL_LE,
|
||||||
.cpu_user_ftrs = PPC_FEATURE_TRUE_LE },
|
.cpu_user_ftrs = PPC_FEATURE_TRUE_LE },
|
||||||
|
@ -197,7 +197,9 @@ static int __spu_trap_data_map(struct spu *spu, unsigned long ea, u64 dsisr)
|
|||||||
(REGION_ID(ea) != USER_REGION_ID)) {
|
(REGION_ID(ea) != USER_REGION_ID)) {
|
||||||
|
|
||||||
spin_unlock(&spu->register_lock);
|
spin_unlock(&spu->register_lock);
|
||||||
ret = hash_page(ea, _PAGE_PRESENT | _PAGE_READ, 0x300, dsisr);
|
ret = hash_page(ea,
|
||||||
|
_PAGE_PRESENT | _PAGE_READ | _PAGE_PRIVILEGED,
|
||||||
|
0x300, dsisr);
|
||||||
spin_lock(&spu->register_lock);
|
spin_lock(&spu->register_lock);
|
||||||
|
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
|
@ -714,7 +714,7 @@ static void pnv_npu2_release_context(struct kref *kref)
|
|||||||
void pnv_npu2_destroy_context(struct npu_context *npu_context,
|
void pnv_npu2_destroy_context(struct npu_context *npu_context,
|
||||||
struct pci_dev *gpdev)
|
struct pci_dev *gpdev)
|
||||||
{
|
{
|
||||||
struct pnv_phb *nphb, *phb;
|
struct pnv_phb *nphb;
|
||||||
struct npu *npu;
|
struct npu *npu;
|
||||||
struct pci_dev *npdev = pnv_pci_get_npu_dev(gpdev, 0);
|
struct pci_dev *npdev = pnv_pci_get_npu_dev(gpdev, 0);
|
||||||
struct device_node *nvlink_dn;
|
struct device_node *nvlink_dn;
|
||||||
@ -728,13 +728,12 @@ void pnv_npu2_destroy_context(struct npu_context *npu_context,
|
|||||||
|
|
||||||
nphb = pci_bus_to_host(npdev->bus)->private_data;
|
nphb = pci_bus_to_host(npdev->bus)->private_data;
|
||||||
npu = &nphb->npu;
|
npu = &nphb->npu;
|
||||||
phb = pci_bus_to_host(gpdev->bus)->private_data;
|
|
||||||
nvlink_dn = of_parse_phandle(npdev->dev.of_node, "ibm,nvlink", 0);
|
nvlink_dn = of_parse_phandle(npdev->dev.of_node, "ibm,nvlink", 0);
|
||||||
if (WARN_ON(of_property_read_u32(nvlink_dn, "ibm,npu-link-index",
|
if (WARN_ON(of_property_read_u32(nvlink_dn, "ibm,npu-link-index",
|
||||||
&nvlink_index)))
|
&nvlink_index)))
|
||||||
return;
|
return;
|
||||||
npu_context->npdev[npu->index][nvlink_index] = NULL;
|
npu_context->npdev[npu->index][nvlink_index] = NULL;
|
||||||
opal_npu_destroy_context(phb->opal_id, npu_context->mm->context.id,
|
opal_npu_destroy_context(nphb->opal_id, npu_context->mm->context.id,
|
||||||
PCI_DEVID(gpdev->bus->number, gpdev->devfn));
|
PCI_DEVID(gpdev->bus->number, gpdev->devfn));
|
||||||
kref_put(&npu_context->kref, pnv_npu2_release_context);
|
kref_put(&npu_context->kref, pnv_npu2_release_context);
|
||||||
}
|
}
|
||||||
|
@ -42,12 +42,12 @@ int test_body(void)
|
|||||||
printf("Check DSCR TM context switch: ");
|
printf("Check DSCR TM context switch: ");
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
for (;;) {
|
for (;;) {
|
||||||
rv = 1;
|
|
||||||
asm __volatile__ (
|
asm __volatile__ (
|
||||||
/* set a known value into the DSCR */
|
/* set a known value into the DSCR */
|
||||||
"ld 3, %[dscr1];"
|
"ld 3, %[dscr1];"
|
||||||
"mtspr %[sprn_dscr], 3;"
|
"mtspr %[sprn_dscr], 3;"
|
||||||
|
|
||||||
|
"li %[rv], 1;"
|
||||||
/* start and suspend a transaction */
|
/* start and suspend a transaction */
|
||||||
"tbegin.;"
|
"tbegin.;"
|
||||||
"beq 1f;"
|
"beq 1f;"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user