diff --git a/aya-log-common/src/lib.rs b/aya-log-common/src/lib.rs index f833f3c11..831c0232b 100644 --- a/aya-log-common/src/lib.rs +++ b/aya-log-common/src/lib.rs @@ -35,6 +35,73 @@ pub enum Level { Trace, } +macro_rules! impl_formatter_for_types { + ($trait:path : { $($type:ty),*}) => { + $( + impl $trait for $type {} + )* + }; +} + +pub trait DefaultFormatter {} +impl_formatter_for_types!( + DefaultFormatter: { + bool, + i8, i16, i32, i64, isize, + u8, u16, u32, u64, usize, + f32, f64, + char, + str, + &str + } +); + +pub trait LowerHexFormatter {} +impl_formatter_for_types!( + LowerHexFormatter: { + i8, i16, i32, i64, isize, + u8, u16, u32, u64, usize, + &[u8] + } +); + +pub trait UpperHexFormatter {} +impl_formatter_for_types!( + UpperHexFormatter: { + i8, i16, i32, i64, isize, + u8, u16, u32, u64, usize, + &[u8] + } +); + +pub trait Ipv4Formatter {} +impl Ipv4Formatter for u32 {} + +pub trait Ipv6Formatter {} +impl Ipv6Formatter for [u8; 16] {} +impl Ipv6Formatter for [u16; 8] {} + +pub trait LowerMacFormatter {} +impl LowerMacFormatter for [u8; 6] {} + +pub trait UpperMacFormatter {} +impl UpperMacFormatter for [u8; 6] {} + +#[inline(always)] +pub fn check_impl_default(_v: T) {} +#[inline(always)] +pub fn check_impl_lower_hex(_v: T) {} +#[inline(always)] +pub fn check_impl_upper_hex(_v: T) {} +#[inline(always)] +pub fn check_impl_ipv4(_v: T) {} +#[inline(always)] +pub fn check_impl_ipv6(_v: T) {} +#[inline(always)] +pub fn check_impl_lower_mac(_v: T) {} +#[inline(always)] +pub fn check_impl_upper_mac(_v: T) {} + #[repr(u8)] #[derive(Copy, Clone, Debug)] pub enum RecordField { diff --git a/aya-log-ebpf-macros/src/expand.rs b/aya-log-ebpf-macros/src/expand.rs index eefcbb723..01de1bf9e 100644 --- a/aya-log-ebpf-macros/src/expand.rs +++ b/aya-log-ebpf-macros/src/expand.rs @@ -86,6 +86,18 @@ fn hint_to_expr(hint: DisplayHint) -> Result { } } +fn hint_to_format_check(hint: DisplayHint) -> Result { + match hint { + DisplayHint::Default => parse_str("::aya_log_ebpf::macro_support::check_impl_default"), + DisplayHint::LowerHex => parse_str("::aya_log_ebpf::macro_support::check_impl_lower_hex"), + DisplayHint::UpperHex => parse_str("::aya_log_ebpf::macro_support::check_impl_upper_hex"), + DisplayHint::Ipv4 => parse_str("::aya_log_ebpf::macro_support::check_impl_ipv4"), + DisplayHint::Ipv6 => parse_str("::aya_log_ebpf::macro_support::check_impl_ipv6"), + DisplayHint::LowerMac => parse_str("::aya_log_ebpf::macro_support::check_impl_lower_mac"), + DisplayHint::UpperMac => parse_str("::aya_log_ebpf::macro_support::check_impl_upper_mac"), + } +} + pub(crate) fn log(args: LogArgs, level: Option) -> Result { let ctx = args.ctx; let target = match args.target { @@ -115,6 +127,8 @@ pub(crate) fn log(args: LogArgs, level: Option) -> Result { @@ -126,7 +140,10 @@ pub(crate) fn log(args: LogArgs, level: Option) -> Result return Err(Error::new(format_string.span(), "no arguments provided")), }; values.push(hint_to_expr(p.hint)?); - values.push(arg); + values.push(arg.clone()); + + f_keys.push(hint_to_format_check(p.hint)?); + f_values.push(arg.clone()); arg_i += 1; } } @@ -135,8 +152,15 @@ pub(crate) fn log(args: LogArgs, level: Option) -> Result