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