Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a9dc54a3 authored by Mohammed Khajapasha's avatar Mohammed Khajapasha Committed by Prasad Sodagudi
Browse files

printk: Make the console flush configurable in hotplug path



The thread which initiates the hot plug can get scheduled
out, while trying to acquire the console lock,
thus increasing the hot plug latency. This option
allows to selectively disable the console flush and
in turn reduce the hot plug latency.

Change-Id: I42507804d321b29b7761146a6c175d959bf79925
Signed-off-by: default avatarMohammed Khajapasha <mkhaja@codeaurora.org>
Signed-off-by: default avatarPrasad Sodagudi <psodagud@codeaurora.org>
parent 0dc787c3
Loading
Loading
Loading
Loading
+10 −0
Original line number Diff line number Diff line
@@ -833,6 +833,16 @@ config LOG_BUF_SHIFT
		     13 =>  8 KB
		     12 =>  4 KB

config CONSOLE_FLUSH_ON_HOTPLUG
	bool "Enable console flush configurable in hot plug code path"
	depends on HOTPLUG_CPU
	def_bool n
	help
	In cpu hot plug path console lock acquire and release causes the
	console to flush. If console lock is not free hot plug latency
	increases. So make console flush configurable in hot plug path
	and default disabled to help in cpu hot plug latencies.

config LOG_CPU_MAX_BUF_SHIFT
	int "CPU kernel log buffer size contribution (13 => 8 KB, 17 => 128KB)"
	depends on SMP
+6 −0
Original line number Diff line number Diff line
@@ -2081,11 +2081,17 @@ static int console_cpu_notify(struct notifier_block *self,
{
	switch (action) {
	case CPU_ONLINE:
		console_lock();
		console_unlock();
		break;
	case CPU_DEAD:
	case CPU_DOWN_FAILED:
	case CPU_UP_CANCELED:
#ifdef CONFIG_CONSOLE_FLUSH_ON_HOTPLUG
		console_lock();
		console_unlock();
#endif
		break;
	}
	return NOTIFY_OK;
}