efi的sys文件系统接口
来源:互联网 发布:淘宝连接转口令 编辑:程序博客网 时间:2024/05/22 08:20
在driver/firmware/efi/efi.c 中通过subsys_initcall(efisubsys_init);来初始化efisubsys
static int __init efisubsys_init(void)
{
int error;
if (!efi_enabled(EFI_BOOT))
return 0;
/* We register the efi directory at /sys/firmware/efi */
efi_kobj = kobject_create_and_add("efi", firmware_kobj);
if (!efi_kobj) {
pr_err("efi: Firmware registration failed.\n");
return -ENOMEM;
}
error = generic_ops_register();
if (error)
goto err_put;
if (efi_enabled(EFI_RUNTIME_SERVICES))
efivar_ssdt_load();
error = sysfs_create_group(efi_kobj, &efi_subsys_attr_group);
if (error) {
pr_err("efi: Sysfs attribute export failed with error %d.\n",
error);
goto err_unregister;
}
error = efi_runtime_map_init(efi_kobj);
if (error)
goto err_remove_group;
/* and the standard mountpoint for efivarfs */
error = sysfs_create_mount_point(efi_kobj, "efivars");
if (error) {
pr_err("efivars: Subsystem registration failed.\n");
goto err_remove_group;
}
}
在efisubsys_init 中会通过kobject_create_and_add在/sys/firmware/下建立efi的目录,然后会通过sysfs_create_group来efi_subsys_attr_group group
static struct attribute_group efi_subsys_attr_group = {
.attrs = efi_subsys_attrs,
.is_visible = efi_attr_is_visible,
};
继续看efi_subsys_attrs
static struct attribute *efi_subsys_attrs[] = {
&efi_attr_systab.attr,
&efi_attr_fw_vendor.attr,
&efi_attr_runtime.attr,
&efi_attr_config_table.attr,
&efi_attr_fw_platform_size.attr,
NULL,
};
在efisubsys_init 中通过sysfs_create_mount_point 来创建efivars的mountpoint。
而efi_runtime_map_init 则为每一段efi.memmap 创建sys接口,而所有的接口都是放在map_entries 这个list中
int __init efi_runtime_map_init(struct kobject *efi_kobj)
{
int i, j, ret = 0;
struct efi_runtime_map_entry *entry;
efi_memory_desc_t *md;
if (!efi_enabled(EFI_MEMMAP))
return 0;
map_entries = kzalloc(efi.memmap.nr_map * sizeof(entry), GFP_KERNEL);
if (!map_entries) {
ret = -ENOMEM;
goto out;
}
i = 0;
for_each_efi_memory_desc(md) {
entry = add_sysfs_runtime_map_entry(efi_kobj, i, md);
if (IS_ERR(entry)) {
ret = PTR_ERR(entry);
goto out_add_entry;
}
*(map_entries + i++) = entry;
}
return 0;
out_add_entry:
for (j = i - 1; j >= 0; j--) {
entry = *(map_entries + j);
kobject_put(&entry->kobj);
}
out:
return ret;
}
因此实际我们可以看到如下:
[root@CentOS efi]# pwd
/sys/firmware/efi
[root@CentOS efi]# ls
efivars fw_platform_size systab vars
static int __init efisubsys_init(void)
{
int error;
if (!efi_enabled(EFI_BOOT))
return 0;
/* We register the efi directory at /sys/firmware/efi */
efi_kobj = kobject_create_and_add("efi", firmware_kobj);
if (!efi_kobj) {
pr_err("efi: Firmware registration failed.\n");
return -ENOMEM;
}
error = generic_ops_register();
if (error)
goto err_put;
if (efi_enabled(EFI_RUNTIME_SERVICES))
efivar_ssdt_load();
error = sysfs_create_group(efi_kobj, &efi_subsys_attr_group);
if (error) {
pr_err("efi: Sysfs attribute export failed with error %d.\n",
error);
goto err_unregister;
}
error = efi_runtime_map_init(efi_kobj);
if (error)
goto err_remove_group;
/* and the standard mountpoint for efivarfs */
error = sysfs_create_mount_point(efi_kobj, "efivars");
if (error) {
pr_err("efivars: Subsystem registration failed.\n");
goto err_remove_group;
}
}
在efisubsys_init 中会通过kobject_create_and_add在/sys/firmware/下建立efi的目录,然后会通过sysfs_create_group来efi_subsys_attr_group group
static struct attribute_group efi_subsys_attr_group = {
.attrs = efi_subsys_attrs,
.is_visible = efi_attr_is_visible,
};
继续看efi_subsys_attrs
static struct attribute *efi_subsys_attrs[] = {
&efi_attr_systab.attr,
&efi_attr_fw_vendor.attr,
&efi_attr_runtime.attr,
&efi_attr_config_table.attr,
&efi_attr_fw_platform_size.attr,
NULL,
};
在efisubsys_init 中通过sysfs_create_mount_point 来创建efivars的mountpoint。
而efi_runtime_map_init 则为每一段efi.memmap 创建sys接口,而所有的接口都是放在map_entries 这个list中
int __init efi_runtime_map_init(struct kobject *efi_kobj)
{
int i, j, ret = 0;
struct efi_runtime_map_entry *entry;
efi_memory_desc_t *md;
if (!efi_enabled(EFI_MEMMAP))
return 0;
map_entries = kzalloc(efi.memmap.nr_map * sizeof(entry), GFP_KERNEL);
if (!map_entries) {
ret = -ENOMEM;
goto out;
}
i = 0;
for_each_efi_memory_desc(md) {
entry = add_sysfs_runtime_map_entry(efi_kobj, i, md);
if (IS_ERR(entry)) {
ret = PTR_ERR(entry);
goto out_add_entry;
}
*(map_entries + i++) = entry;
}
return 0;
out_add_entry:
for (j = i - 1; j >= 0; j--) {
entry = *(map_entries + j);
kobject_put(&entry->kobj);
}
out:
return ret;
}
因此实际我们可以看到如下:
[root@CentOS efi]# pwd
/sys/firmware/efi
[root@CentOS efi]# ls
efivars fw_platform_size systab vars
0 0
- efi的sys文件系统接口
- sys文件系统下的接口函数
- cpu topology sys文件系统接口
- 应用程序访问内核的新接口/sys文件系统
- linux驱动层到应用层的重要接口sys文件系统---/sys目录详解
- sys文件系统
- sys文件系统
- EFI接口详解
- /sys 文件系统下的目录结构
- sys文件系统总结,,
- 什么是sys文件系统
- proc sys文件系统对比
- proc sys文件系统对比
- Sys文件系统分析
- Linux sys文件系统
- linux /sys文件系统介绍
- 什么是sys文件系统
- /sys文件系统概述
- java设计模式之建造者模式
- javascript基础(DOM查询)(二十六)
- Please ensure that adb is correctly located at……问题解决方案
- PL/SQL如何修改ORACLE序列位置
- refresh的停车场
- efi的sys文件系统接口
- Python安装
- 【推荐】Github优秀开发者
- am5728 uboot 添加usb 网卡
- mongodb client
- centos 7上搭建原版 Minecraft 服务器
- java学习3-学习一门语言一般知识点
- 【初等概率论】 03
- mysql数据库查询SQL语句总结