[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20211006161805.GA24396@anparri>
Date: Wed, 6 Oct 2021 18:18:05 +0200
From: Andrea Parri <parri.andrea@...il.com>
To: Michael Kelley <mikelley@...rosoft.com>
Cc: "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
"linux-hyperv@...r.kernel.org" <linux-hyperv@...r.kernel.org>,
"linux-scsi@...r.kernel.org" <linux-scsi@...r.kernel.org>,
KY Srinivasan <kys@...rosoft.com>,
Haiyang Zhang <haiyangz@...rosoft.com>,
Stephen Hemminger <sthemmin@...rosoft.com>,
Wei Liu <wei.liu@...nel.org>,
"James E . J . Bottomley" <jejb@...ux.ibm.com>,
"Martin K . Petersen" <martin.petersen@...cle.com>,
Dexuan Cui <decui@...rosoft.com>
Subject: Re: [PATCH v2] scsi: storvsc: Fix validation for unsolicited
incoming packets
> > @@ -1302,13 +1306,25 @@ static void storvsc_on_channel_callback(void *context)
> > if (rqst_id == 0) {
> > /*
> > * storvsc_on_receive() looks at the vstor_packet in the message
> > - * from the ring buffer. If the operation in the vstor_packet is
> > - * COMPLETE_IO, then we call storvsc_on_io_completion(), and
> > - * dereference the guest memory address. Make sure we don't call
> > - * storvsc_on_io_completion() with a guest memory address that is
> > - * zero if Hyper-V were to construct and send such a bogus packet.
> > + * from the ring buffer.
> > + *
> > + * - If the operation in the vstor_packet is COMPLETE_IO, then
> > + * we call storvsc_on_io_completion(), and dereference the
> > + * guest memory address. Make sure we don't call
> > + * storvsc_on_io_completion() with a guest memory address
> > + * that is zero if Hyper-V were to construct and send such
> > + * a bogus packet.
> > + *
> > + * - If the operation in the vstor_packet is FCHBA_DATA, then
> > + * we call cache_wwn(), and access the data payload area of
> > + * the packet (wwn_packet); however, there is no guarantee
> > + * that the packet is big enough to contain such area.
> > + * Future-proof the code by rejecting such a bogus packet.
>
> The comments look good to me.
>
> > + *
> > + * XXX. Filter out all "invalid" operations.
>
> Is this a leftover comment line that should be deleted? I'm not sure about the "XXX".
That was/is intended as a "TODO". What I think we are missing here is a
specification/authority stating "allowed vstor_operation for unsolicited
messages are: ENUMERATE_BUS, REMOVE_DEVICE, etc.". If we wanted to make
this code even more "future-proof"/"robust", we would reject all packets
whose "operation" doesn't match that list (independently from the actual
form/implementation of storvsc_on_receive()...). We are not quite there
tough AFAICT.
> > */
> > - if (packet->operation == VSTOR_OPERATION_COMPLETE_IO) {
> > + if (packet->operation == VSTOR_OPERATION_COMPLETE_IO ||
> > + packet->operation == VSTOR_OPERATION_FCHBA_DATA) {
> > dev_err(&device->device, "Invalid packet with ID of 0\n");
> > continue;
> > }
> > --
> > 2.25.1
>
> Other than the seemingly spurious comment line,
>
> Reviewed-by: Michael Kelley <mikelley@...rosoft.com>
I wanted to make sure that we're on the same page: I could either expand
or just remove that comment line; no strong opinion. Please let me know
what is your/reviewers' preference.
Thanks,
Andrea
Powered by blists - more mailing lists