Hi Oleg,

On 07/23/2018 09:56 PM, Oleg Nesterov wrote:
> I have a mixed feeling about this series... I'll try to summarise my thinking
> tomorrow, but I do not see any obvious problem so far. Although I have some
> concerns about 5/6, I need to re-read it after sleep.

Sure.

> 
> 
> On 07/16, Ravi Bangoria wrote:
>>
>> +static int delayed_uprobe_install(struct vm_area_struct *vma)
>> +{
>> +    struct list_head *pos, *q;
>> +    struct delayed_uprobe *du;
>> +    unsigned long vaddr;
>> +    int ret = 0, err = 0;
>> +
>> +    mutex_lock(&delayed_uprobe_lock);
>> +    list_for_each_safe(pos, q, &delayed_uprobe_list) {
>> +            du = list_entry(pos, struct delayed_uprobe, list);
>> +
>> +            if (!du->uprobe->ref_ctr_offset ||
> 
> Is it possible to see ->ref_ctr_offset == 0 in delayed_uprobe_list?

I'll remove this check.

> 
>> @@ -1072,7 +1282,13 @@ int uprobe_mmap(struct vm_area_struct *vma)
>>      struct uprobe *uprobe, *u;
>>      struct inode *inode;
>>  
>> -    if (no_uprobe_events() || !valid_vma(vma, true))
>> +    if (no_uprobe_events())
>> +            return 0;
>> +
>> +    if (vma->vm_flags & VM_WRITE)
>> +            delayed_uprobe_install(vma);
> 
> Obviously not nice performance-wise... OK, I do not know if it will actually
> hurt in practice and probably we can use the better data structures if 
> necessary.
> But can't we check MMF_HAS_UPROBES at least? I mean,
> 
>       if (vma->vm_flags & VM_WRITE && test_bit(MMF_HAS_UPROBES, 
> &vma->vm_mm->flags))
>               delayed_uprobe_install(vma);
> 
> ?

Yes.

> 
> 
> Perhaps we can even add another flag later, MMF_HAS_DELAYED_UPROBES set by
> delayed_uprobe_add().

Yes, good idea.

Thanks for the review,
Ravi

Reply via email to