zoukankan      html  css  js  c++  java
  • BionicThe README from the bionic/libc

    Welcome to Bionic, Android's small and custom C library for the Android
    platform.

    Bionic is mainly a port of the BSD C library to our Linux kernel with the
    following additions/changes:

    - no support for locales
    - no support for wide chars (i.e. multi-byte characters)
    - its own smallish implementation of pthreads based on Linux futexes
    - support for x86, ARM and ARM thumb CPU instruction sets and kernel interfaces

    Bionic is released under the standard 3-clause BSD License

    Bionic doesn't want to implement all features of a traditional C library, we only
    add features to it as we need them, and we try to keep things as simple and small
    as possible. Our goal is not to support scaling to thousands of concurrent threads
    on multi-processors machines; we're running this on cell-phones, damnit !!

    Note that Bionic doesn't provide a libthread_db or a libm implementation.


    Adding new syscalls:
    ====================

    Bionic provides the gensyscalls.py Python script to automatically generate syscall
    stubs from the list defined in the file SYSCALLS.TXT. You can thus add a new syscall
    by doing the following:

    - edit SYSCALLS.TXT
    - add a new line describing your syscall, it should look like:

       return_type  syscall_name(parameters)    syscall_number

    - in the event where you want to differentiate the syscall function from its entry name,
      use the alternate:

       return_type  funcname:syscall_name(parameters)  syscall_number

    - additionally, if the syscall number is different between ARM and x86, use:

       return_type  funcname[:syscall_name](parameters)   arm_number,x86_number

    - a syscall number can be -1 to indicate that the syscall is not implemented on
      a given platform, for example:

       void   __set_tls(void*)   arm_number,-1


    the comments in SYSCALLS.TXT contain more information about the line format

    You can also use the 'checksyscalls.py' script to check that all the syscall
    numbers you entered are correct. It does so by looking at the values defined in
    your Linux kernel headers. The script indicates where the values are incorrect
    and what is expected instead.
  • 相关阅读:
    使用yum 安装时出现 : Loaded plugins: fastestmirror
    三级店铺发布店铺悬赏必看
    专属包发布说明
    发布店铺内容(原封不动的直接复制内容发布就可以)
    tomcat 专属图片文件夹配置
    java websocket时时通信
    lua面向对象
    jenkins 查看请求调用栈信息
    从一个简单的例子看spring ApplicationContext上下文隔离
    java异常查看利器之使用 jvmti 的Callback_JVMTI_EVENT_EXCEPTION 事件查看异常
  • 原文地址:https://www.cnblogs.com/ainima/p/6332019.html
Copyright © 2011-2022 走看看