18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Copyright (C) 2022 Changbin Du <changbin.du@gmail.com> 48c2ecf20Sopenharmony_ci */ 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_ci#include <linux/irqflags.h> 78c2ecf20Sopenharmony_ci#include <linux/kprobes.h> 88c2ecf20Sopenharmony_ci#include "trace_irq.h" 98c2ecf20Sopenharmony_ci 108c2ecf20Sopenharmony_ci/* 118c2ecf20Sopenharmony_ci * trace_hardirqs_on/off require the caller to setup frame pointer properly. 128c2ecf20Sopenharmony_ci * Otherwise, CALLER_ADDR1 might trigger an pagging exception in kernel. 138c2ecf20Sopenharmony_ci * Here we add one extra level so they can be safely called by low 148c2ecf20Sopenharmony_ci * level entry code which $fp is used for other purpose. 158c2ecf20Sopenharmony_ci */ 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_civoid __trace_hardirqs_on(void) 188c2ecf20Sopenharmony_ci{ 198c2ecf20Sopenharmony_ci trace_hardirqs_on(); 208c2ecf20Sopenharmony_ci} 218c2ecf20Sopenharmony_ciNOKPROBE_SYMBOL(__trace_hardirqs_on); 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_civoid __trace_hardirqs_off(void) 248c2ecf20Sopenharmony_ci{ 258c2ecf20Sopenharmony_ci trace_hardirqs_off(); 268c2ecf20Sopenharmony_ci} 278c2ecf20Sopenharmony_ciNOKPROBE_SYMBOL(__trace_hardirqs_off); 28