* Oleg Nesterov <o...@redhat.com> [2012-12-31 18:52:29]:

> handle_swbp() does get_utask() before can_skip_sstep() for no reason,
> we do not need ->utask if can_skip_sstep() succeeds.
> 
> Move get_utask() to pre_ssout() who actually starts to use it. Move
> the initialization of utask->active_uprobe/state as well. This way
> the whole initialization is consolidated in pre_ssout().
> 
> Signed-off-by: Oleg Nesterov <o...@redhat.com>
> ---
>  kernel/events/uprobes.c |   16 ++++++----------
>  1 files changed, 6 insertions(+), 10 deletions(-)
> 
> diff --git a/kernel/events/uprobes.c b/kernel/events/uprobes.c
> index bd94d2c..ad1245d 100644
> --- a/kernel/events/uprobes.c
> +++ b/kernel/events/uprobes.c
> @@ -1308,7 +1308,9 @@ pre_ssout(struct uprobe *uprobe, struct pt_regs *regs, 
> unsigned long bp_vaddr)
>       unsigned long xol_vaddr;
>       int err;
> 
> -     utask = current->utask;
> +     utask = get_utask();
> +     if (!utask)
> +             return -ENOMEM;
> 
>       xol_vaddr = xol_get_insn_slot(uprobe);
>       if (!xol_vaddr)
> @@ -1323,6 +1325,8 @@ pre_ssout(struct uprobe *uprobe, struct pt_regs *regs, 
> unsigned long bp_vaddr)
>               return err;
>       }
> 
> +     utask->active_uprobe = uprobe;
> +     utask->state = UTASK_SSTEP;
>       return 0;
>  }
> 
> @@ -1474,7 +1478,6 @@ static void handler_chain(struct uprobe *uprobe, struct 
> pt_regs *regs)
>   */
>  static void handle_swbp(struct pt_regs *regs)
>  {
> -     struct uprobe_task *utask;
>       struct uprobe *uprobe;
>       unsigned long bp_vaddr;
>       int uninitialized_var(is_swbp);
> @@ -1512,19 +1515,12 @@ static void handle_swbp(struct pt_regs *regs)
>       if (unlikely(!test_bit(UPROBE_COPY_INSN, &uprobe->flags)))
>               goto out;
> 
> -     utask = get_utask();
> -     if (!utask)
> -             goto out;       /* re-execute the instruction. */
> -


If get_utask fails with the above change, Dont we end up calling
handler_chain twice(or more)?. I think this is probably true with
previous patch too.

>       handler_chain(uprobe, regs);
>       if (can_skip_sstep(uprobe, regs))
>               goto out;
> 
> -     if (!pre_ssout(uprobe, regs, bp_vaddr)) {
> -             utask->active_uprobe = uprobe;
> -             utask->state = UTASK_SSTEP;
> +     if (!pre_ssout(uprobe, regs, bp_vaddr))
>               return;
> -     }
> 
>       /* can_skip_sstep() succeeded, or restart if can't singlestep */
>  out:
> -- 
> 1.5.5.1
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to