diff options
Diffstat (limited to 'arch/mips/Kconfig')
| -rw-r--r-- | arch/mips/Kconfig | 26 |
1 files changed, 4 insertions, 22 deletions
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index 49896a2a1d72..c930b8ceb418 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
| @@ -1403,7 +1403,6 @@ config MIPS_MT_SMTC | |||
| 1403 | depends on CPU_MIPS32_R2 | 1403 | depends on CPU_MIPS32_R2 |
| 1404 | #depends on CPU_MIPS64_R2 # once there is hardware ... | 1404 | #depends on CPU_MIPS64_R2 # once there is hardware ... |
| 1405 | depends on SYS_SUPPORTS_MULTITHREADING | 1405 | depends on SYS_SUPPORTS_MULTITHREADING |
| 1406 | select GENERIC_CLOCKEVENTS_BROADCAST | ||
| 1407 | select CPU_MIPSR2_IRQ_VI | 1406 | select CPU_MIPSR2_IRQ_VI |
| 1408 | select CPU_MIPSR2_IRQ_EI | 1407 | select CPU_MIPSR2_IRQ_EI |
| 1409 | select MIPS_MT | 1408 | select MIPS_MT |
| @@ -1451,32 +1450,17 @@ config MIPS_VPE_LOADER | |||
| 1451 | Includes a loader for loading an elf relocatable object | 1450 | Includes a loader for loading an elf relocatable object |
| 1452 | onto another VPE and running it. | 1451 | onto another VPE and running it. |
| 1453 | 1452 | ||
| 1454 | config MIPS_MT_SMTC_INSTANT_REPLAY | ||
| 1455 | bool "Low-latency Dispatch of Deferred SMTC IPIs" | ||
| 1456 | depends on MIPS_MT_SMTC && !PREEMPT | ||
| 1457 | default y | ||
| 1458 | help | ||
| 1459 | SMTC pseudo-interrupts between TCs are deferred and queued | ||
| 1460 | if the target TC is interrupt-inhibited (IXMT). In the first | ||
| 1461 | SMTC prototypes, these queued IPIs were serviced on return | ||
| 1462 | to user mode, or on entry into the kernel idle loop. The | ||
| 1463 | INSTANT_REPLAY option dispatches them as part of local_irq_restore() | ||
| 1464 | processing, which adds runtime overhead (hence the option to turn | ||
| 1465 | it off), but ensures that IPIs are handled promptly even under | ||
| 1466 | heavy I/O interrupt load. | ||
| 1467 | |||
| 1468 | config MIPS_MT_SMTC_IM_BACKSTOP | 1453 | config MIPS_MT_SMTC_IM_BACKSTOP |
| 1469 | bool "Use per-TC register bits as backstop for inhibited IM bits" | 1454 | bool "Use per-TC register bits as backstop for inhibited IM bits" |
| 1470 | depends on MIPS_MT_SMTC | 1455 | depends on MIPS_MT_SMTC |
| 1471 | default y | 1456 | default n |
| 1472 | help | 1457 | help |
| 1473 | To support multiple TC microthreads acting as "CPUs" within | 1458 | To support multiple TC microthreads acting as "CPUs" within |
| 1474 | a VPE, VPE-wide interrupt mask bits must be specially manipulated | 1459 | a VPE, VPE-wide interrupt mask bits must be specially manipulated |
| 1475 | during interrupt handling. To support legacy drivers and interrupt | 1460 | during interrupt handling. To support legacy drivers and interrupt |
| 1476 | controller management code, SMTC has a "backstop" to track and | 1461 | controller management code, SMTC has a "backstop" to track and |
| 1477 | if necessary restore the interrupt mask. This has some performance | 1462 | if necessary restore the interrupt mask. This has some performance |
| 1478 | impact on interrupt service overhead. Disable it only if you know | 1463 | impact on interrupt service overhead. |
| 1479 | what you are doing. | ||
| 1480 | 1464 | ||
| 1481 | config MIPS_MT_SMTC_IRQAFF | 1465 | config MIPS_MT_SMTC_IRQAFF |
| 1482 | bool "Support IRQ affinity API" | 1466 | bool "Support IRQ affinity API" |
| @@ -1486,10 +1470,8 @@ config MIPS_MT_SMTC_IRQAFF | |||
| 1486 | Enables SMP IRQ affinity API (/proc/irq/*/smp_affinity, etc.) | 1470 | Enables SMP IRQ affinity API (/proc/irq/*/smp_affinity, etc.) |
| 1487 | for SMTC Linux kernel. Requires platform support, of which | 1471 | for SMTC Linux kernel. Requires platform support, of which |
| 1488 | an example can be found in the MIPS kernel i8259 and Malta | 1472 | an example can be found in the MIPS kernel i8259 and Malta |
| 1489 | platform code. It is recommended that MIPS_MT_SMTC_INSTANT_REPLAY | 1473 | platform code. Adds some overhead to interrupt dispatch, and |
| 1490 | be enabled if MIPS_MT_SMTC_IRQAFF is used. Adds overhead to | 1474 | should be used only if you know what you are doing. |
| 1491 | interrupt dispatch, and should be used only if you know what | ||
| 1492 | you are doing. | ||
| 1493 | 1475 | ||
| 1494 | config MIPS_VPE_LOADER_TOM | 1476 | config MIPS_VPE_LOADER_TOM |
| 1495 | bool "Load VPE program into memory hidden from linux" | 1477 | bool "Load VPE program into memory hidden from linux" |
