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.
  • 相关阅读:
    界面实现的小总结
    创建线程的三种方式
    之前总结的今天给大分享一下iOS
    MVVM
    响应者链条
    layer图层常见属性
    NSRunLoop && NSTimer
    关于Angularjs做的一个购物车小例子
    css中实现元素的绝对居中
    剑指 Offer 18. 删除链表的节点 链表
  • 原文地址:https://www.cnblogs.com/ainima/p/6332019.html
Copyright © 2011-2022 走看看