* [patch] sbp-target: checking for NULL instead of IS_ERR
@ 2016-03-02 10:09 Dan Carpenter
2016-03-05 7:33 ` Nicholas A. Bellinger
0 siblings, 1 reply; 8+ messages in thread
From: Dan Carpenter @ 2016-03-02 10:09 UTC (permalink / raw)
To: Chris Boot, Nicholas A. Bellinger
Cc: target-devel, linux1394-devel, linux-kernel, kernel-janitors
We changed this from kzalloc to sbp_mgt_get_req() so we need to change
from checking for NULL to check for error pointers.
Fixes: c064b2a78989 ('sbp-target: Conversion to percpu_ida tag pre-allocation')
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
index 251d532..a04b0605f 100644
--- a/drivers/target/sbp/sbp_target.c
+++ b/drivers/target/sbp/sbp_target.c
@@ -951,7 +951,7 @@ static void tgt_agent_fetch_work(struct work_struct *work)
while (next_orb && tgt_agent_check_active(agent)) {
req = sbp_mgt_get_req(sess, sess->card, next_orb);
- if (!req) {
+ if (IS_ERR(req)) {
spin_lock_bh(&agent->lock);
agent->state = AGENT_STATE_DEAD;
spin_unlock_bh(&agent->lock);
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-02 10:09 [patch] sbp-target: checking for NULL instead of IS_ERR Dan Carpenter
@ 2016-03-05 7:33 ` Nicholas A. Bellinger
2016-03-05 8:45 ` Chris Boot
0 siblings, 1 reply; 8+ messages in thread
From: Nicholas A. Bellinger @ 2016-03-05 7:33 UTC (permalink / raw)
To: Dan Carpenter
Cc: Chris Boot, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
Hi Dan + BootC,
On Wed, 2016-03-02 at 13:09 +0300, Dan Carpenter wrote:
> We changed this from kzalloc to sbp_mgt_get_req() so we need to change
> from checking for NULL to check for error pointers.
>
> Fixes: c064b2a78989 ('sbp-target: Conversion to percpu_ida tag pre-allocation')
> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
>
> diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
> index 251d532..a04b0605f 100644
> --- a/drivers/target/sbp/sbp_target.c
> +++ b/drivers/target/sbp/sbp_target.c
> @@ -951,7 +951,7 @@ static void tgt_agent_fetch_work(struct work_struct *work)
>
> while (next_orb && tgt_agent_check_active(agent)) {
> req = sbp_mgt_get_req(sess, sess->card, next_orb);
> - if (!req) {
> + if (IS_ERR(req)) {
> spin_lock_bh(&agent->lock);
> agent->state = AGENT_STATE_DEAD;
> spin_unlock_bh(&agent->lock);
Fixed + folded into the original patch.
Thanks Dan.
Chris, would you be so kind to review the original changes here:
sbp-target: Conversion to percpu_ida tag pre-allocation
http://www.spinics.net/lists/target-devel/msg11778.html
sbp-target: Convert to TARGET_SCF_ACK_KREF I/O krefs
http://www.spinics.net/lists/target-devel/msg11780.html
and verify on your local IEEE1394 target setup..?
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-05 7:33 ` Nicholas A. Bellinger
@ 2016-03-05 8:45 ` Chris Boot
2016-03-05 9:33 ` Nicholas A. Bellinger
0 siblings, 1 reply; 8+ messages in thread
From: Chris Boot @ 2016-03-05 8:45 UTC (permalink / raw)
To: Nicholas A. Bellinger
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On 5 Mar 2016, at 07:33, Nicholas A. Bellinger <nab@linux-iscsi.org> wrote:
>
> Hi Dan + BootC,
>
> On Wed, 2016-03-02 at 13:09 +0300, Dan Carpenter wrote:
>> We changed this from kzalloc to sbp_mgt_get_req() so we need to change
>> from checking for NULL to check for error pointers.
>>
>> Fixes: c064b2a78989 ('sbp-target: Conversion to percpu_ida tag pre-allocation')
>> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
>>
>> diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
>> index 251d532..a04b0605f 100644
>> --- a/drivers/target/sbp/sbp_target.c
>> +++ b/drivers/target/sbp/sbp_target.c
>> @@ -951,7 +951,7 @@ static void tgt_agent_fetch_work(struct work_struct *work)
>>
>> while (next_orb && tgt_agent_check_active(agent)) {
>> req = sbp_mgt_get_req(sess, sess->card, next_orb);
>> - if (!req) {
>> + if (IS_ERR(req)) {
>> spin_lock_bh(&agent->lock);
>> agent->state = AGENT_STATE_DEAD;
>> spin_unlock_bh(&agent->lock);
>
> Fixed + folded into the original patch.
>
> Thanks Dan.
>
> Chris, would you be so kind to review the original changes here:
>
> sbp-target: Conversion to percpu_ida tag pre-allocation
> http://www.spinics.net/lists/target-devel/msg11778.html
>
> sbp-target: Convert to TARGET_SCF_ACK_KREF I/O krefs
> http://www.spinics.net/lists/target-devel/msg11780.html
>
> and verify on your local IEEE1394 target setup..?
Hi Nic, Dan,
I’m away this weekend so I can’t test these for a few days at least, unfortunately. I must admit I only vaguely follow the changes here as I haven’t been keeping up with the pace of change in target-devel lately, but it generally looks OK I think.
Are these in linux-next or another branch somewhere I can easily clone them from?
How soon do you need my ACK/NAK on these?
Cheers,
Chris
--
Chris Boot
bootc@bootc.net
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-05 8:45 ` Chris Boot
@ 2016-03-05 9:33 ` Nicholas A. Bellinger
2016-03-10 20:56 ` Chris Boot
0 siblings, 1 reply; 8+ messages in thread
From: Nicholas A. Bellinger @ 2016-03-05 9:33 UTC (permalink / raw)
To: Chris Boot
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On Sat, 2016-03-05 at 08:45 +0000, Chris Boot wrote:
> On 5 Mar 2016, at 07:33, Nicholas A. Bellinger <nab@linux-iscsi.org> wrote:
> >
> > Hi Dan + BootC,
> >
> > On Wed, 2016-03-02 at 13:09 +0300, Dan Carpenter wrote:
> >> We changed this from kzalloc to sbp_mgt_get_req() so we need to change
> >> from checking for NULL to check for error pointers.
> >>
> >> Fixes: c064b2a78989 ('sbp-target: Conversion to percpu_ida tag pre-allocation')
> >> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
> >>
> >> diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
> >> index 251d532..a04b0605f 100644
> >> --- a/drivers/target/sbp/sbp_target.c
> >> +++ b/drivers/target/sbp/sbp_target.c
> >> @@ -951,7 +951,7 @@ static void tgt_agent_fetch_work(struct work_struct *work)
> >>
> >> while (next_orb && tgt_agent_check_active(agent)) {
> >> req = sbp_mgt_get_req(sess, sess->card, next_orb);
> >> - if (!req) {
> >> + if (IS_ERR(req)) {
> >> spin_lock_bh(&agent->lock);
> >> agent->state = AGENT_STATE_DEAD;
> >> spin_unlock_bh(&agent->lock);
> >
> > Fixed + folded into the original patch.
> >
> > Thanks Dan.
> >
> > Chris, would you be so kind to review the original changes here:
> >
> > sbp-target: Conversion to percpu_ida tag pre-allocation
> > http://www.spinics.net/lists/target-devel/msg11778.html
> >
> > sbp-target: Convert to TARGET_SCF_ACK_KREF I/O krefs
> > http://www.spinics.net/lists/target-devel/msg11780.html
> >
> > and verify on your local IEEE1394 target setup..?
>
> Hi Nic, Dan,
>
> I’m away this weekend so I can’t test these for a few days at least,
> unfortunately. I must admit I only vaguely follow the changes here as
> I haven’t been keeping up with the pace of change in target-devel
> lately, but it generally looks OK I think.
>
> Are these in linux-next or another branch somewhere I can easily clone
> them from?
The patch series is in target-pending/for-next.
>
> How soon do you need my ACK/NAK on these?
>
Assuming the merge window opens on the 13th, any time over the next 7-10
days would be fine.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-05 9:33 ` Nicholas A. Bellinger
@ 2016-03-10 20:56 ` Chris Boot
2016-03-10 21:52 ` Chris Boot
0 siblings, 1 reply; 8+ messages in thread
From: Chris Boot @ 2016-03-10 20:56 UTC (permalink / raw)
To: Nicholas A. Bellinger
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On 05/03/16 09:33, Nicholas A. Bellinger wrote:
> On Sat, 2016-03-05 at 08:45 +0000, Chris Boot wrote:
>> Are these in linux-next or another branch somewhere I can easily clone
>> them from?
>
> The patch series is in target-pending/for-next.
Hi Nic,
I've just managed to resurrect a test rig for this (the hardware I had
for it has stopped being usable, yay!), and my initial testing shows the
updated code panics on the first submitted IO.
I'll go and debug it now and see what I can get from it, but I thought
I'd let you know ASAP.
Cheers,
Chris
--
Chris Boot
bootc@bootc.net
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-10 20:56 ` Chris Boot
@ 2016-03-10 21:52 ` Chris Boot
2016-03-10 22:58 ` Chris Boot
0 siblings, 1 reply; 8+ messages in thread
From: Chris Boot @ 2016-03-10 21:52 UTC (permalink / raw)
To: Nicholas A. Bellinger
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On 10/03/16 20:56, Chris Boot wrote:
> On 05/03/16 09:33, Nicholas A. Bellinger wrote:
>> On Sat, 2016-03-05 at 08:45 +0000, Chris Boot wrote:
>>> Are these in linux-next or another branch somewhere I can easily clone
>>> them from?
>>
>> The patch series is in target-pending/for-next.
>
> Hi Nic,
>
> I've just managed to resurrect a test rig for this (the hardware I had
> for it has stopped being usable, yay!), and my initial testing shows the
> updated code panics on the first submitted IO.
So this isn't the first IO, it's exactly the 2nd IO. I'm hitting
BUG_ON(se_cmd->se_tfo || se_cmd->se_sess) in target_submit_cmd_map_sgls().
I'm assuming the se_cmd is being reused due to percpu ida allocator, and
the code must be missing something to clean up the se_cmd sufficiently
once we're done with it.
At this point I'm out of my depth going through the target core, so I'd
appreciate some pointers to get any further!
Thanks,
Chris
--
Chris Boot
bootc@bootc.net
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-10 21:52 ` Chris Boot
@ 2016-03-10 22:58 ` Chris Boot
2016-03-11 4:33 ` Nicholas A. Bellinger
0 siblings, 1 reply; 8+ messages in thread
From: Chris Boot @ 2016-03-10 22:58 UTC (permalink / raw)
To: Nicholas A. Bellinger
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On 10/03/16 21:52, Chris Boot wrote:
> On 10/03/16 20:56, Chris Boot wrote:
>> On 05/03/16 09:33, Nicholas A. Bellinger wrote:
>>> On Sat, 2016-03-05 at 08:45 +0000, Chris Boot wrote:
>>>> Are these in linux-next or another branch somewhere I can easily clone
>>>> them from?
>>>
>>> The patch series is in target-pending/for-next.
>>
>> Hi Nic,
>>
>> I've just managed to resurrect a test rig for this (the hardware I had
>> for it has stopped being usable, yay!), and my initial testing shows the
>> updated code panics on the first submitted IO.
>
> So this isn't the first IO, it's exactly the 2nd IO. I'm hitting
> BUG_ON(se_cmd->se_tfo || se_cmd->se_sess) in target_submit_cmd_map_sgls().
>
> I'm assuming the se_cmd is being reused due to percpu ida allocator, and
> the code must be missing something to clean up the se_cmd sufficiently
> once we're done with it.
>
> At this point I'm out of my depth going through the target core, so I'd
> appreciate some pointers to get any further!
Replying to myself again... Worked it out after reading the thread about the usb gadget target. Here's the patch you want to squash into your existing series:
diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
index a04b0605f8d0..d021997cc837 100644
--- a/drivers/target/sbp/sbp_target.c
+++ b/drivers/target/sbp/sbp_target.c
@@ -933,6 +933,7 @@ static struct sbp_target_request *sbp_mgt_get_req(struct sbp_session *sess,
return ERR_PTR(-ENOMEM);
req = &((struct sbp_target_request *)se_sess->sess_cmd_map)[tag];
+ memset(req, 0, sizeof(*req));
req->se_cmd.map_tag = tag;
req->se_cmd.tag = next_orb;
@@ -1619,12 +1620,8 @@ static void sbp_mgt_agent_rw(struct fw_card *card,
rcode = RCODE_CONFLICT_ERROR;
goto out;
}
- // XXX:
-#if 0
- req = sbp_mgt_get_req(agent->login->sess, card);
-#else
+
req = kzalloc(sizeof(*req), GFP_ATOMIC);
-#endif
if (!req) {
rcode = RCODE_CONFLICT_ERROR;
goto out;
I hope Thunderbird hasn't mangled this too badly.
With this applied, please add this to the patch for sbp_target:
Acked-by: Chris Boot <bootc@bootc.net>
Thanks,
Chris
--
Chris Boot
bootc@bootc.net
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [patch] sbp-target: checking for NULL instead of IS_ERR
2016-03-10 22:58 ` Chris Boot
@ 2016-03-11 4:33 ` Nicholas A. Bellinger
0 siblings, 0 replies; 8+ messages in thread
From: Nicholas A. Bellinger @ 2016-03-11 4:33 UTC (permalink / raw)
To: Chris Boot
Cc: Dan Carpenter, target-devel, linux1394-devel, linux-kernel,
kernel-janitors
On Thu, 2016-03-10 at 22:58 +0000, Chris Boot wrote:
> On 10/03/16 21:52, Chris Boot wrote:
> > On 10/03/16 20:56, Chris Boot wrote:
> >> On 05/03/16 09:33, Nicholas A. Bellinger wrote:
> >>> On Sat, 2016-03-05 at 08:45 +0000, Chris Boot wrote:
> >>>> Are these in linux-next or another branch somewhere I can easily clone
> >>>> them from?
> >>>
> >>> The patch series is in target-pending/for-next.
> >>
> >> Hi Nic,
> >>
> >> I've just managed to resurrect a test rig for this (the hardware I had
> >> for it has stopped being usable, yay!), and my initial testing shows the
> >> updated code panics on the first submitted IO.
> >
> > So this isn't the first IO, it's exactly the 2nd IO. I'm hitting
> > BUG_ON(se_cmd->se_tfo || se_cmd->se_sess) in target_submit_cmd_map_sgls().
> >
> > I'm assuming the se_cmd is being reused due to percpu ida allocator, and
> > the code must be missing something to clean up the se_cmd sufficiently
> > once we're done with it.
> >
> > At this point I'm out of my depth going through the target core, so I'd
> > appreciate some pointers to get any further!
>
> Replying to myself again... Worked it out after reading the thread
> about the usb gadget target. Here's the patch you want to squash into
> your existing series:
>
> diff --git a/drivers/target/sbp/sbp_target.c b/drivers/target/sbp/sbp_target.c
> index a04b0605f8d0..d021997cc837 100644
> --- a/drivers/target/sbp/sbp_target.c
> +++ b/drivers/target/sbp/sbp_target.c
> @@ -933,6 +933,7 @@ static struct sbp_target_request *sbp_mgt_get_req(struct sbp_session *sess,
> return ERR_PTR(-ENOMEM);
>
> req = &((struct sbp_target_request *)se_sess->sess_cmd_map)[tag];
> + memset(req, 0, sizeof(*req));
> req->se_cmd.map_tag = tag;
> req->se_cmd.tag = next_orb;
>
> @@ -1619,12 +1620,8 @@ static void sbp_mgt_agent_rw(struct fw_card *card,
> rcode = RCODE_CONFLICT_ERROR;
> goto out;
> }
> - // XXX:
> -#if 0
> - req = sbp_mgt_get_req(agent->login->sess, card);
> -#else
> +
> req = kzalloc(sizeof(*req), GFP_ATOMIC);
> -#endif
> if (!req) {
> rcode = RCODE_CONFLICT_ERROR;
> goto out;
>
> I hope Thunderbird hasn't mangled this too badly.
>
> With this applied, please add this to the patch for sbp_target:
>
> Acked-by: Chris Boot <bootc@bootc.net>
>
Applied to target-pending/for-next, and squashing into original patches
for -v4.
Thanks BootC!
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2016-03-11 4:33 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-03-02 10:09 [patch] sbp-target: checking for NULL instead of IS_ERR Dan Carpenter
2016-03-05 7:33 ` Nicholas A. Bellinger
2016-03-05 8:45 ` Chris Boot
2016-03-05 9:33 ` Nicholas A. Bellinger
2016-03-10 20:56 ` Chris Boot
2016-03-10 21:52 ` Chris Boot
2016-03-10 22:58 ` Chris Boot
2016-03-11 4:33 ` Nicholas A. Bellinger
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox