On Tue, Dec 05, 2017 at 09:25:07AM +0000, Ard Biesheuvel wrote: > On 5 December 2017 at 08:52, Greg Kroah-Hartman > <gregkh@xxxxxxxxxxxxxxxxxxx> wrote: > > On Tue, Dec 05, 2017 at 04:45:37PM +0800, Dave Young wrote: > >> On 12/05/17 at 09:09am, Greg Kroah-Hartman wrote: > >> > On Tue, Dec 05, 2017 at 01:14:34PM +0800, Dave Young wrote: > >> > > On 12/04/17 at 03:00pm, Greg Kroah-Hartman wrote: > >> > > > On Mon, Dec 04, 2017 at 12:51:13PM +0000, David Laight wrote: > >> > > > > From: Ard Biesheuvel > >> > > > > > Sent: 04 December 2017 10:03 > >> > > > > ... > >> > > > > > and uses __ATTR_RO() to emit initializers for it. __ATTR() initializes > >> > > > > > the .store member as well, which does not exists, and so it cannot be > >> > > > > > used directly. > >> > > > > > > >> > > > > > So we should either add a .store member that is always NULL, or we > >> > > > > > should add our own > >> > > > > > > >> > > > > > #define __ATTR_0400(_name) { \ > >> > > > > > .attr = { .name = __stringify(_name), .mode = 0400 }, \ > >> > > > > > .show = _name##_show, \ > >> > > > > > } > >> > > > > > >> > > > > What about an __ATTR_RO_MODE(name, mode) that doesn't set the .store member. > >> > > > > Even if the mode allowed write, writes wouldn't happen. > >> > > > > >> > > > Ah, that might work, could you convert the other users of __ATTR() in > >> > > > the efi code to use it as well? > >> > > > >> > > $ grep __ATTR * -RI > >> > > efi.c: __ATTR(systab, 0400, systab_show, NULL); > >> > > efi.c:static struct kobj_attribute efi_attr_fw_vendor = __ATTR_RO(fw_vendor); > >> > > efi.c:static struct kobj_attribute efi_attr_runtime = __ATTR_RO(runtime); > >> > > efi.c:static struct kobj_attribute efi_attr_config_table = __ATTR_RO(config_table); > >> > > efi.c: __ATTR_RO(fw_platform_size); > >> > > esrt.c:static struct esre_attribute esre_fw_class = __ATTR(fw_class, 0400, > >> > > esrt.c:static struct esre_attribute esre_##name = __ATTR(name, 0400, \ > >> > > esrt.c:static struct kobj_attribute esrt_##name = __ATTR(name, 0400, \ > >> > > runtime-map.c:static struct map_attribute map_type_attr = __ATTR_RO(type); > >> > > runtime-map.c:static struct map_attribute map_phys_addr_attr = __ATTR_RO(phys_addr); > >> > > runtime-map.c:static struct map_attribute map_virt_addr_attr = __ATTR_RO(virt_addr); > >> > > runtime-map.c:static struct map_attribute map_num_pages_attr = __ATTR_RO(num_pages); > >> > > runtime-map.c:static struct map_attribute map_attribute_attr = __ATTR_RO(attribute); > >> > > > >> > > Above is all the __ATTR users for drivers/firmware/efi/*, it makes sense > >> > > to update all __ATTR_RO to __ATTR_RO_MODE, so efi.c, runtime-map.c, and > >> > > drivers/firmware/dmi-sysfs.c can be updated. But esrt.c __ATTR seems > >> > > not necessary. > >> > > > >> > > And if so __ATTR_RO_MODE(name, mode) still needs go to sysfs.h. > >> > > > >> > > I can do it but need confirm, Is this what you prefer? > >> > > >> > Yes, how about the patch below, it builds for me, haven't done anything > >> > other than that to test it :) > >> > >> Thanks! Let me do a kexec test and a boot test for esrt. > >> > >> > > >> > Also, what's with the multi-line sysfs file systab? That's really not > >> > allowed, can you please remove it? Also the first check for !kobj and > >> > !buf is funny, that can never happen. > >> > >> I thought to do that, but later worried about it will break things: > >> http://lists.infradead.org/pipermail/kexec/2013-December/010759.html > > > > Heh, I guess I complained about this in the past :) > > > > So what userspace tool uses it? > > > > On x86, it is mostly tools that read DMI tables via /dev/mem, and use > /sys/firmware/efi/systab to locate them. dmidecode, lscpu, etc > > That does mean we could investigate which entries are actually used, > and at least start removing the ones we don't need. That would be good to do. Also, the data there is already covered by other sysfs files, right? If not, you should add that as individual files first. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-efi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html