180544aebSJohn Birrell /*-
2*4d846d26SWarner Losh * SPDX-License-Identifier: BSD-2-Clause
38a36da99SPedro F. Giffuni *
480544aebSJohn Birrell * Copyright (c) 2007-2008 John Birrell <jb@FreeBSD.org>
580544aebSJohn Birrell * All rights reserved.
680544aebSJohn Birrell *
780544aebSJohn Birrell * Redistribution and use in source and binary forms, with or without
880544aebSJohn Birrell * modification, are permitted provided that the following conditions
980544aebSJohn Birrell * are met:
1080544aebSJohn Birrell * 1. Redistributions of source code must retain the above copyright
1180544aebSJohn Birrell * notice, this list of conditions and the following disclaimer.
1280544aebSJohn Birrell * 2. Redistributions in binary form must reproduce the above copyright
1380544aebSJohn Birrell * notice, this list of conditions and the following disclaimer in the
1480544aebSJohn Birrell * documentation and/or other materials provided with the distribution.
1580544aebSJohn Birrell *
1680544aebSJohn Birrell * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
1780544aebSJohn Birrell * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1880544aebSJohn Birrell * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1980544aebSJohn Birrell * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
2080544aebSJohn Birrell * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2180544aebSJohn Birrell * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2280544aebSJohn Birrell * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2380544aebSJohn Birrell * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2480544aebSJohn Birrell * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2580544aebSJohn Birrell * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2680544aebSJohn Birrell * SUCH DAMAGE.
2780544aebSJohn Birrell */
2880544aebSJohn Birrell
2980544aebSJohn Birrell #include <sys/cdefs.h>
3080544aebSJohn Birrell #include "opt_kdb.h"
3180544aebSJohn Birrell
3280544aebSJohn Birrell #include <sys/param.h>
3380544aebSJohn Birrell #include <sys/systm.h>
3480544aebSJohn Birrell #include <sys/eventhandler.h>
3580544aebSJohn Birrell #include <sys/kdb.h>
3680544aebSJohn Birrell #include <sys/kernel.h>
3780544aebSJohn Birrell #include <sys/malloc.h>
3880544aebSJohn Birrell #include <sys/proc.h>
3980544aebSJohn Birrell #include <sys/dtrace_bsd.h>
40de5b1952SAlexander Leidinger #include <sys/sysctl.h>
41f2789bd5SMark Johnston #include <sys/sysent.h>
4280544aebSJohn Birrell
4380544aebSJohn Birrell #define KDTRACE_PROC_SIZE 64
4480544aebSJohn Birrell #define KDTRACE_THREAD_SIZE 256
4580544aebSJohn Birrell
46de5b1952SAlexander Leidinger FEATURE(kdtrace_hooks,
47de5b1952SAlexander Leidinger "Kernel DTrace hooks which are required to load DTrace kernel modules");
48de5b1952SAlexander Leidinger
49d745c852SEd Schouten static MALLOC_DEFINE(M_KDTRACE, "kdtrace", "DTrace hooks");
5080544aebSJohn Birrell
51f2789bd5SMark Johnston /* Hooks used in the machine-dependent trap handlers. */
52f2789bd5SMark Johnston dtrace_trap_func_t dtrace_trap_func;
53f2789bd5SMark Johnston dtrace_doubletrap_func_t dtrace_doubletrap_func;
54f2789bd5SMark Johnston dtrace_pid_probe_ptr_t dtrace_pid_probe_ptr;
55f2789bd5SMark Johnston dtrace_return_probe_ptr_t dtrace_return_probe_ptr;
56f2789bd5SMark Johnston
579d68f774SMateusz Guzik bool __read_frequently systrace_enabled;
589d68f774SMateusz Guzik systrace_probe_func_t systrace_probe_func;
59f2789bd5SMark Johnston
6080544aebSJohn Birrell /* Return the DTrace process data size compiled in the kernel hooks. */
6180544aebSJohn Birrell size_t
kdtrace_proc_size(void)62db8ea61aSDimitry Andric kdtrace_proc_size(void)
6380544aebSJohn Birrell {
649f3a1843SRui Paulo
6580544aebSJohn Birrell return (KDTRACE_PROC_SIZE);
6680544aebSJohn Birrell }
6780544aebSJohn Birrell
68598f2b81SMateusz Guzik void
kdtrace_proc_ctor(struct proc * p)69598f2b81SMateusz Guzik kdtrace_proc_ctor(struct proc *p)
7080544aebSJohn Birrell {
7180544aebSJohn Birrell
72258f5a25SRui Paulo p->p_dtrace = malloc(KDTRACE_PROC_SIZE, M_KDTRACE, M_WAITOK|M_ZERO);
7380544aebSJohn Birrell }
7480544aebSJohn Birrell
75598f2b81SMateusz Guzik void
kdtrace_proc_dtor(struct proc * p)76598f2b81SMateusz Guzik kdtrace_proc_dtor(struct proc *p)
7780544aebSJohn Birrell {
789f3a1843SRui Paulo
7980544aebSJohn Birrell free(p->p_dtrace, M_KDTRACE);
8080544aebSJohn Birrell p->p_dtrace = NULL;
8180544aebSJohn Birrell }
8280544aebSJohn Birrell
8380544aebSJohn Birrell /* Return the DTrace thread data size compiled in the kernel hooks. */
8480544aebSJohn Birrell size_t
kdtrace_thread_size(void)85db8ea61aSDimitry Andric kdtrace_thread_size(void)
8680544aebSJohn Birrell {
87258f5a25SRui Paulo
8880544aebSJohn Birrell return (KDTRACE_THREAD_SIZE);
8980544aebSJohn Birrell }
9080544aebSJohn Birrell
91598f2b81SMateusz Guzik void
kdtrace_thread_ctor(struct thread * td)92598f2b81SMateusz Guzik kdtrace_thread_ctor(struct thread *td)
9380544aebSJohn Birrell {
9480544aebSJohn Birrell
95258f5a25SRui Paulo td->td_dtrace = malloc(KDTRACE_THREAD_SIZE, M_KDTRACE, M_WAITOK|M_ZERO);
9680544aebSJohn Birrell }
9780544aebSJohn Birrell
98598f2b81SMateusz Guzik void
kdtrace_thread_dtor(struct thread * td)99598f2b81SMateusz Guzik kdtrace_thread_dtor(struct thread *td)
10080544aebSJohn Birrell {
1019f3a1843SRui Paulo
10280544aebSJohn Birrell free(td->td_dtrace, M_KDTRACE);
10380544aebSJohn Birrell td->td_dtrace = NULL;
10480544aebSJohn Birrell }
105