[PATCH] arm64: hw_breakpoint: Save privilege of access control via ptrace
Tiezhu Yang
yangtiezhu at loongson.cn
Wed Jun 19 19:05:35 PDT 2024
On 06/19/2024 11:15 PM, Oleg Nesterov wrote:
> I don't understand what this patch does, but...
Thanks for your reply.
ctrl->privilege in decode_ctrl_reg() is never be used later but
it can and should be used in arch_build_bp_info().
arch/arm64/include/asm/hw_breakpoint.h
static inline void decode_ctrl_reg(u32 reg,
struct arch_hw_breakpoint_ctrl *ctrl)
{
...
ctrl->privilege = reg & 0x3; // it is never be used later but ...
...
}
arch/arm64/kernel/hw_breakpoint.c
static int arch_build_bp_info(struct perf_event *bp,
const struct perf_event_attr *attr,
struct arch_hw_breakpoint *hw)
{
...
if (arch_check_bp_in_kernelspace(hw))
hw->ctrl.privilege = AARCH64_BREAKPOINT_EL1; // ... it can and should
be used here
else
hw->ctrl.privilege = AARCH64_BREAKPOINT_EL0; // and here.
...
}
>
> On 06/18, Tiezhu Yang wrote:
>>
>> --- a/include/uapi/linux/perf_event.h
>> +++ b/include/uapi/linux/perf_event.h
>> @@ -467,6 +467,7 @@ struct perf_event_attr {
>> __u32 wakeup_watermark; /* bytes before wakeup */
>> };
>>
>> + __u8 bp_priv;
>> __u32 bp_type;
>
> Is it safe to add the new member in the middle of uapi struct?
> This will break userspace...
Let me put the new member "bp_priv" at the end of uapi struct
perf_event_attr in the next version if you are OK with it.
Thanks,
Tiezhu
More information about the linux-arm-kernel
mailing list