From: Jens Axboe <axboe@kernel.dk>
To: yanlonglong <yanlonglong@kylinos.cn>
Cc: linux-block@vger.kernel.org, linux-kernel@vger.kernel.org,
yukuai@fnnas.com
Subject: Re: [PATCH v3] block: add NULL checks for bic in bfq_bfqq_save_state function
Date: Wed, 6 May 2026 23:18:13 -0600 [thread overview]
Message-ID: <4e9e8eff-b619-4062-9783-511d9771abc9@kernel.dk> (raw)
In-Reply-To: <20260507012826.1535-1-yanlonglong@kylinos.cn>
On 5/6/26 7:28 PM, yanlonglong wrote:
> When the `bic` variable is null, referencing `bfqq_data` through `bic` will
> cause the program to crash. Therefore, the null check for `bic` should be
> moved to the beginning of the function to prevent referencing a null pointer.
This part is obvious, what really needs explaining here is what conditions
can lead to bic being NULL, as that is supposedly the problem being fixed.
So, which conditions lead to bic being NULL here? A good commit message
should explain the "why" of why a change is being made. It's obvious
from the code change what is being done, what is not obvious is why it's
necessary.
> Fixes:fd571df0ac5b("block, bfq: turn bfqq_data into an array in bfq_io_cq")
Still incorrect, need space after Fixes:
> diff --git a/block/bfq-iosched.c b/block/bfq-iosched.c
> index 141c602d5e85..c8cf8764d48d 100644
> --- a/block/bfq-iosched.c
> +++ b/block/bfq-iosched.c
> @@ -3036,7 +3036,7 @@ static void bfq_bfqq_save_state(struct bfq_queue *bfqq)
> {
> struct bfq_io_cq *bic = bfqq->bic;
> unsigned int a_idx = bfqq->actuator_idx;
> - struct bfq_iocq_bfqq_data *bfqq_data = &bic->bfqq_data[a_idx];
> + struct bfq_iocq_bfqq_data *bfqq_data = NULL;
Minor nit, but why initialize it to NULL?
--
Jens Axboe
prev parent reply other threads:[~2026-05-07 5:18 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-06 5:56 [PATCH] block: bic maybe null pointer dereference yanlonglong
2026-05-06 7:09 ` Jens Axboe
2026-05-06 9:04 ` [PATCH v2] block: add NULL checks for bic in bfq_bfqq_save_state function yanlonglong
2026-05-06 10:41 ` Jens Axboe
2026-05-07 1:28 ` [PATCH v3] " yanlonglong
2026-05-07 5:18 ` Jens Axboe [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4e9e8eff-b619-4062-9783-511d9771abc9@kernel.dk \
--to=axboe@kernel.dk \
--cc=linux-block@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=yanlonglong@kylinos.cn \
--cc=yukuai@fnnas.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox