From ec38d0ce9837f9b82f16e45aa7eca6f02ee8e13c Mon Sep 17 00:00:00 2001 From: Jiuzhu Dong Date: Thu, 20 May 2021 20:06:38 +0800 Subject: [PATCH] syslog/ramlog: save ramlog to fixed section we can reload ramlog after hot reboot. Change-Id: Iee7c105a2358075302121d6bf0047bc54d07e9a6 Signed-off-by: Jiuzhu Dong --- drivers/syslog/Kconfig | 8 ++++++++ drivers/syslog/ramlog.c | 3 ++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/drivers/syslog/Kconfig b/drivers/syslog/Kconfig index 263e05671b..b7c0ac1342 100644 --- a/drivers/syslog/Kconfig +++ b/drivers/syslog/Kconfig @@ -34,6 +34,14 @@ config RAMLOG details as needed to support logging. if RAMLOG +config RAMLOG_BUFFER_SECTION + string "The section where ramlog buffer is located" + default ".bss" + depends on RAMLOG_SYSLOG + ---help--- + The section where ramlog buffer is located, this section cannot + be initialized each time when the system boot. + config RAMLOG_BUFSIZE int "RAMLOG buffer size" default 1024 diff --git a/drivers/syslog/ramlog.c b/drivers/syslog/ramlog.c index a35b3bb28d..7c20eb8ec7 100644 --- a/drivers/syslog/ramlog.c +++ b/drivers/syslog/ramlog.c @@ -120,7 +120,8 @@ static const struct file_operations g_ramlogfops = */ #ifdef CONFIG_RAMLOG_SYSLOG -static char g_sysbuffer[CONFIG_RAMLOG_BUFSIZE]; +static char g_sysbuffer[CONFIG_RAMLOG_BUFSIZE] + locate_data(CONFIG_RAMLOG_BUFFER_SECTION); /* This is the device structure for the console or syslogging function. It * must be statically initialized because the RAMLOG ramlog_putc function