Re: [PATCH 2/3] libfc: check fc_frame_payload_get() return value for null

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, 7 Oct 2018, 1:35am, Hannes Reinecke wrote:

> External Email
> 
> From: Thomas Abraham <tabraham@xxxxxxxx>
> 
> We should not assume the payload of a PRLI or PLOGI
> respons is always present.
> 
> Signed-off-by: Thomas Abraham <tabraham@xxxxxxxx>
> Reviewed-by: Hannes Reinecke <hare@xxxxxxxx>
> ---
>  drivers/scsi/libfc/fc_rport.c | 14 ++++++++++----
>  1 file changed, 10 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/scsi/libfc/fc_rport.c b/drivers/scsi/libfc/fc_rport.c
> index 372387a450df..e400783ebb87 100644
> --- a/drivers/scsi/libfc/fc_rport.c
> +++ b/drivers/scsi/libfc/fc_rport.c
> @@ -1038,8 +1038,11 @@ static void fc_rport_plogi_resp(struct fc_seq *sp, struct fc_frame *fp,
>                 struct fc_els_ls_rjt *rjt;
> 
>                 rjt = fc_frame_payload_get(fp, sizeof(*rjt));
> -               FC_RPORT_DBG(rdata, "PLOGI ELS rejected, reason %x expl %x\n",
> -                            rjt->er_reason, rjt->er_explan);
> +               if (!rjt)
> +                       FC_RPORT_DBG(rdata, "PLOGI bad response\n");
> +               else
> +                       FC_RPORT_DBG(rdata, "PLOGI ELS rejected, reason %x expl %x\n",
> +                                    rjt->er_reason, rjt->er_explan);
>                 fc_rport_error_retry(rdata, -FC_EX_ELS_RJT);
>         }
>  out:
> @@ -1211,8 +1214,11 @@ static void fc_rport_prli_resp(struct fc_seq *sp, struct fc_frame *fp,
> 
>         } else {
>                 rjt = fc_frame_payload_get(fp, sizeof(*rjt));
> -               FC_RPORT_DBG(rdata, "PRLI ELS rejected, reason %x expl %x\n",
> -                            rjt->er_reason, rjt->er_explan);
> +               if (!rjt)
> +                       FC_RPORT_DBG(rdata, "PRLI bad response\n");
> +               else
> +                       FC_RPORT_DBG(rdata, "PRLI ELS rejected, reason %x expl %x\n",
> +                                    rjt->er_reason, rjt->er_explan);
>                 fc_rport_error_retry(rdata, FC_EX_ELS_RJT);
>         }

It would be a good idea to explicitly mention in the header message 
that this fixes a crash. The changes by themselves look good to me.

Reviewed-by: Arun Easi <arun.easi@xxxxxxxxxx>

Regards,
-Arun

> 
> --
> 2.16.4
> 
> 




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]

  Powered by Linux