On 2/10/2012 3:24 PM, Gilad Ben-Yossef wrote: > On Fri, Feb 10, 2012 at 8:38 PM, Peter Zijlstra <a.p.zijlstra@xxxxxxxxx> wrote: >> On Thu, 2012-02-02 at 10:41 -0500, Chris Metcalf wrote: >>> /* >>> * Quiesce the timer interrupt before returning to user space after a >>> * system call. Normally if a task on a dataplane core makes a >>> * syscall, the system will run one or more timer ticks after the >>> * syscall has completed, causing unexpected interrupts in userspace. >>> * Setting DP_QUIESCE avoids that problem by having the kernel "hold" >>> * the task in kernel mode until the timer ticks are complete. This >>> * will make syscalls dramatically slower. >>> * >>> * If multiple dataplane tasks are scheduled on a single core, this >>> * in effect silently disables DP_QUIESCE, which allows the tasks to make >>> * progress, but without actually disabling the timer tick. >>> */ >>> #define DP_QUIESCE 0x1 >> This is what Frederics work does > Actually it's not quite the same I believe. Frederic's patch set > disables the tick > for an adaptive tick task at some timer tick interrupt after the > system call, but > the task doesn't know when that happens, so if timing determinism guarantee is > what you are after you don't quite know in your user task if its safe > to start doing > real time stuff or know. > > If I understood Chris quote correctly, they hold the task in kernel > space until the > timer tick is off, so that when the user space task continues to run > after the system > call it can assume the tick is off. > > Of course, nothing stops something (IPI?) from re-enabling it later, > but I guess it at least > lets you start in a known state. > > I think the concept of giving the task some way to know if the tick is > disabled or not is nice. > Not sure the exact feature and surely not the interface are what we > should adopt - maybe > allow registering to receive a signal at the end of the tick when it > is disabled an re-enabled? The problem with that is that by receiving a signal, you are back where you started: returning from the kernel to userspace, and potentially leaving open the possibility that the kernel will still need a scheduler tick or two to quiesce. An alternative we considered was to pass in a memory location that the kernel would update with the current state of the process (tick disabled or not), and you could then spin reading that location until the kernel stopped interrupting you and disabled the tick. But it seemed silly when we could essentially put that code in the kernel once and get it right. And note that the "IPI to re-enable it" is an event that is probably a bug either in your application or in the kernel, which we track with the DP_DEBUG flag; you wouldn't expect that to happen once your application was up and running. -- Chris Metcalf, Tilera Corp. http://www.tilera.com -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>