From: "Ilpo Järvinen" <ilpo.jarvinen@linux.intel.com>
To: Jorge Lopez <jorgealtxwork@gmail.com>
Cc: hdegoede@redhat.com, platform-driver-x86@vger.kernel.org,
LKML <linux-kernel@vger.kernel.org>,
thomas@t-8ch.de
Subject: Re: [PATCH v12 11/13] HP BIOSCFG driver - surestart-attributes
Date: Fri, 12 May 2023 17:12:14 +0300 (EEST) [thread overview]
Message-ID: <a8d1a232-d0f0-16ab-57a8-28e3b2f84@linux.intel.com> (raw)
In-Reply-To: <CAOOmCE9rNSJDbhoMgyEenog1CG6xG_cRoPNtYp--37DAi4iqsg@mail.gmail.com>
[-- Attachment #1: Type: text/plain, Size: 5929 bytes --]
On Fri, 12 May 2023, Jorge Lopez wrote:
> On Thu, May 11, 2023 at 4:32 AM Ilpo Järvinen
> <ilpo.jarvinen@linux.intel.com> wrote:
> >
> > On Wed, 10 May 2023, Jorge Lopez wrote:
> >
> > > On Tue, May 9, 2023 at 8:57 AM Ilpo Järvinen
> > > <ilpo.jarvinen@linux.intel.com> wrote:
> > > >
> > > > On Fri, 5 May 2023, Jorge Lopez wrote:
> > > >
> > > > > HP BIOS Configuration driver purpose is to provide a driver supporting
> > > > > the latest sysfs class firmware attributes framework allowing the user
> > > > > to change BIOS settings and security solutions on HP Inc.’s commercial
> > > > > notebooks.
> > > > >
> > > > > Many features of HP Commercial notebooks can be managed using Windows
> > > > > Management Instrumentation (WMI). WMI is an implementation of Web-Based
> > > > > Enterprise Management (WBEM) that provides a standards-based interface
> > > > > for changing and monitoring system settings. HP BIOSCFG driver provides
> > > > > a native Linux solution and the exposed features facilitates the
> > > > > migration to Linux environments.
> > > > >
> > > > > The Linux security features to be provided in hp-bioscfg driver enables
> > > > > managing the BIOS settings and security solutions via sysfs, a virtual
> > > > > filesystem that can be used by user-mode applications. The new
> > > > > documentation cover HP-specific firmware sysfs attributes such Secure
> > > > > Platform Management and Sure Start. Each section provides security
> > > > > feature description and identifies sysfs directories and files exposed
> > > > > by the driver.
> > > > >
> > > > > Many HP Commercial notebooks include a feature called Secure Platform
> > > > > Management (SPM), which replaces older password-based BIOS settings
> > > > > management with public key cryptography. PC secure product management
> > > > > begins when a target system is provisioned with cryptographic keys
> > > > > that are used to ensure the integrity of communications between system
> > > > > management utilities and the BIOS.
> > > > >
> > > > > HP Commercial notebooks have several BIOS settings that control its
> > > > > behaviour and capabilities, many of which are related to security.
> > > > > To prevent unauthorized changes to these settings, the system can
> > > > > be configured to use a cryptographic signature-based authorization
> > > > > string that the BIOS will use to verify authorization to modify the
> > > > > setting.
> > > > >
> > > > > Linux Security components are under development and not published yet.
> > > > > The only linux component is the driver (hp bioscfg) at this time.
> > > > > Other published security components are under Windows.
> > > > >
> > > > > Signed-off-by: Jorge Lopez <jorge.lopez2@hp.com>
> > > > >
> > > > > ---
> > > > > Based on the latest platform-drivers-x86.git/for-next
> > > > > ---
> > > > > + */
> > > > > + if (count * LOG_ENTRY_SIZE > PAGE_SIZE)
> > > > > + return -EIO;
> > > > > +
> > > > > + /*
> > > > > + * We are guaranteed the buffer is 4KB so today all the event
> > > > > + * logs will fit
> > > > > + */
> > > > > + for (i = 0; i < count; i++) {
> > > > > + audit_log_buffer[0] = (i + 1);
> > > > > +
> > > > > + /*
> > > > > + * read audit log entry at a time. 'buf' input value
> > > > > + * provides the audit log entry to be read. On
> > > > > + * input, Byte 0 = Audit Log entry number from
> > > > > + * beginning (1..254)
> > > > > + * Entry number 1 is the newest entry whereas the
> > > > > + * highest entry number (number of entries) is the
> > > > > + * oldest entry.
> > > > > + */
> > > > > + ret = hp_wmi_perform_query(HPWMI_SURESTART_GET_LOG,
> > > > > + HPWMI_SURESTART,
> > > > > + audit_log_buffer, 1, 128);
> > > > > +
> > > > > + if (ret >= 0 && (LOG_ENTRY_SIZE * i) < PAGE_SIZE) {
> > > >
> > > > Can the second condition ever fail?
> > > >
> > > Only in the event BIOS data is corrupted.
> >
> > i runs from 0 to count - 1 and you prevented count * LOG_ENTRY_SIZE >
> > PAGE_SIZE above. So what does the BIOS data have to do with that?
>
> BIOS guarantees the number of audit logs * LOG_ENTRY_SIZE will be less
> than 4K (PAGE_SIZE)
> Because Linux kernel trusts no one, we are checking that BIOS does not
> report more events than it should.
I know you're checking that.
What I'm trying to say that even after that check, your own code does not
trust that when i < count holds (as per the for loop termination
condition), i * LOG_ENTRY_SIZE < count * LOG_ENTRY_SIZE.
So what I'm trying to say is that this check:
&& (LOG_ENTRY_SIZE * i) < PAGE_SIZE
...is always true (and therefore unnecessary).
> WMI expects the input buffer to include the current audit log number
> (audit_log_buffer[0] = (i + 1);) which is i+1.
I don't see how this is relevant to what I was asking.
> > > > > + memcpy(buf, audit_log_buffer, LOG_ENTRY_SIZE);
> > > > > + buf += LOG_ENTRY_SIZE;
> > > > > + } else {
> > > > > + /*
> > > > > + * Encountered a failure while reading
> > > > > + * individual logs. Only a partial list of
> > > > > + * audit log will be returned.
> > > > > + */
> > > > > + count = i + 1;
> > > > > + break;
> > > > > + }
> > > >
> > > > Reverse order, do error handling with break first.
> > > Done!
> > > >
> > > > Why not return i * LOG_ENTRY_SIZE directly (or at the end), no need to
> > > > tweak count?
> > >
> > > Done!
> > > >
> > > > > + }
> > > > > +
> > > > > + return count * LOG_ENTRY_SIZE;
> > > > > +}
--
i.
next prev parent reply other threads:[~2023-05-12 14:12 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-05-05 22:00 [PATCH v12 00/13] HP BIOSCFG driver Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 01/13] HP BIOSCFG driver - Documentation Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 02/13] HP BIOSCFG driver - biosattr-interface Jorge Lopez
2023-05-08 14:31 ` Ilpo Järvinen
2023-05-08 20:59 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 03/13] HP BIOSCFG driver - bioscfg Jorge Lopez
2023-05-08 15:26 ` Ilpo Järvinen
2023-05-05 22:00 ` [PATCH v12 04/13] HP BIOSCFG driver - int-attributes Jorge Lopez
2023-05-08 14:45 ` Ilpo Järvinen
2023-05-08 21:33 ` Jorge Lopez
2023-05-09 10:24 ` Ilpo Järvinen
2023-05-10 19:01 ` Jorge Lopez
2023-05-08 21:16 ` Thomas Weißschuh
2023-05-09 21:23 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 05/13] HP BIOSCFG driver - ordered-attributes Jorge Lopez
2023-05-08 21:35 ` Thomas Weißschuh
2023-05-09 22:17 ` Jorge Lopez
2023-05-09 13:15 ` Ilpo Järvinen
2023-05-10 20:29 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 06/13] HP BIOSCFG driver - passwdobj-attributes Jorge Lopez
2023-05-09 12:34 ` Ilpo Järvinen
2023-05-10 20:10 ` Jorge Lopez
2023-05-11 9:09 ` Ilpo Järvinen
2023-05-11 13:52 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 07/13] HP BIOSCFG driver - string-attributes Jorge Lopez
2023-05-09 13:18 ` Ilpo Järvinen
2023-05-10 20:35 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 08/13] HP BIOSCFG driver - bioscfg-h Jorge Lopez
2023-05-06 7:15 ` Thomas Weißschuh
2023-05-08 15:36 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 09/13] HP BIOSCFG driver - enum-attributes Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 10/13] HP BIOSCFG driver - spmobj-attributes Jorge Lopez
2023-05-09 13:48 ` Ilpo Järvinen
2023-05-10 21:56 ` Jorge Lopez
2023-05-11 9:23 ` Ilpo Järvinen
2023-05-15 14:12 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 11/13] HP BIOSCFG driver - surestart-attributes Jorge Lopez
2023-05-09 13:57 ` Ilpo Järvinen
2023-05-10 22:13 ` Jorge Lopez
2023-05-11 9:32 ` Ilpo Järvinen
2023-05-12 13:54 ` Jorge Lopez
2023-05-12 14:12 ` Ilpo Järvinen [this message]
2023-05-12 15:34 ` Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 12/13] HP BIOSCFG driver - Makefile Jorge Lopez
2023-05-05 22:00 ` [PATCH v12 13/13] HP BIOSCFG driver - MAINTAINERS Jorge Lopez
2023-05-06 6:57 ` [PATCH v12 00/13] HP BIOSCFG driver Thomas Weißschuh
2023-05-08 14:05 ` Jorge Lopez
2023-05-08 20:42 ` Thomas Weißschuh
2023-05-08 20:48 ` Jorge Lopez
2023-05-08 20:57 ` Thomas Weißschuh
2023-05-08 21:02 ` Jorge Lopez
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=a8d1a232-d0f0-16ab-57a8-28e3b2f84@linux.intel.com \
--to=ilpo.jarvinen@linux.intel.com \
--cc=hdegoede@redhat.com \
--cc=jorgealtxwork@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=platform-driver-x86@vger.kernel.org \
--cc=thomas@t-8ch.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox