All of lore.kernel.org
 help / color / mirror / Atom feed
* re: EFI: Stash ROMs if they're not in the PCI BAR
@ 2013-03-15  8:29 Dan Carpenter
       [not found] ` <20130315082928.GA14520-dZEljifmRObu9KfB+GxooP8+0UxHXcjY@public.gmane.org>
  0 siblings, 1 reply; 7+ messages in thread
From: Dan Carpenter @ 2013-03-15  8:29 UTC (permalink / raw)
  To: matthew.garrett-05XSO3Yj/JvQT0dZR+AlfA; +Cc: linux-efi-u79uwXL29TY76Z2rM5mHXA

Hello Matthew Garrett,

The patch dd5fc854de5f: "EFI: Stash ROMs if they're not in the PCI 
BAR" from Dec 5, 2012, leads to the following warning:
"arch/x86/boot/compressed/eboot.c:290 setup_efi_pci()
	 error: potentially dereferencing uninitialized 'pci_handle'."

  254  static efi_status_t setup_efi_pci(struct boot_params *params)
  255  {
  256          efi_pci_io_protocol *pci;
  257          efi_status_t status;
  258          void **pci_handle;
  259          efi_guid_t pci_proto = EFI_PCI_IO_PROTOCOL_GUID;
  260          unsigned long nr_pci, size = 0;
  261          int i;
  262          struct setup_data *data;
  263  
  264          data = (struct setup_data *)(unsigned long)params->hdr.setup_data;
  265  
  266          while (data && data->next)
  267                  data = (struct setup_data *)(unsigned long)data->next;
  268  
  269          status = efi_call_phys5(sys_table->boottime->locate_handle,
  270                                  EFI_LOCATE_BY_PROTOCOL, &pci_proto,
  271                                  NULL, &size, pci_handle);
                                                    ^^^^^^^^^^
This hasn't been initialized yet.

  272  
  273          if (status == EFI_BUFFER_TOO_SMALL) {
  274                  status = efi_call_phys3(sys_table->boottime->allocate_pool,
  275                                          EFI_LOADER_DATA, size, &pci_handle);
  276  

regards,
dan carpenter

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found] ` <20130315082928.GA14520-dZEljifmRObu9KfB+GxooP8+0UxHXcjY@public.gmane.org>
@ 2013-03-15  8:57   ` David Woodhouse
       [not found]     ` <1363337872.2444.9.camel-Fexsq3y4057IgHVZqg5X0TlWvGAXklZc@public.gmane.org>
  0 siblings, 1 reply; 7+ messages in thread
From: David Woodhouse @ 2013-03-15  8:57 UTC (permalink / raw)
  To: Dan Carpenter
  Cc: matthew.garrett-05XSO3Yj/JvQT0dZR+AlfA,
	linux-efi-u79uwXL29TY76Z2rM5mHXA

[-- Attachment #1: Type: text/plain, Size: 1630 bytes --]

On Fri, 2013-03-15 at 11:29 +0300, Dan Carpenter wrote:
> Hello Matthew Garrett,
> 
> The patch dd5fc854de5f: "EFI: Stash ROMs if they're not in the PCI 
> BAR" from Dec 5, 2012, leads to the following warning:
> "arch/x86/boot/compressed/eboot.c:290 setup_efi_pci()
> 	 error: potentially dereferencing uninitialized 'pci_handle'."
> 
>   254  static efi_status_t setup_efi_pci(struct boot_params *params)
>   255  {
>   256          efi_pci_io_protocol *pci;
>   257          efi_status_t status;
>   258          void **pci_handle;
>   259          efi_guid_t pci_proto = EFI_PCI_IO_PROTOCOL_GUID;
>   260          unsigned long nr_pci, size = 0;
>   261          int i;
>   262          struct setup_data *data;
>   263  
>   264          data = (struct setup_data *)(unsigned long)params->hdr.setup_data;
>   265  
>   266          while (data && data->next)
>   267                  data = (struct setup_data *)(unsigned long)data->next;
>   268  
>   269          status = efi_call_phys5(sys_table->boottime->locate_handle,
>   270                                  EFI_LOCATE_BY_PROTOCOL, &pci_proto,
>   271                                  NULL, &size, pci_handle);
>                                                     ^^^^^^^^^^
> This hasn't been initialized yet.

True. It probably doesn't *matter* because the size is zero so the
firmware is just going to ignore the pointer anyway. Although in that
case I wonder why we couldn't have just passed NULL. Perhaps we expected
that some firmware might do some validation on the pointer before
getting to the size check?

-- 
dwmw2


[-- Attachment #2: smime.p7s --]
[-- Type: application/x-pkcs7-signature, Size: 6171 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found]     ` <1363337872.2444.9.camel-Fexsq3y4057IgHVZqg5X0TlWvGAXklZc@public.gmane.org>
@ 2013-03-18 11:36       ` Matt Fleming
       [not found]         ` <1363606563.15011.333.camel-ZqTwcBeJ+wsBof6jY8KHXm7IUlhRatedral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
  0 siblings, 1 reply; 7+ messages in thread
From: Matt Fleming @ 2013-03-18 11:36 UTC (permalink / raw)
  To: David Woodhouse
  Cc: Dan Carpenter, matthew.garrett-05XSO3Yj/JvQT0dZR+AlfA,
	linux-efi-u79uwXL29TY76Z2rM5mHXA

On Fri, 2013-03-15 at 08:57 +0000, David Woodhouse wrote:
> On Fri, 2013-03-15 at 11:29 +0300, Dan Carpenter wrote:
> > Hello Matthew Garrett,
> > 
> > The patch dd5fc854de5f: "EFI: Stash ROMs if they're not in the PCI 
> > BAR" from Dec 5, 2012, leads to the following warning:
> > "arch/x86/boot/compressed/eboot.c:290 setup_efi_pci()
> > 	 error: potentially dereferencing uninitialized 'pci_handle'."
> > 
> >   254  static efi_status_t setup_efi_pci(struct boot_params *params)
> >   255  {
> >   256          efi_pci_io_protocol *pci;
> >   257          efi_status_t status;
> >   258          void **pci_handle;
> >   259          efi_guid_t pci_proto = EFI_PCI_IO_PROTOCOL_GUID;
> >   260          unsigned long nr_pci, size = 0;
> >   261          int i;
> >   262          struct setup_data *data;
> >   263  
> >   264          data = (struct setup_data *)(unsigned long)params->hdr.setup_data;
> >   265  
> >   266          while (data && data->next)
> >   267                  data = (struct setup_data *)(unsigned long)data->next;
> >   268  
> >   269          status = efi_call_phys5(sys_table->boottime->locate_handle,
> >   270                                  EFI_LOCATE_BY_PROTOCOL, &pci_proto,
> >   271                                  NULL, &size, pci_handle);
> >                                                     ^^^^^^^^^^
> > This hasn't been initialized yet.
> 
> True. It probably doesn't *matter* because the size is zero so the
> firmware is just going to ignore the pointer anyway. Although in that
> case I wonder why we couldn't have just passed NULL. Perhaps we expected
> that some firmware might do some validation on the pointer before
> getting to the size check?

I doubt that the firmware checks the validity of pci_handle when size is
zero, and I agree it's worth passing NULL to silence the warning (which
is also more explicit that just initialising pci_handle), unless Matthew
knows of a reason we shouldn't do that?

-- 
Matt Fleming, Intel Open Source Technology Center

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found]         ` <1363606563.15011.333.camel-ZqTwcBeJ+wsBof6jY8KHXm7IUlhRatedral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
@ 2013-03-18 16:02           ` Matthew Garrett
       [not found]             ` <1363622520.2553.8.camel-tCUS0Eywp2Pehftex57rkxo58HMYffqeLoYNBG0abjxeoWH0uzbU5w@public.gmane.org>
  0 siblings, 1 reply; 7+ messages in thread
From: Matthew Garrett @ 2013-03-18 16:02 UTC (permalink / raw)
  To: Matt Fleming
  Cc: David Woodhouse, Dan Carpenter,
	linux-efi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org

On Mon, 2013-03-18 at 11:36 +0000, Matt Fleming wrote:
> On Fri, 2013-03-15 at 08:57 +0000, David Woodhouse wrote:
> > True. It probably doesn't *matter* because the size is zero so the
> > firmware is just going to ignore the pointer anyway. Although in that
> > case I wonder why we couldn't have just passed NULL. Perhaps we expected
> > that some firmware might do some validation on the pointer before
> > getting to the size check?
> 
> I doubt that the firmware checks the validity of pci_handle when size is
> zero, and I agree it's worth passing NULL to silence the warning (which
> is also more explicit that just initialising pci_handle), unless Matthew
> knows of a reason we shouldn't do that?

No reason I can think of, and any failure will be pretty immediately
obvious.

-- 
Matthew Garrett | mjg59@srcf.ucam.org

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found]             ` <1363622520.2553.8.camel-tCUS0Eywp2Pehftex57rkxo58HMYffqeLoYNBG0abjxeoWH0uzbU5w@public.gmane.org>
@ 2013-03-20  8:44               ` Matt Fleming
       [not found]                 ` <514976F3.2-HNK1S37rvNbeXh+fF434Mdi2O/JbrIOy@public.gmane.org>
  2013-03-20  9:27               ` David Woodhouse
  1 sibling, 1 reply; 7+ messages in thread
From: Matt Fleming @ 2013-03-20  8:44 UTC (permalink / raw)
  To: Matthew Garrett
  Cc: David Woodhouse, Dan Carpenter,
	linux-efi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org

On 03/18/2013 04:02 PM, Matthew Garrett wrote:
> On Mon, 2013-03-18 at 11:36 +0000, Matt Fleming wrote:
>> On Fri, 2013-03-15 at 08:57 +0000, David Woodhouse wrote:
>>> True. It probably doesn't *matter* because the size is zero so the
>>> firmware is just going to ignore the pointer anyway. Although in that
>>> case I wonder why we couldn't have just passed NULL. Perhaps we expected
>>> that some firmware might do some validation on the pointer before
>>> getting to the size check?
>>
>> I doubt that the firmware checks the validity of pci_handle when size is
>> zero, and I agree it's worth passing NULL to silence the warning (which
>> is also more explicit that just initialising pci_handle), unless Matthew
>> knows of a reason we shouldn't do that?
> 
> No reason I can think of, and any failure will be pretty immediately
> obvious.

Anyone want to submit a patch?

-- 
Matt Fleming, Intel Open Source Technology Center

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found]                 ` <514976F3.2-HNK1S37rvNbeXh+fF434Mdi2O/JbrIOy@public.gmane.org>
@ 2013-03-20  9:09                   ` Dan Carpenter
  0 siblings, 0 replies; 7+ messages in thread
From: Dan Carpenter @ 2013-03-20  9:09 UTC (permalink / raw)
  To: Matt Fleming
  Cc: Matthew Garrett, David Woodhouse,
	linux-efi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org

On Wed, Mar 20, 2013 at 08:44:35AM +0000, Matt Fleming wrote:
> On 03/18/2013 04:02 PM, Matthew Garrett wrote:
> > On Mon, 2013-03-18 at 11:36 +0000, Matt Fleming wrote:
> >> On Fri, 2013-03-15 at 08:57 +0000, David Woodhouse wrote:
> >>> True. It probably doesn't *matter* because the size is zero so the
> >>> firmware is just going to ignore the pointer anyway. Although in that
> >>> case I wonder why we couldn't have just passed NULL. Perhaps we expected
> >>> that some firmware might do some validation on the pointer before
> >>> getting to the size check?
> >>
> >> I doubt that the firmware checks the validity of pci_handle when size is
> >> zero, and I agree it's worth passing NULL to silence the warning (which
> >> is also more explicit that just initialising pci_handle), unless Matthew
> >> knows of a reason we shouldn't do that?
> > 
> > No reason I can think of, and any failure will be pretty immediately
> > obvious.
> 
> Anyone want to submit a patch?
> 

Sure.  I'll send one tomorrow.

regards,
dan carpenter

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: EFI: Stash ROMs if they're not in the PCI BAR
       [not found]             ` <1363622520.2553.8.camel-tCUS0Eywp2Pehftex57rkxo58HMYffqeLoYNBG0abjxeoWH0uzbU5w@public.gmane.org>
  2013-03-20  8:44               ` Matt Fleming
@ 2013-03-20  9:27               ` David Woodhouse
  1 sibling, 0 replies; 7+ messages in thread
From: David Woodhouse @ 2013-03-20  9:27 UTC (permalink / raw)
  To: Matthew Garrett
  Cc: Matt Fleming, Dan Carpenter,
	linux-efi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org

[-- Attachment #1: Type: text/plain, Size: 1954 bytes --]

On Mon, 2013-03-18 at 16:02 +0000, Matthew Garrett wrote:
> On Mon, 2013-03-18 at 11:36 +0000, Matt Fleming wrote:
> > On Fri, 2013-03-15 at 08:57 +0000, David Woodhouse wrote:
> > > True. It probably doesn't *matter* because the size is zero so the
> > > firmware is just going to ignore the pointer anyway. Although in that
> > > case I wonder why we couldn't have just passed NULL. Perhaps we expected
> > > that some firmware might do some validation on the pointer before
> > > getting to the size check?
> > 
> > I doubt that the firmware checks the validity of pci_handle when size is
> > zero, and I agree it's worth passing NULL to silence the warning (which
> > is also more explicit that just initialising pci_handle), unless Matthew
> > knows of a reason we shouldn't do that?
> 
> No reason I can think of, and any failure will be pretty immediately
> obvious.

I agree with Matthew that I can think of no reason why a sane
implementation of EFI would ever actually dereference the pointer in
that case¹.

But there's an important difference in the way I phrased it...

I can't see why a *sane* implementation of EFI would do a lot of things.
Many of which have actually been seen in the field, much to our
distress.

So I'm starting to to think "hm, maybe we should give it a valid pointer
anyway, just in case".

Remember: Any sufficiently advanced incompetence is indistinguishable
from malice.

Assuming malice on the part of firmware authors is a fairly good way to
model their potential behaviour. So I'm perfectly prepared that someone
would ship an implementation which does *no* input checking, ever.
Except for gratuitously checking that particular pointer for NULL and
bailing out with an 'invalid parameters' error, even if the length was
zero.

-- 
dwmw2

¹ Although I haven't actually checked the spec to see if the pointer is
  required to be valid even when length is zero.



[-- Attachment #2: smime.p7s --]
[-- Type: application/x-pkcs7-signature, Size: 6171 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2013-03-20  9:27 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-03-15  8:29 EFI: Stash ROMs if they're not in the PCI BAR Dan Carpenter
     [not found] ` <20130315082928.GA14520-dZEljifmRObu9KfB+GxooP8+0UxHXcjY@public.gmane.org>
2013-03-15  8:57   ` David Woodhouse
     [not found]     ` <1363337872.2444.9.camel-Fexsq3y4057IgHVZqg5X0TlWvGAXklZc@public.gmane.org>
2013-03-18 11:36       ` Matt Fleming
     [not found]         ` <1363606563.15011.333.camel-ZqTwcBeJ+wsBof6jY8KHXm7IUlhRatedral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
2013-03-18 16:02           ` Matthew Garrett
     [not found]             ` <1363622520.2553.8.camel-tCUS0Eywp2Pehftex57rkxo58HMYffqeLoYNBG0abjxeoWH0uzbU5w@public.gmane.org>
2013-03-20  8:44               ` Matt Fleming
     [not found]                 ` <514976F3.2-HNK1S37rvNbeXh+fF434Mdi2O/JbrIOy@public.gmane.org>
2013-03-20  9:09                   ` Dan Carpenter
2013-03-20  9:27               ` David Woodhouse

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.