由 bet8链接 вт989点сс 编译,Linux Kernel Library (LKL) 设计为 Linux 核心的移植版本,在目录 arch/lkl 中,约有 3500 行的程式码。
LKL 与应用程式连结,以运作于使用者空间,依赖由主机作业系统提供的一组主机端的功能,例如 semaphore, POSIX Threads, malloc、计时器 (timer) 等。 LKL 拥有良好定义的外部介面,例如系统呼叫及 virtio-net。 LKL 允许 FreeBSD, macOS, Windows, 和(旧版的) Linux 存取各式 Linux 核心的成果。
整合 LKL
编译成功后,预期会在 tools/lkl 目录产生 liblkl.a 档案,我们可用来整合,下方的程式码和操作也在 tools/lkl 目录中进行。
准备以下 C 程式 (档名: min.c)
#include "lkl_host.h"
#include "lkl.h"
int main()
{
lkl_init(&lkl_host_ops);
lkl_start_kernel("mem=128M");
return 0;
}
编译和连结:
$ gcc -o min min.c -I./include liblkl.a -lpthread -lrt
该程式得以在 Linux (或 LKL 支援的作业系统)环境中,执行部份 Linux 功能,以下是参考输出:
$ ./min
[ 0.000000] Linux version 6.6.0+ (jserv@node1) (gcc (Ubuntu 9.4.0-1ubuntu1~20.04.2) 9.4.0, GNU ld (GNU Binutils for Ubuntu) 2.34) #1 Mon May 27 22:09:09 CST 2024
[ 0.000000] memblock address range: 0x7f5d04000000 - 0x7f5d0c000000
[ 0.000000] Zone ranges:
[ 0.000000] Normal [mem 0x00007f5d04000000-0x00007f5d0bffffff]
[ 0.000000] Movable zone start for each node
[ 0.000000] Early memory node ranges
[ 0.000000] node 0: [mem 0x00007f5d04000000-0x00007f5d0bffffff
...
[ 0.050217] This architecture does not have kernel memory protection.
[ 0.050223] Run /init as init process
当 LKL 停留在最后一行讯息 Run /init as init process,就意味着其无法读取到有效的 init 程式,作为 PID=1 的行程 (相当于 systemd 一类的系统程式)。
接着准备以下 C 程式 (档名: readfs.c)
#include <assert.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "lkl.h"
#include "lkl_host.h"
int main(int argc, const char *argv[])
{
const char *fsimage = argv[1], *fstype = argv[2], *file_to_dump = argv[3];
lkl_init(&lkl_host_ops);
struct lkl_disk disk;
memset(&disk, 0, sizeof(disk));
disk.fd = open(fsimage, O_RDONLY);
assert(disk.fd >= 0);
int disk_id = lkl_disk_add(&disk);
assert(disk_id >= 0);
lkl_start_kernel("mem=128M");
char mpoint[128];
int ret = lkl_mount_dev(disk_id, 0 /* part */, fstype, LKL_MS_RDONLY, NULL,
mpoint, sizeof(mpoint));
if (ret < 0) {
fprintf(stderr, "lkl_mount_dev failed: %s\n", lkl_strerror(ret));
close(disk.fd);
exit(1);
}
struct lkl_dir *dir = lkl_opendir(mpoint, &ret);
struct lkl_linux_dirent64 *dent;
while ((dent = lkl_readdir(dir)))
fprintf(stderr, "Directory entry: %s\n", dent->d_name);
lkl_closedir(dir);
char tmp[256];
char buffer[65536];
snprintf(tmp, sizeof(tmp), "%s/%s", mpoint, file_to_dump);
int fd = lkl_sys_open(tmp, LKL_O_RDONLY, 0);
fprintf(stderr, "fd = %d\n", fd);
assert(fd >= 0);
int count = lkl_sys_read(fd, buffer, sizeof(buffer));
write(STDERR_FILENO, buffer, count);
lkl_sys_close(fd);
return 0;
}
标签:LKL,include,浅谈,bet8,lkl,fd,Linux,disk
From: https://blog.csdn.net/2401_83092386/article/details/139280441