--- zzzz-none-000/linux-4.4.60/kernel/printk/printk.c 2017-04-08 07:53:53.000000000 +0000 +++ hawkeye-5590-729/linux-4.4.60/kernel/printk/printk.c 2022-03-30 14:21:53.000000000 +0000 @@ -16,6 +16,11 @@ * 01Mar01 Andrew Morton */ +#ifdef CONFIG_AVM_FASTIRQ +#include +#define CLIENT_FIQ_PRIO FIQ_PRIO_WATCHDOG +#endif + #include #include #include @@ -46,6 +51,12 @@ #include #include #include +#ifdef CONFIG_AVM_DEBUG +#include +#if defined(CONFIG_SMP) && defined(CONFIG_MIPS) +#include +#endif /*--- #if defined(CONFIG_SMP) && defined(CONFIG_MIPS) ---*/ +#endif /*--- #ifdef CONFIG_AVM_DEBUG ---*/ #include @@ -55,6 +66,16 @@ #include "console_cmdline.h" #include "braille.h" +#if defined(CONFIG_AVM_FASTIRQ) + +#include +#define __NONLINUX_CONTEXT_NAME "FastIrq" +#define _BUILD_AVM_CONTEXT_FUNC(func) firq_##func +#else +#define _BUILD_AVM_CONTEXT_FUNC(func) func +#define is_avm_rte() 0 +#endif + int console_printk[4] = { CONSOLE_LOGLEVEL_DEFAULT, /* console_loglevel */ MESSAGE_LOGLEVEL_DEFAULT, /* default_message_loglevel */ @@ -101,22 +122,26 @@ * macros instead of functions so that _RET_IP_ contains useful information. */ #define down_console_sem() do { \ - down(&console_sem);\ + _BUILD_AVM_CONTEXT_FUNC(down)(&console_sem);\ mutex_acquire(&console_lock_dep_map, 0, 0, _RET_IP_);\ } while (0) static int __down_trylock_console_sem(unsigned long ip) { - if (down_trylock(&console_sem)) + if (_BUILD_AVM_CONTEXT_FUNC(down_trylock)(&console_sem)) return 1; - mutex_acquire(&console_lock_dep_map, 0, 1, ip); + if (!_BUILD_AVM_CONTEXT_FUNC(is_avm_rte)()) { + mutex_acquire(&console_lock_dep_map, 0, 1, ip); + } return 0; } #define down_trylock_console_sem() __down_trylock_console_sem(_RET_IP_) -#define up_console_sem() do { \ - mutex_release(&console_lock_dep_map, 1, _RET_IP_);\ - up(&console_sem);\ +#define up_console_sem() do { \ + if (!_BUILD_AVM_CONTEXT_FUNC(is_avm_rte)()) { \ + mutex_release(&console_lock_dep_map, 1, _RET_IP_); \ + } \ + _BUILD_AVM_CONTEXT_FUNC(up)(&console_sem); \ } while (0) /* @@ -232,6 +257,9 @@ u8 facility; /* syslog facility */ u8 flags:5; /* internal record flags */ u8 level:3; /* syslog level */ +#if defined(CONFIG_AVM_DEBUG) + u8 cpu; +#endif/*--- #if defined(CONFIG_AVM_DEBUG) ---*/ }; /* @@ -281,7 +309,8 @@ #define __LOG_BUF_LEN (1 << CONFIG_LOG_BUF_SHIFT) static char __log_buf[__LOG_BUF_LEN] __aligned(LOG_ALIGN); static char *log_buf = __log_buf; -static u32 log_buf_len = __LOG_BUF_LEN; +u32 log_buf_len = __LOG_BUF_LEN; +EXPORT_SYMBOL(log_buf_len); /* Return log buffer address */ char *log_buf_addr_get(void) @@ -464,10 +493,17 @@ msg->facility = facility; msg->level = level & 7; msg->flags = flags & 0x1f; +#if defined(CONFIG_AVM_DEBUG) + if (!_BUILD_AVM_CONTEXT_FUNC(is_avm_rte)()) { + msg->cpu = raw_smp_processor_id(); + } else { + msg->cpu = raw_smp_processor_id() | 0x80; + } +#endif/*--- #if defined(CONFIG_AVM_DEBUG) ---*/ if (ts_nsec > 0) msg->ts_nsec = ts_nsec; else - msg->ts_nsec = local_clock(); + msg->ts_nsec = _BUILD_AVM_CONTEXT_FUNC(local_clock)(); memset(log_dict(msg) + dict_len, 0, pad_len); msg->len = size; @@ -669,6 +705,7 @@ struct printk_log *msg; size_t len; ssize_t ret; + unsigned long flags; if (!user) return -EBADF; @@ -676,20 +713,20 @@ ret = mutex_lock_interruptible(&user->lock); if (ret) return ret; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); while (user->seq == log_next_seq) { if (file->f_flags & O_NONBLOCK) { ret = -EAGAIN; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); goto out; } - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); ret = wait_event_interruptible(log_wait, user->seq != log_next_seq); if (ret) goto out; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); } if (user->seq < log_first_seq) { @@ -697,7 +734,7 @@ user->idx = log_first_idx; user->seq = log_first_seq; ret = -EPIPE; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); goto out; } @@ -711,7 +748,7 @@ user->prev = msg->flags; user->idx = log_next(user->idx); user->seq++; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); if (len > count) { ret = -EINVAL; @@ -732,13 +769,14 @@ { struct devkmsg_user *user = file->private_data; loff_t ret = 0; + unsigned long flags; if (!user) return -EBADF; if (offset) return -ESPIPE; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); switch (whence) { case SEEK_SET: /* the first record */ @@ -762,7 +800,7 @@ default: ret = -EINVAL; } - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); return ret; } @@ -770,13 +808,14 @@ { struct devkmsg_user *user = file->private_data; int ret = 0; + unsigned long flags; if (!user) return POLLERR|POLLNVAL; poll_wait(file, &log_wait, wait); - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (user->seq < log_next_seq) { /* return error when data has vanished underneath us */ if (user->seq < log_first_seq) @@ -784,7 +823,7 @@ else ret = POLLIN|POLLRDNORM; } - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); return ret; } @@ -793,6 +832,7 @@ { struct devkmsg_user *user; int err; + unsigned long flags; /* write-only does not need any file context */ if ((file->f_flags & O_ACCMODE) == O_WRONLY) @@ -809,10 +849,10 @@ mutex_init(&user->lock); - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); user->idx = log_first_idx; user->seq = log_first_seq; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); file->private_data = user; return 0; @@ -951,13 +991,13 @@ return; } - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); log_buf_len = new_log_buf_len; log_buf = new_log_buf; new_log_buf_len = 0; free = __LOG_BUF_LEN - log_next_idx; memcpy(log_buf, __log_buf, __LOG_BUF_LEN); - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); pr_info("log_buf_len: %d bytes\n", log_buf_len); pr_info("early log buf free: %d(%d%%)\n", @@ -1073,6 +1113,12 @@ } len += print_time(msg->ts_nsec, buf ? buf + len : NULL); +#if defined(CONFIG_AVM_DEBUG) && defined(CONFIG_SMP) + if(buf) { + if(len && buf[len-1] == ' ') len--; + len += sprintf(&buf[len], "[%s%x] ", msg->cpu & 0x80 ? "F" : "", msg->cpu & ~0x80); + } +#endif /*--- #if defined(CONFIG_AVM_DEBUG) && defined(CONFIG_SMP) ---*/ return len; } @@ -1140,6 +1186,7 @@ char *text; struct printk_log *msg; int len = 0; + unsigned long flags; text = kmalloc(LOG_LINE_MAX + PREFIX_MAX, GFP_KERNEL); if (!text) @@ -1149,7 +1196,7 @@ size_t n; size_t skip; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (syslog_seq < log_first_seq) { /* messages are gone, move to first one */ syslog_seq = log_first_seq; @@ -1158,7 +1205,7 @@ syslog_partial = 0; } if (syslog_seq == log_next_seq) { - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); break; } @@ -1179,7 +1226,7 @@ syslog_partial += n; } else n = 0; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); if (!n) break; @@ -1203,12 +1250,13 @@ { char *text; int len = 0; + unsigned long flags; text = kmalloc(LOG_LINE_MAX + PREFIX_MAX, GFP_KERNEL); if (!text) return -ENOMEM; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (buf) { u64 next_seq; u64 seq; @@ -1268,12 +1316,12 @@ seq++; prev = msg->flags; - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); if (copy_to_user(buf + len, text, textlen)) len = -EFAULT; else len += textlen; - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (seq < log_first_seq) { /* messages are gone, move to next one */ @@ -1288,7 +1336,7 @@ clear_seq = log_next_seq; clear_idx = log_next_idx; } - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); kfree(text); return len; @@ -1299,6 +1347,7 @@ bool clear = false; static int saved_console_loglevel = LOGLEVEL_DEFAULT; int error; + unsigned long flags; error = check_syslog_permissions(type, source); if (error) @@ -1375,7 +1424,7 @@ break; /* Number of chars in the log buffer */ case SYSLOG_ACTION_SIZE_UNREAD: - raw_spin_lock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (syslog_seq < log_first_seq) { /* messages are gone, move to first one */ syslog_seq = log_first_seq; @@ -1406,7 +1455,7 @@ } error -= syslog_partial; } - raw_spin_unlock_irq(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); break; /* Size of the log buffer */ case SYSLOG_ACTION_SIZE_BUFFER: @@ -1429,6 +1478,7 @@ * Call the console drivers, asking them to write out * log_buf[start] to log_buf[end - 1]. * The console_lock must be held. + * FASTIRQ-Kontext-fest */ static void call_console_drivers(int level, const char *ext_text, size_t ext_len, @@ -1448,9 +1498,11 @@ continue; if (!(con->flags & CON_ENABLED)) continue; + if (con->flags & CON_MUTED) + continue; if (!con->write) continue; - if (!cpu_online(smp_processor_id()) && + if (!cpu_online(raw_smp_processor_id()) && !(con->flags & CON_ANYTIME)) continue; if (con->flags & CON_EXTENDED) @@ -1477,7 +1529,7 @@ debug_locks_off(); /* If a crash is occurring, make sure we can't deadlock */ - raw_spin_lock_init(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_init)(&logbuf_lock); /* And make sure that we print immediately */ sema_init(&console_sem, 1); } @@ -1514,10 +1566,11 @@ * messages from a 'printk'. Return true (and with the * console_lock held, and 'console_locked' set) if it * is successful, false otherwise. + * FASTIRQ-Kontext fest */ static int console_trylock_for_printk(void) { - unsigned int cpu = smp_processor_id(); + unsigned int cpu = raw_smp_processor_id() & ~0x80; if (!console_trylock()) return 0; @@ -1613,7 +1666,7 @@ cont.facility = facility; cont.level = level; cont.owner = current; - cont.ts_nsec = local_clock(); + cont.ts_nsec = _BUILD_AVM_CONTEXT_FUNC(local_clock)(); cont.flags = 0; cont.cons = 0; cont.flushed = false; @@ -1665,25 +1718,29 @@ char *text = textbuf; size_t text_len = 0; enum log_flags lflags = 0; - unsigned long flags; + unsigned long flags = 0; int this_cpu; int printed_len = 0; bool in_sched = false; /* cpu currently holding logbuf_lock in this function */ static unsigned int logbuf_cpu = UINT_MAX; + this_cpu = raw_smp_processor_id(); + if (level == LOGLEVEL_SCHED) { level = LOGLEVEL_DEFAULT; in_sched = true; } - - boot_delay_msec(level); - printk_delay(); + if (!_BUILD_AVM_CONTEXT_FUNC(is_avm_rte)()) { + boot_delay_msec(level); + printk_delay(); + } else { + this_cpu |= 0x80; + in_sched = true; + } /* This stops the holder of console_sem just where we want him */ - local_irq_save(flags); - this_cpu = smp_processor_id(); - + _BUILD_AVM_CONTEXT_FUNC(local_irq_save)(flags); /* * Ouch, printk recursed into itself! */ @@ -1697,14 +1754,14 @@ */ if (!oops_in_progress && !lockdep_recursing(current)) { recursion_bug = 1; - local_irq_restore(flags); + _BUILD_AVM_CONTEXT_FUNC(local_irq_restore)(flags); return 0; } zap_locks(); } lockdep_off(); - raw_spin_lock(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock)(&logbuf_lock); logbuf_cpu = this_cpu; if (unlikely(recursion_bug)) { @@ -1801,9 +1858,9 @@ } logbuf_cpu = UINT_MAX; - raw_spin_unlock(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock)(&logbuf_lock); lockdep_on(); - local_irq_restore(flags); + _BUILD_AVM_CONTEXT_FUNC(local_irq_restore)(flags); /* If called from the scheduler, we can not call up(). */ if (!in_sched) { @@ -1919,10 +1976,18 @@ } EXPORT_SYMBOL(printk); +#ifdef CONFIG_QCA_MINIDUMP +void minidump_get_log_buf_info(uint64_t *plog_buf, uint64_t *plog_buf_len) +{ + *plog_buf = (uint64_t)(uintptr_t)log_buf; + *plog_buf_len = (uint64_t)__pa(&log_buf_len); +} +#endif + #else /* CONFIG_PRINTK */ -#define LOG_LINE_MAX 0 -#define PREFIX_MAX 0 +#define LOG_LINE_MAX 0 +#define PREFIX_MAX 0 static u64 syslog_seq; static u32 syslog_idx; @@ -2183,12 +2248,15 @@ return console_locked; } +/*--------------------------------------------------------------------------------*\ + * FASTIRQ-Kontext fest +\*--------------------------------------------------------------------------------*/ static void console_cont_flush(char *text, size_t size) { unsigned long flags; size_t len; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (!cont.len) goto out; @@ -2202,14 +2270,15 @@ goto out; len = cont_print_text(text, size); - raw_spin_unlock(&logbuf_lock); - stop_critical_timings(); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock)(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(stop_critical_timings)(); call_console_drivers(cont.level, NULL, 0, text, len); - start_critical_timings(); - local_irq_restore(flags); + + _BUILD_AVM_CONTEXT_FUNC(start_critical_timings)(); + _BUILD_AVM_CONTEXT_FUNC(local_irq_restore)(flags); return; out: - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); } /** @@ -2225,6 +2294,7 @@ * If there is output waiting, we wake /dev/kmsg and syslog() users. * * console_unlock(); may be called from any context. + * FASTIRQ-Kontext fest */ void console_unlock(void) { @@ -2262,7 +2332,7 @@ size_t len; int level; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (seen_seq != log_next_seq) { wake_klogd = true; seen_seq = log_next_seq; @@ -2316,12 +2386,12 @@ console_idx = log_next(console_idx); console_seq++; console_prev = msg->flags; - raw_spin_unlock(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock)(&logbuf_lock); - stop_critical_timings(); /* don't trace print latency */ + _BUILD_AVM_CONTEXT_FUNC(stop_critical_timings)(); /* don't trace print latency */ call_console_drivers(level, ext_text, ext_len, text, len); - start_critical_timings(); - local_irq_restore(flags); + _BUILD_AVM_CONTEXT_FUNC(start_critical_timings)(); + _BUILD_AVM_CONTEXT_FUNC(local_irq_restore)(flags); if (do_cond_resched) cond_resched(); @@ -2332,7 +2402,7 @@ if (unlikely(exclusive_console)) exclusive_console = NULL; - raw_spin_unlock(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock)(&logbuf_lock); up_console_sem(); @@ -2342,14 +2412,14 @@ * there's a new owner and the console_unlock() from them will do the * flush, no worries. */ - raw_spin_lock(&logbuf_lock); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock)(&logbuf_lock); retry = console_seq != log_next_seq; - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); if (retry && console_trylock()) goto again; - if (wake_klogd) + if (wake_klogd && !_BUILD_AVM_CONTEXT_FUNC(is_avm_rte)()) wake_up_klogd(); } EXPORT_SYMBOL(console_unlock); @@ -2452,6 +2522,35 @@ } EXPORT_SYMBOL(console_start); + +void console_mute(struct console *console) +{ + console_lock(); + console_mute_nolock(console); + console_unlock(); +} +EXPORT_SYMBOL(console_mute); + +void console_mute_nolock(struct console *console) +{ + console->flags |= CON_MUTED; +} +EXPORT_SYMBOL(console_mute_nolock); + +void console_unmute(struct console *console) +{ + console_lock(); + console_unmute_nolock(console); + console_unlock(); +} +EXPORT_SYMBOL(console_unmute); + +void console_unmute_nolock(struct console *console) +{ + console->flags &= ~CON_MUTED; +} +EXPORT_SYMBOL(console_unmute_nolock); + static int __read_mostly keep_bootcon; static int __init keep_bootcon_setup(char *str) @@ -2607,11 +2706,11 @@ * console_unlock(); will print out the buffered messages * for us. */ - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); console_seq = syslog_seq; console_idx = syslog_idx; console_prev = syslog_prev; - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); /* * We're about to replay the log buffer. Only do this to the * just-registered console to avoid excessive message spam to @@ -2647,7 +2746,7 @@ int unregister_console(struct console *console) { - struct console *a, *b; + struct console *a, *b; int res; pr_info("%sconsole [%s%d] disabled\n", @@ -2816,14 +2915,14 @@ if (!dumper->dump) return -EINVAL; - spin_lock_irqsave(&dump_list_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(spin_lock_irqsave)(&dump_list_lock, flags); /* Don't allow registering multiple times */ if (!dumper->registered) { dumper->registered = 1; list_add_tail_rcu(&dumper->list, &dump_list); err = 0; } - spin_unlock_irqrestore(&dump_list_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(spin_unlock_irqrestore)(&dump_list_lock, flags); return err; } @@ -2841,13 +2940,13 @@ unsigned long flags; int err = -EINVAL; - spin_lock_irqsave(&dump_list_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(spin_lock_irqsave)(&dump_list_lock, flags); if (dumper->registered) { dumper->registered = 0; list_del_rcu(&dumper->list); err = 0; } - spin_unlock_irqrestore(&dump_list_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(spin_unlock_irqrestore)(&dump_list_lock, flags); synchronize_rcu(); return err; @@ -2881,12 +2980,12 @@ /* initialize iterator with data about the stored records */ dumper->active = true; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); dumper->cur_seq = clear_seq; dumper->cur_idx = clear_idx; dumper->next_seq = log_next_seq; dumper->next_idx = log_next_idx; - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); /* invoke dumper which will iterate over records */ dumper->dump(dumper, reason); @@ -2971,9 +3070,9 @@ unsigned long flags; bool ret; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); ret = kmsg_dump_get_line_nolock(dumper, syslog, line, size, len); - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); return ret; } @@ -3013,7 +3112,7 @@ if (!dumper->active) goto out; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); if (dumper->cur_seq < log_first_seq) { /* messages are gone, move to first available one */ dumper->cur_seq = log_first_seq; @@ -3022,7 +3121,7 @@ /* last entry */ if (dumper->cur_seq >= dumper->next_seq) { - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); goto out; } @@ -3069,7 +3168,7 @@ dumper->next_seq = next_seq; dumper->next_idx = next_idx; ret = true; - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); out: if (len) *len = l; @@ -3107,9 +3206,9 @@ { unsigned long flags; - raw_spin_lock_irqsave(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_lock_irqsave)(&logbuf_lock, flags); kmsg_dump_rewind_nolock(dumper); - raw_spin_unlock_irqrestore(&logbuf_lock, flags); + _BUILD_AVM_CONTEXT_FUNC(raw_spin_unlock_irqrestore)(&logbuf_lock, flags); } EXPORT_SYMBOL_GPL(kmsg_dump_rewind);