你的位置:欧博体育投注 > 欧博会员注册 > 排列五体育博彩平台游戏挑战_鸿蒙轻内核M核源码分析系列之Newlib C
排列五体育博彩平台游戏挑战_鸿蒙轻内核M核源码分析系列之Newlib C
发布日期:2023-10-30 02:06    点击次数:105

排列五体育博彩平台游戏挑战_鸿蒙轻内核M核源码分析系列之Newlib C

法律排列五体育博彩平台游戏挑战_

排列五体育皇冠体育皇冠官网地址

念念了解更多内容,请拜访:

51CTO和华为官方合营共建的鸿蒙技能社区

根据此前节目组发布的消息,《浪姐4》总决赛将分为三轮进行,分别是队长合作秀、联盟团秀以及1V1PK秀,三轮比拼决出7个出道位归属。

通过之前曝光的信息看,《浪姐4》总决赛总共分为3轮比拼,除了队长秀和联盟团秀外,将继续延续第四轮公演的1V1PK秀,谢娜组的朱珠、刘雅瑟,陈嘉桦组的芝芙、龚琳娜以及刘逸云组的美依礼芽、刘惜君6人组成两两对抗关系,将在成团夜合作演出《岁月》、《say no》以及《what's that girl》三首曲目,由观众进行二选一投票。

皇冠客服飞机:@seo3687奥门新葡京网址

https://harmonyos.51cto.com

LiteOS-M内核LibC杀青存2种,不错证实需求进行二选一,永诀是musl libC和newlibc。本文先学习下Newlib C的杀青代码。文中所触及的源码,均不错在开源站点https://gitee.com/openharmony/kernel_liteos_m 赢得。

使用Musl C库的时分,内核提供了基于LOS_XXX适配杀青pthread、mqeue、fs、semaphore、time等模块的posix接口(//kernel/liteos_m/kal/posix)。内核提供的posix接口与musl中的模范C库接口共同构成LiteOS-M的LibC。编译时使用arm-none-eabi-gcc,但只使用其器具链的编译功能,通过加上-nostdinc与-nostdlib强制使用咱们我方翻新后的musl-C。

社区及三方厂商斥地多使用公版器具链arm-none-eabi-gcc加上畸形定制优化进行编译,LiteOS-M内核也撑握公版arm-none-eabi-gcc C库编译内核运转。newlib是微型C库,针对posix接口触及系统调用的部分,newlib提供一些需要系统适配的钩子函数,举例_exit(),_open(),_close(),_gettimeofday()等,操作系统适配这些钩子,就不错使用公版newlib器具链编译运转要领。

1、Newlib C文献系统

在使用Newlib C况且使能撑握POSIX FS API时(不错在kernel\liteos-m\目次下,实践make meuconfig弹出建立界面,旅途为Compat-Choose libc implementation),如下图所示。不错使用文献kal\libc\newlib\porting\src\fs.c中界说的文献系统操作接口。这些是模范的POSIX接口,若是念念了解POSIX用法,不错在linux平台输入 man -a 函数称呼,欧博会员注册比如man -a opendir来掀开函数的手册。

鸿蒙轻内核M核源码分析系列二十 Newlib C-鸿蒙HarmonyOS技能社区 1.1 函数mount、umount和umount2

这些函数的用法,函数杀青和musl c部分一致。

博彩平台游戏挑战一场极具悬念虚拟赛事中,皇冠赌客们投下大笔赌注,最终比赛结果出乎意料,大家大跌眼镜。
int mount(const char *source, const char *target,           const char *filesystemtype, unsigned long mountflags,           const void *data) {     return LOS_FsMount(source, target, filesystemtype, mountflags, data); }  int umount(const char *target) {     return LOS_FsUmount(target); }  int umount2(const char *target, int flag) {     return LOS_FsUmount2(target, flag); } 
1.2 文献操作接口

以下划线发轫的函数杀青是newlib c的钩子函数杀青。关系newlib的钩子函数调用历程下文畸形分析下。

澳门美高梅赌场

皇冠体育hg86a

int _open(const char *path, int oflag, ...) {     va_list vaList;     va_start(vaList, oflag);     int ret;     ret = LOS_Open(path, oflag);     va_end(vaList);     return ret; }  int _close(int fd) {     return LOS_Close(fd); }  ssize_t _read(int fd, void *buf, size_t nbyte) {     return LOS_Read(fd, buf, nbyte); }  ssize_t _write(int fd, const void *buf, size_t nbyte) {     return LOS_Write(fd, buf, nbyte); }  off_t _lseek(int fd, off_t offset, int whence) {     return LOS_Lseek(fd, offset, whence); }  int _unlink(const char *path) {     return LOS_Unlink(path); }  int _fstat(int fd, struct stat *buf) {     return LOS_Fstat(fd, buf); }  int _stat(const char *path, struct stat *buf) {     return LOS_Stat(path, buf); }  int fsync(int fd) {     return LOS_Fsync(fd); }  int mkdir(const char *path, mode_t mode) {     return LOS_Mkdir(path, mode); }  DIR *opendir(const char *dirName) {     return LOS_Opendir(dirName); }  struct dirent *readdir(DIR *dir) {     return LOS_Readdir(dir); }  int closedir(DIR *dir) {     return LOS_Closedir(dir); }  int rmdir(const char *path) {     return LOS_Unlink(path); }  int rename(const char *oldName, const char *newName) {     return LOS_Rename(oldName, newName); }  int statfs(const char *path, struct statfs *buf) {     return LOS_Statfs(path, buf); }  int ftruncate(int fd, off_t length) {     return LOS_Ftruncate(fd, length); } 

在newlib莫得使能使能撑握POSIX FS API常常,需要提供这些钩子函数的空的杀青,复返-1空虚码即可。

int _open(const char *path, int oflag, ...) {     return -1; }  int _close(int fd) {     return -1; }  ssize_t _read(int fd, void *buf, size_t nbyte) {     return -1; }  ssize_t _write(int fd, const void *buf, size_t nbyte) {     return -1; }  off_t _lseek(int fd, off_t offset, int whence) {     return -1; }  int _unlink(const char *path) {     return -1; }  int _fstat(int fd, struct stat *buf) {     return -1; }  int _stat(const char *path, struct stat *buf) {     return -1; } 
2、Newlib C内存分拨开释

newlibc 的malloc适配参考The Red Hat newlib C Library-malloc。杀青malloc适配有以下两种神情:

皇冠现金网 杀青 _sbrk_r 函数。这种神情中,内存分拨函数使用newlib中的。 杀青 _malloc_r, _realloc_r, _free_r, _memalign_r, _malloc_usable_size_r等。这种神情中,内存分拨函数不错使用内核的。

为了便捷地证实业务进行内存分拨算法调优和问题定位,保举给与后者。内核的内存函数界说在文献kal\libc\newlib\porting\src\malloc.c中。源码片断如下,代码杀青比拟浅易,不再分析源码。

...... void __wrap__free_r(struct _reent *reent, void *aptr) {     if (aptr == NULL) {         return;     }      LOS_MemFree(OS_SYS_MEM_ADDR, aptr); }  size_t __wrap__malloc_usable_size_r(struct _reent *reent, void *aptr) {     return 0; }  void *__wrap__malloc_r(struct _reent *reent, size_t nbytes) {     if (nbytes == 0) {         return NULL;     }      return LOS_MemAlloc(OS_SYS_MEM_ADDR, nbytes); }  void *__wrap__memalign_r(struct _reent *reent, size_t align, size_t nbytes) {     if (nbytes == 0) {         return NULL;     }      return LOS_MemAllocAlign(OS_SYS_MEM_ADDR, nbytes, align); } ...... 

可能依然暴露到函数定名由__wrap_加入彀子函数称呼两部分构成。这是因为newlib中依然存在这些函数的记号,因此需要用到gcc的wrap的畅通选项替换这些函数记号为内核的杀青,在设立斥地板的建立文献中,比如//device/board/fnlink/v200zr/liteos_m/config.gni,新增这些函数的wrap畅通选项,示举例下:

board_ld_flags += [      "-Wl,--wrap=_malloc_r",      "-Wl,--wrap=_realloc_r",      "-Wl,--wrap=_free_r",      "-Wl,--wrap=_memalign_r",      "-Wl,--wrap=_malloc_usable_size_r", ] 
3、Newlib钩子函数先容

以open函数的钩子函数_open为例来先容newlib的钩子函数的调用历程。open()函数杀青在newlib-cygwin\newlib\libc\syscalls\sysopen.c中,该函数会进一设施用函数_open_r,这是个可重入函数Reentrant Function,撑握在多线程中运转。

int open (const char *file,         int flags, ...) {   va_list ap;   int ret;    va_start (ap, flags);   ret = _open_r (_REENT, file, flags, va_arg (ap, int));   va_end (ap);   return ret; } 

 所有这个词的可重入函数界说在文献夹newlib-cygwin\newlib\libc\reent,函数_open_r界说在该文献夹的文献newlib-cygwin\newlib\libc\reent\openr.c里。函数代码如下:

int _open_r (struct _reent *ptr,      const char *file,      int flags,      int mode) {   int ret;    errno = 0;   if ((ret = _open (file, flags, mode)) == -1 && errno != 0)     ptr->_errno = errno;   return ret; } 

 函数_open_r如上述代码所示,会进一设施用函数_open,该函数,以arm硬件平台为例,杀青在newlib-cygwin\libgloss\arm\syscalls.c文献里。newlib目次是和硬件平台无关的痛殴他阿谁功能杀青,libloss目次是底层的驱动杀青,以各个硬件平台为文献夹进行组织。在特定硬件平台的目次下的syscalls.c文献内部杀青了newlib需要的各个桩函数:

/* Forward prototypes.  */ int _system     (const char *); int _rename     (const char *, const char *); int _isatty     (int); clock_t _times      (struct tms *); int _gettimeofday   (struct timeval *, void *); int _unlink     (const char *); int _link       (const char *, const char *); int _stat       (const char *, struct stat *); int _fstat      (int, struct stat *); int _swistat    (int fd, struct stat * st); void *  _sbrk       (ptrdiff_t); pid_t   _getpid     (void); int _close      (int); clock_t _clock      (void); int _swiclose   (int); int _open       (const char *, int, ...); int _swiopen    (const char *, int); int _write      (int, const void *, size_t); int _swiwrite   (int, const void *, size_t); _off_t  _lseek      (int, _off_t, int); _off_t  _swilseek   (int, _off_t, int); int _read       (int, void *, size_t); int _swiread    (int, void *, size_t); void    initialise_monitor_handles (void); 

关于上文提到的函数_open,源码如下。后续不再不绝分析了,LiteOS-M内核会提供这些钩子函数的杀青。

int _open (const char * path, int flags, ...) {   return _swiopen (path, flags); } 
小结

实质裁习了LiteOS-M内核Newlib C的杀青,相配是文献系统和内存分拨开释部分,终末先容了Newlib钩子函数。

念念了解更多内容,请拜访:

51CTO和华为官方合营共建的鸿蒙技能社区

https://harmonyos.51cto.com

AG百家乐



相关资讯