Skip to content
Snippets Groups Projects
Forked from drm / kernel
Source project has a limited visibility.
  • Alice Ryhl's avatar
    ad37bcd9
    rust: add tracepoint support · ad37bcd9
    Alice Ryhl authored
    Make it possible to have Rust code call into tracepoints defined by C
    code. It is still required that the tracepoint is declared in a C
    header, and that this header is included in the input to bindgen.
    
    Instead of calling __DO_TRACE directly, the exported rust_do_trace_
    function calls an inline helper function. This is because the `cond`
    argument does not exist at the callsite of DEFINE_RUST_DO_TRACE.
    
    __DECLARE_TRACE always emits an inline static and an extern declaration
    that is only used when CREATE_RUST_TRACE_POINTS is set. These should not
    end up in the final binary so it is not a problem that they sometimes
    are emitted without a user.
    
    Cc: Masami Hiramatsu <mhiramat@kernel.org>
    Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
    Cc: Peter Zijlstra <peterz@infradead.org>
    Cc: Josh Poimboeuf <jpoimboe@kernel.org>
    Cc: Jason Baron <jbaron@akamai.com>
    Cc: Ard Biesheuvel <ardb@kernel.org>
    Cc: Miguel Ojeda <ojeda@kernel.org>
    Cc: Alex Gaynor <alex.gaynor@gmail.com>
    Cc: Wedson Almeida Filho <wedsonaf@gmail.com>
    Cc: " =?utf-8?q?Bj=C3=B6rn_Roy_Baron?= " <bjorn3_gh@protonmail.com>
    Cc: Benno Lossin <benno.lossin@proton.me>
    Cc: Andreas Hindborg <a.hindborg@kernel.org>
    Cc: Arnd Bergmann <arnd@arndb.de>
    Cc: Thomas Gleixner <tglx@linutronix.de>
    Cc: Ingo Molnar <mingo@redhat.com>
    Cc: Borislav Petkov <bp@alien8.de>
    Cc: Dave Hansen <dave.hansen@linux.intel.com>
    Cc: "H. Peter Anvin" <hpa@zytor.com>
    Cc: Sean Christopherson <seanjc@google.com>
    Cc: Uros Bizjak <ubizjak@gmail.com>
    Cc: Catalin Marinas <catalin.marinas@arm.com>
    Cc: Will Deacon <will@kernel.org>
    Cc: Marc Zyngier <maz@kernel.org>
    Cc: Oliver Upton <oliver.upton@linux.dev>
    Cc: Mark Rutland <mark.rutland@arm.com>
    Cc: Ryan Roberts <ryan.roberts@arm.com>
    Cc: Fuad Tabba <tabba@google.com>
    Cc: Paul Walmsley <paul.walmsley@sifive.com>
    Cc: Palmer Dabbelt <palmer@dabbelt.com>
    Cc: Albert Ou <aou@eecs.berkeley.edu>
    Cc: Anup Patel <apatel@ventanamicro.com>
    Cc: Andrew Jones <ajones@ventanamicro.com>
    Cc: Alexandre Ghiti <alexghiti@rivosinc.com>
    Cc: Conor Dooley <conor.dooley@microchip.com>
    Cc: Samuel Holland <samuel.holland@sifive.com>
    Cc: Huacai Chen <chenhuacai@kernel.org>
    Cc: WANG Xuerui <kernel@xen0n.name>
    Cc: Bibo Mao <maobibo@loongson.cn>
    Cc: Tiezhu Yang <yangtiezhu@loongson.cn>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Cc: Tianrui Zhao <zhaotianrui@loongson.cn>
    Link: https://lore.kernel.org/20241030-tracepoint-v12-2-eec7f0f8ad22@google.com
    
    
    Reviewed-by: default avatarCarlos Llamas <cmllamas@google.com>
    Reviewed-by: default avatarGary Guo <gary@garyguo.net>
    Reviewed-by: default avatarBoqun Feng <boqun.feng@gmail.com>
    Signed-off-by: default avatarAlice Ryhl <aliceryhl@google.com>
    Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
    ad37bcd9
    History
    rust: add tracepoint support
    Alice Ryhl authored
    Make it possible to have Rust code call into tracepoints defined by C
    code. It is still required that the tracepoint is declared in a C
    header, and that this header is included in the input to bindgen.
    
    Instead of calling __DO_TRACE directly, the exported rust_do_trace_
    function calls an inline helper function. This is because the `cond`
    argument does not exist at the callsite of DEFINE_RUST_DO_TRACE.
    
    __DECLARE_TRACE always emits an inline static and an extern declaration
    that is only used when CREATE_RUST_TRACE_POINTS is set. These should not
    end up in the final binary so it is not a problem that they sometimes
    are emitted without a user.
    
    Cc: Masami Hiramatsu <mhiramat@kernel.org>
    Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
    Cc: Peter Zijlstra <peterz@infradead.org>
    Cc: Josh Poimboeuf <jpoimboe@kernel.org>
    Cc: Jason Baron <jbaron@akamai.com>
    Cc: Ard Biesheuvel <ardb@kernel.org>
    Cc: Miguel Ojeda <ojeda@kernel.org>
    Cc: Alex Gaynor <alex.gaynor@gmail.com>
    Cc: Wedson Almeida Filho <wedsonaf@gmail.com>
    Cc: " =?utf-8?q?Bj=C3=B6rn_Roy_Baron?= " <bjorn3_gh@protonmail.com>
    Cc: Benno Lossin <benno.lossin@proton.me>
    Cc: Andreas Hindborg <a.hindborg@kernel.org>
    Cc: Arnd Bergmann <arnd@arndb.de>
    Cc: Thomas Gleixner <tglx@linutronix.de>
    Cc: Ingo Molnar <mingo@redhat.com>
    Cc: Borislav Petkov <bp@alien8.de>
    Cc: Dave Hansen <dave.hansen@linux.intel.com>
    Cc: "H. Peter Anvin" <hpa@zytor.com>
    Cc: Sean Christopherson <seanjc@google.com>
    Cc: Uros Bizjak <ubizjak@gmail.com>
    Cc: Catalin Marinas <catalin.marinas@arm.com>
    Cc: Will Deacon <will@kernel.org>
    Cc: Marc Zyngier <maz@kernel.org>
    Cc: Oliver Upton <oliver.upton@linux.dev>
    Cc: Mark Rutland <mark.rutland@arm.com>
    Cc: Ryan Roberts <ryan.roberts@arm.com>
    Cc: Fuad Tabba <tabba@google.com>
    Cc: Paul Walmsley <paul.walmsley@sifive.com>
    Cc: Palmer Dabbelt <palmer@dabbelt.com>
    Cc: Albert Ou <aou@eecs.berkeley.edu>
    Cc: Anup Patel <apatel@ventanamicro.com>
    Cc: Andrew Jones <ajones@ventanamicro.com>
    Cc: Alexandre Ghiti <alexghiti@rivosinc.com>
    Cc: Conor Dooley <conor.dooley@microchip.com>
    Cc: Samuel Holland <samuel.holland@sifive.com>
    Cc: Huacai Chen <chenhuacai@kernel.org>
    Cc: WANG Xuerui <kernel@xen0n.name>
    Cc: Bibo Mao <maobibo@loongson.cn>
    Cc: Tiezhu Yang <yangtiezhu@loongson.cn>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Cc: Tianrui Zhao <zhaotianrui@loongson.cn>
    Link: https://lore.kernel.org/20241030-tracepoint-v12-2-eec7f0f8ad22@google.com
    
    
    Reviewed-by: default avatarCarlos Llamas <cmllamas@google.com>
    Reviewed-by: default avatarGary Guo <gary@garyguo.net>
    Reviewed-by: default avatarBoqun Feng <boqun.feng@gmail.com>
    Signed-off-by: default avatarAlice Ryhl <aliceryhl@google.com>
    Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>