Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751684AbbKIPLK (ORCPT ); Mon, 9 Nov 2015 10:11:10 -0500 Received: from mail-wm0-f53.google.com ([74.125.82.53]:34838 "EHLO mail-wm0-f53.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750804AbbKIPLI convert rfc822-to-8bit (ORCPT ); Mon, 9 Nov 2015 10:11:08 -0500 MIME-Version: 1.0 In-Reply-To: <1670BE0E-C0E0-4D45-BF16-1FF60C298149@gmail.com> References: <1446582059-17355-1-git-send-email-octavian.purdila@intel.com> <1670BE0E-C0E0-4D45-BF16-1FF60C298149@gmail.com> Date: Mon, 9 Nov 2015 17:11:06 +0200 Message-ID: Subject: Re: [RFC PATCH 00/28] Linux Kernel Library From: Octavian Purdila To: yalin wang Cc: Richard Weinberger , Linux-Arch , LKML , Hajime Tazaki , "Richard W.M. Jones" Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3577 Lines: 90 On Sun, Nov 8, 2015 at 4:42 PM, yalin wang wrote: > > On Nov 4, 2015, at 07:06, Octavian Purdila > wrote: > > On Tue, Nov 3, 2015 at 11:40 PM, Richard Weinberger > wrote: > > Hi Richard, > > On Tue, Nov 3, 2015 at 9:20 PM, Octavian Purdila > wrote: > > LKL (Linux Kernel Library) is aiming to allow reusing the Linux kernel code > as extensively as possible with minimal effort and reduced maintenance > overhead. > > Examples of how LKL can be used are: creating userspace applications > (running on Linux and other operating systems) that can read or write Linux > filesystems or can use the Linux networking stack, creating kernel drivers > for other operating systems that can read Linux filesystems, bootloaders > support for reading/writing Linux filesystems, etc. > > With LKL, the kernel code is compiled into an object file that can be > directly linked by applications. The API offered by LKL is based on the > Linux system call interface. > > LKL is implemented as an architecture port in arch/lkl. It relies on host > operations defined by the application or a host library (tools/lkl/lib). > > The latest LKL version can be found at git@github.com:lkl/linux.git > > > Or more copy&paste friendly: https://github.com/lkl/linux.git > > FAQ > === > > Q: How is LKL different from UML? > A: UML provides a full OS environment (e.g. user/kernel separation, user > processes) and also has requirements (a filesystem, processes, etc.) that > makes it hard to use it for standalone applications. UML also relies > heavily on Linux hosts. On the other hand LKL is designed to be linked > directly with the application and hence does not have user/kernel > separation which makes it easier to use it in standalone applications. > > > So, this is a "liblinux" where applications are directly linked > against the kernel. > IOW system calls are plain function calls into the kernel? > > > More like "thread" calls. All system calls are executed in a dedicate > (kernel) thread to avoid race conditions with the "interrupt" path. > > why not call sys_XXX() function directly? > since kernel have implement lots of spin_locks to avoid race with normal > path > in IRQ handle , isn’t it ? > for example, you timer IRQ can be simulated by SIGALARM signal, > and the signal handler can check if IRQ is disabled , > if not , then continuing , otherwise , return directly .. > it is not safe ? > Hi Yalin, We need to have a proper Linux context in order to issue system calls (e.g. current needs to point to a proper Linux kernel thread_struct). We also want to let the Linux scheduler to select what kernel threads run at a given time. Lets say that currently a ksoftirqd runs and the application want to issue a system call. In this case we want to wait for ksoftirqd to complete then run the system call. The simplest way I found to do that is to have the system calls execute from Linux kernel threads hence the need to queue the system calls from the application thread to the Linux kernel system call thread. (BTW, we can have multiple system call threads if needed and the 2.6 implementation has that, but in order to simplify the review process I decided to throw away that for the moment). Thanks, Tavi -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/