android系列-init 挂载文件系统

1.init 挂载文件系统 

//android10\system\core\init\main.cpp

int main(int argc, char** argv) {

    return FirstStageMain(argc, argv);
}
//android10\system\core\init\first_stage_init.cpp

int FirstStageMain(int argc, char** argv) {
    
    CHECKCALL(mount("tmpfs", "/dev", "tmpfs", MS_NOSUID, "mode=0755"));

    CHECKCALL(mount("devpts", "/dev/pts", "devpts", 0, NULL));

    CHECKCALL(mount("proc", "/proc", "proc", 0, "hidepid=2,gid=" MAKE_STR(AID_READPROC)));

    CHECKCALL(mount("sysfs", "/sys", "sysfs", 0, NULL));

    CHECKCALL(mount("selinuxfs", "/sys/fs/selinux", "selinuxfs", 0, NULL));
}

2.tmpfs文件系统

(来自chatgpt的回答)

在Android系统中,`tmpfs` 是一个临时文件系统,通常用于临时存储数据。`tmpfs` 把数据存储在内存中,而不是存储在磁盘上。这样的设计使得对数据的读写速度非常快,但也意味着数据不会在设备重启时保留。

在 Android 中,`tmpfs` 主要用于 `/dev` 和 `/tmp` 这样的目录,以及一些临时文件的存储。这有助于提高临时数据的访问速度,例如在应用程序运行时创建的临时文件。

请注意,`tmpfs` 不是持久的存储解决方案,因此不适合用于需要在设备重启后仍然保留的数据。如果你需要持久存储数据,你可能需要考虑使用其他文件系统,例如 Ext4 或 F2FS,它们通常用于设备的持久性存储。

3.devpts文件系统

(来自chatgpt的回答)

在 Android 中,`devpts` 是一个伪终端文件系统,用于提供终端功能。这个文件系统负责创建和管理伪终端设备,以便支持终端应用程序、shell 进程以及与终端相关的交互。`devpts` 在 Android 系统中的作用与其在标准 Linux 系统中的作用类似。

在 Android 设备上,`devpts` 文件系统通常被挂载到 `/dev/pts` 目录。你可以使用以下命令来查看当前挂载的文件系统:

cat /proc/mounts | grep devpts

这将显示挂载的 `devpts` 文件系统的相关信息,包括挂载点(通常是 `/dev/pts`)、文件系统类型等。

伪终端设备是在 `/dev/pts` 目录下创建的,每个终端设备都对应一个文件,例如 `/dev/pts/0`、`/dev/pts/1` 等。这些设备文件允许终端应用程序与系统进行通信,执行命令行操作,以及与 shell 进程进行交互。

`devpts` 文件系统的存在使得在 Android 系统中能够进行命令行交互,例如通过终端模拟器应用或通过 ADB(Android Debug Bridge)连接到设备的命令行。这对于开发、调试和系统管理等方面是非常有用的。

4.proc文件系统

(来自chatgpt的回答)

在 Android 操作系统中,`/proc` 是一个虚拟文件系统,它提供了对内核和系统信息的访问。这个文件系统并不存储在磁盘上,而是由内核动态生成,用于向用户空间提供有关系统状态、进程信息和其他内核参数的实时数据。

在 `/proc` 文件系统中,你可以找到一系列文件和子目录,每个都包含有关系统或进程的信息。以下是一些常见的内容:

1. **/proc/cpuinfo:** 包含有关 CPU 的信息,如型号、架构、频率等。

2. **/proc/meminfo:** 提供有关内存使用情况的信息,包括总内存、空闲内存、缓冲区和缓存等。

3. **/proc/version:** 包含 Linux 内核的版本信息。

4. **/proc/sys:** 包含系统参数,例如内核参数和网络设置。这是一个可以用于读写内核参数的目录。

5. **/proc/:** 包含有关指定进程的信息,其中 `` 是进程的标识符。

在 Android 开发和系统调试中,开发者经常使用 `/proc` 文件系统来查看系统的运行状态、调试性能问题,以及了解进程的详细信息。例如,通过读取 `/proc/cpuinfo`,你可以获取有关设备上的 CPU 信息,通过读取 `/proc/meminfo`,你可以查看内存的使用情况。

注意,`/proc` 文件系统的内容可能因 Android 版本和设备而异,而不是所有的文件和信息都对应着实际的物理存储。这是一个动态生成的虚拟文件系统,它提供了一种方便的方式来获取系统和内核的运行时信息。

5.sys文件系统

(来自chatgpt的回答)

在 Android 操作系统中,`sysfs` 是一个虚拟文件系统,提供了对内核参数和硬件设备的信息的访问。与 `/proc` 文件系统类似,`sysfs` 也是一个用于与内核交互的接口。这个文件系统通常挂载在 `/sys` 目录下。

以下是一些 `sysfs` 中常见的内容:

1. **/sys/class:** 包含设备类别相关的信息,比如输入设备、网络设备等。

2. **/sys/block:** 包含块设备(如磁盘和分区)的信息。

3. **/sys/bus:** 包含总线类型相关的信息,如 USB、PCI 等。

4. **/sys/devices:** 包含系统中所有设备的信息。

5. **/sys/kernel:** 包含与内核相关的信息,如调试、参数等。

通过访问 `sysfs`,开发者可以获取关于设备和内核的运行时信息,以及对一些内核参数进行调整。这对于 Android 系统的开发和调试非常有用。

举例来说,你可以在 `/sys/class/backlight` 中找到有关设备亮度的信息,或者在 `/sys/class/net` 中找到有关网络接口的信息。这些信息可以用于调整设备的行为,进行性能优化,或者用于调试目的。

需要注意的是,`sysfs` 提供的接口可以因 Android 版本、设备型号和内核配置而异,因此在使用时应当仔细查阅相关文档,确保了解所使用 Android 版本和设备的特定细节。

6.selinuxfs文件系统

(来自chatgpt的回答)

在 Android 操作系统中,`selinuxfs`(Security-Enhanced Linux File System)是用于 SELinux(Security-Enhanced Linux)的虚拟文件系统。SELinux是一种强制访问控制(MAC)机制,用于增强Linux系统的安全性。

`selinuxfs` 通常挂载在 `/sys/fs/selinux` 目录下,提供了与 SELinux 相关的信息和控制接口。这个文件系统包含一系列文件和目录,用于配置和管理 SELinux 的策略。

以下是一些常见的 `selinuxfs` 内容:

1. **/sys/fs/selinux/enforce:** 该文件用于控制 SELinux 的强制模式。写入 `0` 可以切换到宽松模式,写入 `1` 可以切换到强制模式。

2. **/sys/fs/selinux/policy:** 该文件包含当前 SELinux 策略的二进制表示。

3. **/sys/fs/selinux/load:** 通过将 SELinux 策略的二进制表示写入此文件,可以加载新的 SELinux 策略。

4. **/sys/fs/selinux/contexts:** 包含默认的 SELinux 上下文配置。

通过访问 `selinuxfs`,Android 系统和应用程序可以与 SELinux 交互,查询当前的 SELinux 配置,加载新的策略,以及控制 SELinux 强制模式。

SELinux 在 Android 中被广泛使用,它通过强制访问控制帮助保护系统免受恶意应用程序和攻击。开发者和系统管理员可能需要在特定情况下使用 `selinuxfs` 进行配置和管理 SELinux 的运行时行为。需要注意的是,对于一般用户和应用程序来说,通常无需直接操作 `selinuxfs`。

(看不懂,也记不住 /(ㄒoㄒ)/~~)

你可能感兴趣的:(Android,android)