[PATCH v3 09/15] perf: Reflow to get rid of aux_success label

Peter Zijlstra posted 15 patches 1 month, 3 weeks ago
[PATCH v3 09/15] perf: Reflow to get rid of aux_success label
Posted by Peter Zijlstra 1 month, 3 weeks ago
Mostly re-indent noise needed to get rid of that label.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
---
 kernel/events/core.c |   37 ++++++++++++++++++-------------------
 1 file changed, 18 insertions(+), 19 deletions(-)

--- a/kernel/events/core.c
+++ b/kernel/events/core.c
@@ -7127,30 +7127,29 @@ static int perf_mmap(struct file *file,
 		if (rb_has_aux(rb)) {
 			atomic_inc(&rb->aux_mmap_count);
 			ret = 0;
-			goto aux_success;
-		}
 
-		if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
-			ret = -EPERM;
-			atomic_dec(&rb->mmap_count);
-			goto unlock;
-		}
+		} else {
+			if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
+				ret = -EPERM;
+				atomic_dec(&rb->mmap_count);
+				goto unlock;
+			}
 
-		WARN_ON(!rb && event->rb);
+			WARN_ON(!rb && event->rb);
 
-		if (vma->vm_flags & VM_WRITE)
-			flags |= RING_BUFFER_WRITABLE;
+			if (vma->vm_flags & VM_WRITE)
+				flags |= RING_BUFFER_WRITABLE;
 
-		ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
-				   event->attr.aux_watermark, flags);
-		if (ret) {
-			atomic_dec(&rb->mmap_count);
-			goto unlock;
-		}
+			ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
+					   event->attr.aux_watermark, flags);
+			if (ret) {
+				atomic_dec(&rb->mmap_count);
+				goto unlock;
+			}
 
-		atomic_set(&rb->aux_mmap_count, 1);
-		rb->aux_mmap_locked = extra;
-aux_success:
+			atomic_set(&rb->aux_mmap_count, 1);
+			rb->aux_mmap_locked = extra;
+		}
 		perf_mmap_account(vma, user_extra, extra);
 		atomic_inc(&event->mmap_count);
 	}
Re: [PATCH v3 09/15] perf: Reflow to get rid of aux_success label
Posted by Lorenzo Stoakes 1 month, 3 weeks ago
On Tue, Aug 12, 2025 at 12:39:07PM +0200, Peter Zijlstra wrote:
> Mostly re-indent noise needed to get rid of that label.
>
> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>

This is where a side-by-side git diff pager comes in handy :)

LGTM apart from nit/comment below so:

Reviewed-by: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>

> ---
>  kernel/events/core.c |   37 ++++++++++++++++++-------------------
>  1 file changed, 18 insertions(+), 19 deletions(-)
>
> --- a/kernel/events/core.c
> +++ b/kernel/events/core.c
> @@ -7127,30 +7127,29 @@ static int perf_mmap(struct file *file,
>  		if (rb_has_aux(rb)) {
>  			atomic_inc(&rb->aux_mmap_count);
>  			ret = 0;
> -			goto aux_success;
> -		}
>
> -		if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
> -			ret = -EPERM;
> -			atomic_dec(&rb->mmap_count);
> -			goto unlock;
> -		}

NIT: These leaves  a space above:

		if (rb_has_aux(rb)) {
			atomic_inc(&rb->aux_mmap_count);
			ret = 0;

		} else {


> +		} else {
> +			if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
> +				ret = -EPERM;
> +				atomic_dec(&rb->mmap_count);
> +				goto unlock;
> +			}
>
> -		WARN_ON(!rb && event->rb);
> +			WARN_ON(!rb && event->rb);
>
> -		if (vma->vm_flags & VM_WRITE)
> -			flags |= RING_BUFFER_WRITABLE;
> +			if (vma->vm_flags & VM_WRITE)
> +				flags |= RING_BUFFER_WRITABLE;
>
> -		ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
> -				   event->attr.aux_watermark, flags);
> -		if (ret) {
> -			atomic_dec(&rb->mmap_count);
> -			goto unlock;
> -		}
> +			ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
> +					   event->attr.aux_watermark, flags);
> +			if (ret) {
> +				atomic_dec(&rb->mmap_count);
> +				goto unlock;
> +			}
>
> -		atomic_set(&rb->aux_mmap_count, 1);
> -		rb->aux_mmap_locked = extra;
> -aux_success:
> +			atomic_set(&rb->aux_mmap_count, 1);
> +			rb->aux_mmap_locked = extra;
> +		}

This gets rid of the label but leave spretty horrid nesting, but I'm
guessing further refactorings will tame it.

>  		perf_mmap_account(vma, user_extra, extra);
>  		atomic_inc(&event->mmap_count);
>  	}
>
>
Re: [PATCH v3 09/15] perf: Reflow to get rid of aux_success label
Posted by Peter Zijlstra 1 month, 3 weeks ago
On Wed, Aug 13, 2025 at 07:03:01AM +0100, Lorenzo Stoakes wrote:
> On Tue, Aug 12, 2025 at 12:39:07PM +0200, Peter Zijlstra wrote:
> > Mostly re-indent noise needed to get rid of that label.
> >
> > Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
> 
> This is where a side-by-side git diff pager comes in handy :)
> 
> LGTM apart from nit/comment below so:
> 
> Reviewed-by: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>
> 
> > ---
> >  kernel/events/core.c |   37 ++++++++++++++++++-------------------
> >  1 file changed, 18 insertions(+), 19 deletions(-)
> >
> > --- a/kernel/events/core.c
> > +++ b/kernel/events/core.c
> > @@ -7127,30 +7127,29 @@ static int perf_mmap(struct file *file,
> >  		if (rb_has_aux(rb)) {
> >  			atomic_inc(&rb->aux_mmap_count);
> >  			ret = 0;
> > -			goto aux_success;
> > -		}
> >
> > -		if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
> > -			ret = -EPERM;
> > -			atomic_dec(&rb->mmap_count);
> > -			goto unlock;
> > -		}
> 
> NIT: These leaves  a space above:
> 
> 		if (rb_has_aux(rb)) {
> 			atomic_inc(&rb->aux_mmap_count);
> 			ret = 0;
> 
> 		} else {
> 

Yeah, you mention that elsewhere as well. I tend to do that to visually
separate the else branch from the previous block. Although I'm not very
consistent with it. I can remove these I suppose.

> > +		} else {
> > +			if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
> > +				ret = -EPERM;
> > +				atomic_dec(&rb->mmap_count);
> > +				goto unlock;
> > +			}
> >
> > -		WARN_ON(!rb && event->rb);
> > +			WARN_ON(!rb && event->rb);
> >
> > -		if (vma->vm_flags & VM_WRITE)
> > -			flags |= RING_BUFFER_WRITABLE;
> > +			if (vma->vm_flags & VM_WRITE)
> > +				flags |= RING_BUFFER_WRITABLE;
> >
> > -		ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
> > -				   event->attr.aux_watermark, flags);
> > -		if (ret) {
> > -			atomic_dec(&rb->mmap_count);
> > -			goto unlock;
> > -		}
> > +			ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
> > +					   event->attr.aux_watermark, flags);
> > +			if (ret) {
> > +				atomic_dec(&rb->mmap_count);
> > +				goto unlock;
> > +			}
> >
> > -		atomic_set(&rb->aux_mmap_count, 1);
> > -		rb->aux_mmap_locked = extra;
> > -aux_success:
> > +			atomic_set(&rb->aux_mmap_count, 1);
> > +			rb->aux_mmap_locked = extra;
> > +		}
> 
> This gets rid of the label but leave spretty horrid nesting, but I'm
> guessing further refactorings will tame it.

The split out in the next patch removes one indent level.
[tip: perf/core] perf: Reflow to get rid of aux_success label
Posted by tip-bot2 for Peter Zijlstra 1 month, 2 weeks ago
The following commit has been merged into the perf/core branch of tip:

Commit-ID:     8558dca9fbdf825edf30b5fb74fbbbf3e6ba5dce
Gitweb:        https://git.kernel.org/tip/8558dca9fbdf825edf30b5fb74fbbbf3e6ba5dce
Author:        Peter Zijlstra <peterz@infradead.org>
AuthorDate:    Tue, 12 Aug 2025 12:39:07 +02:00
Committer:     Peter Zijlstra <peterz@infradead.org>
CommitterDate: Fri, 15 Aug 2025 13:13:00 +02:00

perf: Reflow to get rid of aux_success label

Mostly re-indent noise needed to get rid of that label.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>
Link: https://lore.kernel.org/r/20250812104019.362581570@infradead.org
---
 kernel/events/core.c | 37 ++++++++++++++++++-------------------
 1 file changed, 18 insertions(+), 19 deletions(-)

diff --git a/kernel/events/core.c b/kernel/events/core.c
index 236c60a..5bbea81 100644
--- a/kernel/events/core.c
+++ b/kernel/events/core.c
@@ -7130,30 +7130,29 @@ static int perf_mmap(struct file *file, struct vm_area_struct *vma)
 		if (rb_has_aux(rb)) {
 			atomic_inc(&rb->aux_mmap_count);
 			ret = 0;
-			goto aux_success;
-		}
 
-		if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
-			ret = -EPERM;
-			atomic_dec(&rb->mmap_count);
-			goto unlock;
-		}
+		} else {
+			if (!perf_mmap_calc_limits(vma, &user_extra, &extra)) {
+				ret = -EPERM;
+				atomic_dec(&rb->mmap_count);
+				goto unlock;
+			}
 
-		WARN_ON(!rb && event->rb);
+			WARN_ON(!rb && event->rb);
 
-		if (vma->vm_flags & VM_WRITE)
-			flags |= RING_BUFFER_WRITABLE;
+			if (vma->vm_flags & VM_WRITE)
+				flags |= RING_BUFFER_WRITABLE;
 
-		ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
-				   event->attr.aux_watermark, flags);
-		if (ret) {
-			atomic_dec(&rb->mmap_count);
-			goto unlock;
-		}
+			ret = rb_alloc_aux(rb, event, vma->vm_pgoff, nr_pages,
+					   event->attr.aux_watermark, flags);
+			if (ret) {
+				atomic_dec(&rb->mmap_count);
+				goto unlock;
+			}
 
-		atomic_set(&rb->aux_mmap_count, 1);
-		rb->aux_mmap_locked = extra;
-aux_success:
+			atomic_set(&rb->aux_mmap_count, 1);
+			rb->aux_mmap_locked = extra;
+		}
 		perf_mmap_account(vma, user_extra, extra);
 		atomic_inc(&event->mmap_count);
 	}