Re: [PATCH v12] firmware: google: Implement cbmem in sysfs driver

From: Jack Rosenthal
Date: Tue Oct 04 2022 - 12:57:09 EST


On 2022-10-04 at 10:51 +0200, Greg KH wrote:
> > + A list of ids known to Coreboot can be found in the coreboot
> > + source tree at
> > + ``src/commonlib/bsd/include/commonlib/bsd/cbmem_id.h``.
>
> That will not age well, why not point to the reference in the kernel
> tree instead?

There is no copy in the kernel tree.

> > +What: /sys/bus/coreboot/devices/cbmem-<id>/address
> > +Date: August 2022
> > +Contact: Jack Rosenthal <jrosenth@xxxxxxxxxxxx>
> > +Description:
> > + This is the pyhsical memory address that the CBMEM entry's data
> > + begins at.
>
> In hex? Decimal?
>
> > +
> > +What: /sys/bus/coreboot/devices/cbmem-<id>/size
> > +Date: August 2022
> > +Contact: Jack Rosenthal <jrosenth@xxxxxxxxxxxx>
> > +Description:
> > + This is the size of the CBMEM entry's data.
>
> In hex? Decimal? Octal? Binary? Be specific please :)

Added "hexadecimal" and an example for both in v13.

> > +What: /sys/bus/coreboot/devices/cbmem-<id>/id
> > +Date: August 2022
> > +Contact: Jack Rosenthal <jrosenth@xxxxxxxxxxxx>
> > +Description:
> > + This is the CBMEM id corresponding to the entry.
>
> so "id" is the same as "<id>" here? Why is that needed?

Removed in v13, agreee it's reduntant with the device name now.

> > + Say Y here to enable the kernel to search for Coreboot CBMEM
> > + entries, and expose the memory for each entry in sysfs under
> > + /sys/bus/coreboot/devices/cbmem-<id>.
>
> Module name?

Added in v13.

>
> > +
> > config GOOGLE_COREBOOT_TABLE
> > tristate "Coreboot Table Access"
> > depends on HAS_IOMEM && (ACPI || OF)
> > diff --git a/drivers/firmware/google/Makefile b/drivers/firmware/google/Makefile
> > index d17caded5d88..8151e323cc43 100644
> > --- a/drivers/firmware/google/Makefile
> > +++ b/drivers/firmware/google/Makefile
> > @@ -7,5 +7,8 @@ obj-$(CONFIG_GOOGLE_MEMCONSOLE) += memconsole.o
> > obj-$(CONFIG_GOOGLE_MEMCONSOLE_COREBOOT) += memconsole-coreboot.o
> > obj-$(CONFIG_GOOGLE_MEMCONSOLE_X86_LEGACY) += memconsole-x86-legacy.o
> >
> > +# Must come after coreboot_table.o, as this driver depends on that bus type.
>
> Doesn't the linker handle this for us?

Not in the case of compiling as a built-in module: I observed in this
scenario the order in the Makefile deterimined the module initialization
order, and, if this were to be listed alphabetically, the coreboot_table
module would not have been loaded before the cbmem module.

> > + entry->size = dev->cbmem_entry.entry_size;
>
> Ah nevermind you set the size here.

The size that stat reports is still 0, as when creating this as a device
attribute, the size is not known until the driver is probed. I observed
this in some other sysfs attributes, so I imagine it's a common pattern.

> > +/* Corresponds to LB_TAG_CBMEM_ENTRY */
> > +struct lb_cbmem_entry {
> > + u32 tag;
> > + u32 size;
>
> little or big endian?

It's the native host endianness, as coreboot wrote these tables from the
same CPU that Linux is running on.