首页 > 系统相关 >bet8链接:浅谈LKL对Linux和新的成果

bet8链接:浅谈LKL对Linux和新的成果

时间:2024-05-28 23:32:51浏览次数:31  
标签:LKL include 浅谈 bet8 lkl fd Linux disk

由 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

相关文章

  • 浅谈C++函数
    目录一、函数的概念二、调用函数的两个前提三、函数传参的三种形式四、函数返回类型一、函数的概念函数是C++程序的基本模块,通常一个C++程序由一个或多个函数组成。函数可以完成用户指定的任务,一般分为库函数和用户自定义的函数。函数由函数头和函数体组成,函数头中包......
  • Java中继承与接口的区别(浅谈)
    在Java中,继承和接口是两种不同的方式来实现代码的复用和扩展。以下是它们之间的主要区别:1.继承:继承是面向对象编程中的一种方式,允许一个类继承另一个类的属性和方法。继承的主要目的是为了实现代码的复用,即子类可以继承父类的属性和方法,从而避免重复编写相同的代码。此外,继......
  • 浅谈一下C#和java的线程不同点
    C#和Java在线程处理方面有一些显著的区别,这些区别主要体现在线程的创建、管理和生命周期控制上。以下是一些主要的区别:线程的创建和管理Java:Java中线程的创建通常是通过继承Thread类或实现Runnable接口来实现的。Java提供了线程组(ThreadGroup)的概念,允许将线程组织在一起......
  • 浅谈C#中取消令牌CancellationTokenSource
    基础操作CancellationTokenSourcecancellationTokenSource=newCancellationTokenSource();cancellationTokenSource.Token.Register(()=>{Console.WriteLine("取消了1111");});......
  • 「网络流浅谈」最小割的模型
    最大权闭合子图引入Introduction闭合子图指对于子图\(G=(V,E)\),\(\forallu\inV,(u,v)\inE\),都有\(v\inV\)。最大权闭合子图无非就是对于所有的闭合子图\(G\)中\(\sum_{u\inV}w_u\)最大的闭合子图。对于这个图中,闭合子图有哪些呢?红色框圈画出的即为\(1\)个......
  • weblogic漏洞浅谈
    weblogic反序列化漏洞原理分析weblogic是oracle公司出品的applicationserver,用于本地和云端开发,集成,部署和大型分布式web应用,网络应用和数据库应用的Java应用服务器weblogicserver是一个基于JAVAEE架构的中间件,将java的动态功能和javaEnterprise标准的安全性引入大型网络应用......
  • 浅谈 FHQ Treap
    浅谈FHQTreap目录浅谈FHQTreap简单介绍前置操作结构分裂split合并merge一般操作Insertdelete查询排名为\(x\)的数查询\(v\)的排名rank查询\(x\)的前驱precursor查询\(x\)的后继successor版题简单介绍FHQTreap,以下简写为\(fhq\),是一种treap(树堆)的变体,功能......
  • 「网络流浅谈」最小割的模型 1
    最大权闭合子图引入闭合子图指对于子图\(G=(V,E)\),\(\forallu\inV,(u,v)\inE\),都有\(v\inV\)。最大权闭合子图无非就是对于所有的闭合子图\(G\)中\(\sum_{u\inV}w_u\)最大的闭合子图。对于这个图中,闭合子图有哪些呢?红色框圈画出的即为\(1\)个闭合子图,因为......
  • 「网络流浅谈」最大流的应用
    二分图匹配考虑如何将二分图匹配问题,转化为流网络。设置\(1\)个汇点和源点,从源点向二分图一侧的每一个点连边,从另一侧向汇点连边,边权均为\(1\),二分图中的边也全部加入,权值设为\(1\)。这样,二分图的最大匹配等于流网络的最大流。P2756飞行员配对方案问题题意:给定\(1\)个二......
  • 浅谈Vue.js与原生开发
    在现代的Web开发中,前端框架的选择是至关重要的。Vue.js作为一款流行的前端框架,与传统的原生开发相比,有许多明显的区别。模版语法与HTMLVue.js使用特殊的模板语法来创建动态视图,这样开发者可以更方便地表达复杂的逻辑。通过指令(例如v-if、v-for等)和模板表达式,Vue.js简化了数据的......