Re: [PATCH 2/2] efi: Capsule update support

From: Sam Protsenko
Date: Tue Oct 14 2014 - 11:30:44 EST


Matt,

I tried to play with your code and now I have some extra notes about this patch:

1. As it was proposed earlier, I support thought that it would be nice to
rename function names in next way:

efi_update_capsule -> __efi_update_capsule
efi_capsule_update -> efi_update_capsule

because it's quite confusing to have both efi_update_capsule() and
efi_capsule_update(). Besides, EFI function called UpdateCapsule, so it's
good idea to stick to this name in kernel API (I mean exporting
efi_update_capsule() instead of efi_capsule_update()).

2. UEFI's UpdateCapsule() runtime service supports passing more than one
capsule to it (we can pass CapsuleCount argument to it for this purpose).
But your particular kernel implementation allows us only to provide one
capsule at a time. Is that was done for a reason? Can it be consider as
shortcoming?

3. I noticed that you dropped efi_capsule_build() in this patch (w.r.t.
https://git.kernel.org/cgit/linux/kernel/git/mfleming/efi.git/
implementation). BTW, it should be declared in header there.
Anyway, how do we suppose to build capsule to pass to efi_capsule_update()?
I mean, it can take a quite large code to build a capsule (allocating pages
etc). Wouldn't it be easier to user to use your API if it has something
ready to use? Anyway, if it should be done like this, it would be nice
to have a decent example code (use-case) how to use this API (maybe in
Documentation/, idk), because it looks quite non-intuitive (for me at least).

4. Tedious stuff: I checked your patch with "checkpatch.pl" and it shows
some warnings, please fix them if possible.

I will try to test and verify this patch further, will notify you if
notice any issues.


On 13 October 2014 18:43, Sam Protsenko <semen.protsenko@xxxxxxxxxx> wrote:
>> When I originally wrote this patch in 2013 arm64 support didn't exist,
>> and ia64 isn't going to be using capsule support. I can separate that
>> out into a separate patch though, no problem.
>
> For me it's just the matter of good VCS practices. In this case I call
> this "patch atomicity" (one patch per feature). It's not about your
> patch particularly, it's just policy. In the end it boils down to next
> two things:
> 1. Separating common code from platform code makes it easier to use
> "git bisect" in case of regressions.
> 2. This way if we want to revert patch, we can revert only stuff we
> want, not touching another part (e.g. you want to revert platform
> code, you can keep common code in place).
>
>> Next time, could you please quote the part of the patch you're
>> commenting on inline? That would have saved me searching through the
>> original email.
>
> Sure, my bad. I know it's general approach in mailing lists to review
> patch, just forgot it.
>
>
> On 13 October 2014 12:53, Matt Fleming <matt@xxxxxxxxxxxxxxxxx> wrote:
>> On Fri, 10 Oct, at 06:55:49PM, Sam Protsenko wrote:
>>> Hi Matt,
>>>
>>> 1. Why x86 code isn't separated to another patch?
>>
>> When I originally wrote this patch in 2013 arm64 support didn't exist,
>> and ia64 isn't going to be using capsule support. I can separate that
>> out into a separate patch though, no problem.
>>
>>> 2. drivers/firmware/efi/reboot.c: efi_reboot():
>>> One shouldn't use "printk()" with no KERN_* stuff passed into it.
>>> I'd recommend to use "pr_info()" macro or something like that.
>>
>> Oops, I missed that, good catch.
>>
>> Next time, could you please quote the part of the patch you're
>> commenting on inline? That would have saved me searching through the
>> original email.
>>
>> --
>> Matt Fleming, Intel Open Source Technology Center
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/