Mbed OS version of IoT.js implementation running on GR-PEACH
ビルド方法
ビルド環境セットアップ
Host PC要件 : Ubuntu 16.04 (64-bit)
1. 以下のコマンドを実行し、下表に示すツールをインストールします。
$ sudo apt update $ sudo apt upgrade $ sudo apt install [Package]
Package | Version |
build-essential | 12.1ubuntu2 |
gyp | 0.1+20150913git1f374df9-1ubuntu1 |
mercurial | 3.7.3-1ubuntu1 |
cmake | 3.5.1-1ubuntu3 |
git | 1:2.7.4-0ubuntu1.4 |
python2.7 | 2.7.12-1ubuntu016.04.3 |
valgrind | 1:3.11.0-1ubuntu4.2 |
python-pip | 8.1.1-2ubuntu0.4 |
2. 以下のコマンドを実行してMbed OS用ビルドツール mbed CLIをインストールします。
$ sudo -H pip install mbed-cli
3. GNU Arm Embedded Toolchainをインストールします。
- 下記URLからLinux用パッケージ (gcc-arm-none-eabi-6-2017-q2-update-linux.tar.bz2) をダウンロードしてください。
https://developer.arm.com/-/media/Files/downloads/gnu-rm/6-2017q2/gcc-arm-none-eabi-6-2017-q2-update-linux.tar.bz2?revision=2cc92fb5-3e0e-402d-9197-bdfc8224d8a5?product=GNU%20Arm%20Embedded%20Toolchain,64-bit,,Linux,6-2017-q2-update
- ダウンロードしたファイルを任意のディレクトリに展開します。
(以下、展開先を${TOOLCHAIN}と記載します)
tar xjf gcc-arm-none-eabi-6-2017-q2-update-linux.tar.bz2
- ツールチェインのパスを設定します。
環境変数を使用する場合
$ export GCC_ARM_ROOT=${TOOLCHAIN}/gcc-arm-none-eabi-6-2017-q2-update/bin $ export PATH=$GCC_ARM_ROOT:$PATH
mbed CLIで指定する場合
$ mbed config -G GCC_ARM_PATH $GCC_ARM_ROOT
iotjs環境のビルド
1. 本プログラムのクローン
下記コマンドを実行し、本プログラムをクローンしてください。
$ hg clone https://HinoNaka@os.mbed.com/users/HinoNaka/code/GR-PEACH_mbed-os-iotjs/
クローンが正常に終了すると、GR-PEACH_mbed-os-iotjs という名称のディレクトリが生成されますので、下記コマンドで当該ディレクトリへ移動してください。
$ cd GR-PEACH_mbed-os-iotjs
(Optional)
GR-PEACH-mbed-os-iotjsディレクトリを指す環境変数 ROOTを設定してください。以降の記載は本環境変数が設定されているものとします。
$ export ROOT=$(PWD)
2. 作業用ディレクトリ(e.g. work)を作成し、当該ディレクトリに移動してください。
$ mkdir -p work $ cd work
(Optional)
作業用ディレクトリを指す環境変数 WORK を設定してください。以降の記載は本環境変数 が設定されているものとします。
$ export WORK=$(PWD)
3. iotjsのソースツリーを取得します。
$ git clone https://github.com/pando-project/iotjs
クローンが正常に終了するとiotjsというディレクトリが生成されますので、当該ディレクトリに移動してください。
$cd iotjs
コミットID: acae9c8b2d40e7598b8d39b630b79113ce880a7e を取得します。
(下記例では、あわせてposixというブランチを作成し、当該ブランチへ切り替えています)
$ git checkout -b posix acae9c8b2d40e7598b8d39b630b79113ce880a7e
4. mbed-osセットアップ
Mbed OSソースツリーを格納するフォルダを生成し、当該フォルダへ移動します。
$ mkdir -p $(WORK)/iotjs/src/platform/mbedos5 $ cd $(WORK)/iotjs/src/platform/mbedos5
Mbed OSのソースツリーをクローンします。
$ git clone -b mbed-os-5.9 https://github.com/ARMmbed/mbed-os.git
クローンが正常に終了するとmbed-osというディレクトリが生成されますので、当該ディレクトリに移動してください。
$ cd mbed-os
コミットID: 50bd61a4a72332baa6b1bac6caccb44dc5423309 を取得します。
(下記例では、あわせてposixというブランチを作成し、当該ブランチへ切り替えています)
$ git checkout -b posix 50bd61a4a72332baa6b1bac6caccb44dc5423309
5. sd-driverの取得
下記コマンドでmbedos5ディレクトリへ移動します。
$ cd $(WORK)/iotjs/src/platform/mbedos5
sd-driverをクローンします。
$ git clone https://github.com/ARMmbed/sd-driver.git
クローンが正常終了するとsd-driverディレクトリが生成されますので、当該ディレクトリへ移動します。
$ cd sd-driver
コミットID: c8ae38fb291e086232566b0f1372cfb69c277e84 を取得します。
(下記例では、あわせてposixというブランチを作成し、当該ブランチへ切り替えています)
$ git checkout -b posix c8ae38fb291e086232566b0f1372cfb69c277e84
6. mbed-gr-libsの取得
下記コマンドでmbedos5ディレクトリへ移動します。
$ cd $(WORK)/iotjs/src/platform/mbedos5
mbed-gr-libsをクローンします。
$ git clone https://github.com/d-kato/mbed-gr-libs
クローンが正常終了するとmbed-gr-libsディレクトリが生成されますので、当該ディレクトリへ移動します。
$ cd mbed-gr-libs
コミットID: d921d611d596ecaebaab49070ef82450c583309c を取得します。
(下記例では、あわせてposixというブランチを作成し、当該ブランチへ切り替えています)
$ git checkout -b posix d921d611d596ecaebaab49070ef82450c583309c
7. AsciiFONTの取得
下記コマンドでmbedos5ディレクトリへ移動します。
$ cd $(WORK)/iotjs/src/platform/mbedos5
AsciiFONTライブラリを追加します。
$ mbed add https://os.mbed.com/teams/Renesas/code/AsciiFont/
8. iotjs環境のビルド
下記コマンドでiotjs環境のビルドディレクトリに移動し、ビルドを実行します。
$ cd $(WORK)/iotjs $ ./tools/build.py --no-snapshot
9. GR-PEACH用コードのコピー
(Optional) 既存のiotjs環境に上書きする場合、下記コマンドを実行してください。
$ rm -rf $(WORK)/iotjs/deps/posix $ rm -rf $(WORK)/iotjs/src/ext-modules $ rm -rf $(WORK)/iotjs/src/platform/mbedos5/iotjs_def.h
下記コマンドでGR-PEACH用コードをコピーします。
$ cp -pr $(ROOT)/src/iotjs/* $(WORK)/iotjs/
10. lwipパッチ適用
以下コマンドでlwipパッチを適用します。
$ cd $(WORK)/iotjs/src/platform/mbedos5/mbed-os $ git apply lwip_improve.patch
11. ESP32 TRNG対応パッチ適用
以下コマンドでESP32のTRNGを活用するためのパッチを適用します。
$ cd $(WORK)/iotjs/src/platform/mbedos5/mbed-os $ git apply trng_support.patch
12. Mbed OS版iotjs環境のビルド
下記コマンドを実行してMbed OS版iotjs環境をビルドします。
(リリースビルドの場合)
$ cd $(WORK)/iotjs/src/platform/mbedos5 $ make clean; make DEBUG=0
(デバッグビルドの場合)
$ cd $(WORK)/iotjs/src/platform/mbedos5 $ make clean; make DEBUG=1
13. ビルドが正常に終了すると、以下の通りバイナリが生成されます。
(リリースビルドの場合)
$ ls -l ${WORK}/iotjs/src/platform/mbedos5/BUILD/RZ_A1H/GCC_ARM-RELEASE/iotjs.bin
(デバッグビルドの場合)
$ ls -l ${WORK}/iotjs/src/platform/mbedos5/BUILD/RZ_A1H/GCC_ARM-DEBUG/iotjs.bin
実行方法
1. GR-PEACHにmicro SDカードを挿入します。
2. GR-PEACHのEthernetポートから遠い側のUSBポートとHost PCをマイクロUSBケーブルで接続します。
3. Host PCでGR-PEACHが『mbed:』ドライブとして認識されたら、iotjs.binをmbedドライブにコピーします。
4. ターミナルS/Wを立上げ、『mbed Serial Port』と接続します。
シリアルポートは下記設定としてください。
Baud rate | 115200 | |||
Data | 8 bit | |||
Parity | none | |||
Stop | 1 bit | |||
Flow control | none |
5. 正常に書込みが終了したらGR-PEACHのRESETボタンを押下します。
6. ターミナルS/W上に下記メッセージが表示されます。
7. Enterキーを押下してコード入力モードに移行します。
8. 実行するJavascriptコードをターミナルソフトウェアに貼り付けてEnterキーを押下すると、実行開始します。Javascriptコード例については、test/case.txtを参照ください。
Diff: src/iotjs/deps/posix/posix4.h
- Revision:
- 0:7cc000799c93
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/iotjs/deps/posix/posix4.h Thu Jul 11 18:48:09 2019 +0900 @@ -0,0 +1,333 @@ +/* Copyright 2017-present Renesas Electronics Corporation and other contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef POSIX4_INCL +#define POSIX4_INCL + +#include "./posix4_aux.h" + +#ifdef __cplusplus +extern "C" { +#endif + +#define P4_API(type,func) type P4(func) +#define POSIX_API P4_API +#define LINUX_API P4_API +#define OVRDN_API P4_API +#define NIC_API P4_API + +POSIX_API(char*, getcwd(char* buf, P4(size_t) size)); +POSIX_API(int, chdir(const char* path)); +POSIX_API(int, fdatasync(int fd)); +POSIX_API(int, fsync(int fd)); +POSIX_API(int, ftruncate(int fd, P4(off_t) length)); +POSIX_API(int, scandir(const char* dirp, struct P4(dirent)*** namelist, int (*filter)(const struct P4(dirent)*), int (*compar)(const struct P4(dirent)**, const struct P4(dirent)**))); +POSIX_API(int, utime(const char* filename, const struct utimbuf* times)); +POSIX_API(int, utimes(const char* filename, const struct timeval times[2])); +POSIX_API(P4(ssize_t), pread(int fd, void* buf, P4(size_t) count, P4(off_t) offset)); +POSIX_API(P4(ssize_t), pwrite(int fd, const void* buf, P4(size_t) count, P4(off_t) offset)); +POSIX_API(P4(ssize_t), readv(int fd, const struct P4(iovec)* iov, int iovcnt)); +POSIX_API(P4(ssize_t), writev(int fd, const struct P4(iovec)* iov, int iovcnt)); +POSIX_API(int, utimensat(int dirfd, const char* pathname, const struct P4(timespec) times[2], int flags)); + +POSIX_API(int, clock_getres(P4(clockid_t) clk_id, struct P4(timespec)* res)); +POSIX_API(int, clock_gettime(P4(clockid_t) clk_id, struct P4(timespec)* tp)); + +POSIX_API(int, pthread_create(P4(pthread_t)* thread, P4(pthread_attr_t)* attr, void* (*start_routine)(void*), void* arg)); +POSIX_API(int, pthread_join(P4(pthread_t) thread, void** retval)); +POSIX_API(int, pthread_once(P4(pthread_once_t)* once_control, void (*init_routine)(void))); +POSIX_API(int, pthread_sigmask(int how, const P4(sigset_t)* set, P4(sigset_t)* oldset)); +POSIX_API(int, pthread_attr_destroy(P4(pthread_attr_t)* attr)); +POSIX_API(int, pthread_cond_destroy(P4(pthread_cond_t)* cond)); +POSIX_API(int, pthread_cond_init(P4(pthread_cond_t)* cond, P4(pthread_condattr_t)* cond_attr)); +POSIX_API(int, pthread_cond_signal(P4(pthread_cond_t)* cond)); +POSIX_API(int, pthread_cond_wait(P4(pthread_cond_t)* cond, P4(pthread_mutex_t)* mutex)); +POSIX_API(int, pthread_condattr_destroy(P4(pthread_condattr_t)* attr)); +POSIX_API(int, pthread_condattr_init(P4(pthread_condattr_t)* attr)); +POSIX_API(int, pthread_condattr_setclock(P4(pthread_condattr_t)* attr, clockid_t clock_id)); +POSIX_API(int, pthread_mutex_destroy(P4(pthread_mutex_t)* mutex)); +POSIX_API(int, pthread_mutex_init(P4(pthread_mutex_t)* mutex, const P4(pthread_mutexattr_t)* mutexattr)); +POSIX_API(int, pthread_mutex_lock(P4(pthread_mutex_t)* mutex)); +POSIX_API(int, pthread_mutex_unlock(P4(pthread_mutex_t)* mutex)); +POSIX_API(int, pthread_rwlock_destroy(P4(pthread_rwlock_t)* rwlock)); +POSIX_API(int, pthread_rwlock_init(P4(pthread_rwlock_t)* rwlock, const P4(pthread_rwlockattr_t)* attr)); +POSIX_API(int, pthread_rwlock_rdlock(P4(pthread_rwlock_t)* rwlock)); +POSIX_API(int, pthread_rwlock_unlock(P4(pthread_rwlock_t)* rwlock)); + POSIX_API(int, pthread_cond_broadcast(P4(pthread_cond_t)* cond)); + POSIX_API(int, pthread_cond_timedwait(P4(pthread_cond_t)* cond, P4(pthread_mutex_t)* mutex, const struct P4(timespec)* abstime)); + POSIX_API(P4(pthread_t), pthread_self(void)); + POSIX_API(int, pthread_equal(P4(pthread_t) t1, P4(pthread_t) t2)); + POSIX_API(int, pthread_mutex_trylock(P4(pthread_mutex_t)* mutex)); + POSIX_API(int, pthread_rwlock_tryrdlock(P4(pthread_rwlock_t)* rwlock)); + POSIX_API(int, pthread_rwlock_trywrlock(P4(pthread_rwlock_t)* rwlock)); + POSIX_API(int, pthread_rwlock_wrlock(P4(pthread_rwlock_t)* rwlock)); + POSIX_API(int, sem_init(P4(sem_t)* sem, int pshared, unsigned int value)); + POSIX_API(int, sem_destroy(P4(sem_t)* sem)); + POSIX_API(int, sem_wait(P4(sem_t)* sem)); + POSIX_API(int, sem_trywait(P4(sem_t)* sem)); + POSIX_API(int, sem_post(P4(sem_t)* sem)); + +#define CMSG_ALIGN(len) (((len) + sizeof(P4(size_t)) - 1) & (P4(size_t))~(sizeof(P4(size_t)) - 1)) +#define CMSG_SPACE(len) (CMSG_ALIGN(len) + CMSG_ALIGN(sizeof(struct P4(cmsghdr)))) +#define CMSG_LEN(len) (CMSG_ALIGN(sizeof(struct P4(cmsghdr))) + (len)) +#define CMSG_FIRSTHDR(mhdr) ( \ + (P4(size_t))(mhdr)->msg_controllen >= sizeof(struct P4(cmsghdr)) \ + ? (struct P4(cmsghdr)*)(mhdr)->msg_control : (struct P4(cmsghdr)*)0 \ +) +P4_API(struct P4(cmsghdr)*, cmsg_nxthdr(struct P4(msghdr)* mhdr, struct P4(cmsghdr)* cmsg)); +#define CMSG_NXTHDR(mhdr, cmsg) P4(cmsg_nxthdr)(mhdr, cmsg) +#define CMSG_DATA(cmsg) ((unsigned char*)((struct P4(cmsghdr)*)(cmsg) + 1)) + +POSIX_API(int, accept(int sockfd, struct P4(sockaddr)* addr, P4(socklen_t)* addrlen)); +POSIX_API(int, bind(int sockfd, const struct P4(sockaddr)* addr, P4(socklen_t) addrlen)); +POSIX_API(int, connect(int sockfd, const struct P4(sockaddr)* addr, P4(socklen_t) addrlen)); +POSIX_API(void, freeaddrinfo(struct P4(addrinfo)* res)); +POSIX_API(int, getaddrinfo(const char* node, const char* service, const struct P4(addrinfo)* hints, struct P4(addrinfo)** res)); + POSIX_API(int, getpeername(int sockfd, struct P4(sockaddr)* addr, P4(socklen_t)* addrlen)); +POSIX_API(int, getsockname(int sockfd, struct P4(sockaddr)* addr, P4(socklen_t)* addrlen)); +POSIX_API(int, getsockopt(int sockfd, int level, int optname, void* optval, P4(socklen_t)* optlen)); +POSIX_API(uint32_t, htonl(uint32_t hostlong)); +POSIX_API(uint16_t, htons(uint16_t hostshort)); +POSIX_API(unsigned int, if_nametoindex(const char* ifname)); +POSIX_API(int, listen(int sockfd, int backlog)); +POSIX_API(uint16_t, ntohs(uint16_t netshort)); +POSIX_API(P4(ssize_t), recvmsg(int sockfd, struct P4(msghdr)* msg, int flags)); +POSIX_API(P4(ssize_t), sendmsg(int sockfd, const struct P4(msghdr)* msg, int flags)); +POSIX_API(int, setsockopt(int sockfd, int level, int optname, const void* optval, P4(socklen_t) optlen)); +POSIX_API(int, shutdown(int sockfd, int how)); +POSIX_API(int, socket(int domain, int type, int protocol)); + +POSIX_API(int, nanosleep(const struct P4(timespec)* req, struct P4(timespec)* rem)); +POSIX_API(int, pipe(int pipefd[2])); +POSIX_API(long, sysconf(int name)); + +LINUX_API(P4(ssize_t), preadv(int fd, const struct P4(iovec)* iov, int iovcnt, P4(off_t) offset)); +LINUX_API(P4(ssize_t), pwritev(int fd, const struct P4(iovec)* iov, int iovcnt, P4(off_t) offset)); + +LINUX_API(int, epoll_create(int size)); +LINUX_API(int, epoll_create1(int flags)); +LINUX_API(int, epoll_ctl(int epfd, int op, int fd, struct P4(poll_event)* event)); +LINUX_API(int, epoll_pwait(int epfd, struct P4(poll_event)* events, int maxevents, int timeout, const P4(sigset_t)* sigmask)); +LINUX_API(int, epoll_wait(int epfd, struct P4(poll_event)* events, int maxevents, int timeout)); +LINUX_API(int, eventfd(unsigned int initval, int flags)); +LINUX_API(int, eventfd2(unsigned int initval, int flags)); + +LINUX_API(int, accept4(int fd, struct P4(sockaddr)* addr, P4(socklen_t)* addr_len, int flags)); +LINUX_API(int, socketcall(int call, unsigned long* args)); + +LINUX_API(int, ioctl(int fd, unsigned long request, ...)); +LINUX_API(long, syscall(long number, ...)); +LINUX_API(int, pipe2(int pipefd[2], int flags)); + +LINUX_API(void*, dlopen(const char* filename, int flag)); +LINUX_API(void*, dlsym(void* handle, char* symbol)); +LINUX_API(int, dlclose(void* handle)); + +LINUX_API(char**, backtrace_symbols(void*const* buffer, int size)); +LINUX_API(int, backtrace(void** buffer, int size)); + +OVRDN_API(void, abort(void)); +OVRDN_API(int, gettimeofday(struct timeval* tv, void* tz)); +OVRDN_API(P4(ssize_t), read(int fd, void* buf, P4(size_t) count)); +OVRDN_API(P4(ssize_t), write(int fd, const void* buf, P4(size_t) count)); +OVRDN_API(int, open(const char* pathname, ...)); +OVRDN_API(int, close(int fd)); +OVRDN_API(int, unlink(const char* pathname)); +OVRDN_API(int, mkdir(const char* pathname, P4(mode_t) mode)); +OVRDN_API(int, rmdir(const char* pathname)); +OVRDN_API(int, stat(const char* pathname, P4(stat_t)* buf)); +OVRDN_API(int, fstat(int fd, P4(stat_t)* buf)); + +NIC_API(char*, nic_enumerate(void)); +NIC_API(int, nic_ifup(const char* nic, const char* params)); +NIC_API(int, nic_ifdown(const char* nic)); +NIC_API(char*, nic_ifconfig(const char* nic)); +NIC_API(int, nic_ntpdate(const char* nic, const char* server, int port, int timeout)); + +#undef NIC_API +#undef OVRDN_API +#undef LINUX_API +#undef POSIX_API + +#if !defined( POSIX4_ITSELF ) + + // functions + #define getcwd P4(getcwd) + #define chdir P4(chdir) + #define fdatasync P4(fdatasync) + #define fsync P4(fsync) + #define ftruncate P4(ftruncate) + #define scandir P4(scandir) + #define utime P4(utime) + #define utimes P4(utimes) + #define pread P4(pread) + #define pwrite P4(pwrite) + #define readv P4(readv) + #define writev P4(writev) + #define utimensat P4(utimensat) + + #define clock_getres P4(clock_getres) + #define clock_gettime P4(clock_gettime) + + #define pthread_create P4(pthread_create) + #define pthread_join P4(pthread_join) + #define pthread_once P4(pthread_once) + #define pthread_sigmask P4(pthread_sigmask) + #define pthread_attr_destroy P4(pthread_attr_destroy) + #define pthread_cond_destroy P4(pthread_cond_destroy) + #define pthread_cond_init P4(pthread_cond_init) + #define pthread_cond_signal P4(pthread_cond_signal) + #define pthread_cond_wait P4(pthread_cond_wait) + #define pthread_condattr_destroy P4(pthread_condattr_destroy) + #define pthread_condattr_init P4(pthread_condattr_init) + #define pthread_condattr_setclock P4(pthread_condattr_setclock) + #define pthread_mutex_destroy P4(pthread_mutex_destroy) + #define pthread_mutex_init P4(pthread_mutex_init) + #define pthread_mutex_lock P4(pthread_mutex_lock) + #define pthread_mutex_unlock P4(pthread_mutex_unlock) + #define pthread_rwlock_destroy P4(pthread_rwlock_destroy) + #define pthread_rwlock_init P4(pthread_rwlock_init) + #define pthread_rwlock_rdlock P4(pthread_rwlock_rdlock) + #define pthread_rwlock_unlock P4(pthread_rwlock_unlock) + #define pthread_cond_broadcast P4(pthread_cond_broadcast) + #define pthread_cond_timedwait P4(pthread_cond_timedwait) + #define pthread_self P4(pthread_self) + #define pthread_equal P4(pthread_equal) + #define pthread_mutex_trylock P4(pthread_mutex_trylock) + #define pthread_rwlock_tryrdlock P4(pthread_rwlock_tryrdlock) + #define pthread_rwlock_trywrlock P4(pthread_rwlock_trywrlock) + #define pthread_rwlock_wrlock P4(pthread_rwlock_wrlock) + #define sem_init P4(sem_init) + #define sem_destroy P4(sem_destroy) + #define sem_wait P4(sem_wait) + #define sem_trywait P4(sem_trywait) + #define sem_post P4(sem_post) + + #define accept P4(accept) + #define bind P4(bind) + #define connect P4(connect) + #define freeaddrinfo P4(freeaddrinfo) + #define getaddrinfo P4(getaddrinfo) + #define getpeername P4(getpeername) + #define getsockname P4(getsockname) + #define getsockopt P4(getsockopt) + #define htonl P4(htonl) + #define htons P4(htons) + #define if_nametoindex P4(if_nametoindex) + #define listen P4(listen) + #define ntohs P4(ntohs) + #define recvmsg P4(recvmsg) + #define sendmsg P4(sendmsg) + #define setsockopt P4(setsockopt) + #define shutdown P4(shutdown) + #define socket(d,t,p) P4(socket)(d, t, p) + + #define nanosleep P4(nanosleep) + #define pipe P4(pipe) + #define sysconf P4(sysconf) + + #define preadv P4(preadv) + #define pwritev P4(pwritev) + + #define epoll_create P4(epoll_create) + #define epoll_create1 P4(epoll_create1) + #define epoll_ctl P4(epoll_ctl) + #define epoll_pwait P4(epoll_pwait) + #define epoll_wait P4(epoll_wait) + #define eventfd P4(eventfd) + #define eventfd2 P4(eventfd2) + + #define accept4 P4(accept4) + #define socketcall P4(socketcall) + + #define ioctl P4(ioctl) + #define syscall(n, ...) P4(syscall)(n, __VA_ARGS__) + #define pipe2 P4(pipe2) + + #define dlopen P4(dlopen) + #define dlsym P4(dlsym) + #define dlclose P4(dlclose) + + #define backtrace_symbols P4(backtrace_symbols) + #define backtrace P4(backtrace) + + #define abort P4(abort) + #define gettimeofday(tv,tz) P4(gettimeofday)(tv, tz) + #define read(fd,buf,count) P4(read)(fd, buf, count) + #define write(fd,buf,count) P4(write)(fd, buf, count) + #define open(pathname, ...) P4(open)(pathname, __VA_ARGS__) + #define close(fd) P4(close)(fd) + #define unlink(pathname) P4(unlink)(pathname) + #define mkdir(pathname,mode) P4(mkdir)(pathname,mode) + #define rmdir(pathname) P4(rmdir)(pathname) + #define stat(pathname,buf) P4(stat)(pathname, buf) + #define fstat(fd,buf) P4(fstat)(fd, buf) + + #define nic_enumerate P4(nic_enumerate) + #define nic_ifup P4(nic_ifup) + #define nic_ifdown P4(nic_ifdown) + #define nic_ifconfig P4(nic_ifconfig) + #define nic_ntpdate P4(nic_ntpdate) + + // structs + #define addrinfo P4(addrinfo) + #define cmsghdr P4(cmsghdr) + #define dirent P4(dirent) + #define in_addr P4(in_addr) + #define in6_addr P4(in6_addr) + #define iovec P4(iovec) + #define msghdr P4(msghdr) + #define poll_event P4(poll_event) + #define sockaddr P4(sockaddr) + #define sockaddr_in P4(sockaddr_in) + #define sockaddr_in6 P4(sockaddr_in6) + #define sockaddr_storage P4(sockaddr_storage) + #define termios P4(termios) + #define timespec P4(timespec) + #define timeval P4(timeval) + #define utimbuf P4(utimbuf) + + // typedefs + #define clockid_t P4(clockid_t) + #define ip_mreq P4(ip_mreq) + #define ipv6_mreq P4(ipv6_mreq) + #define in_addr_t P4(in_addr_t) + #define in_port_t P4(in_port_t) + #define off_t P4(off_t) + #define pthread_attr_t P4(pthread_attr_t) + #define pthread_cond_t P4(pthread_cond_t) + #define pthread_condattr_t P4(pthread_condattr_t) + #define pthread_key_t P4(pthread_key_t) + #define pthread_mutex_t P4(pthread_mutex_t) + #define pthread_mutexattr_t P4(pthread_mutexattr_t) + #define pthread_once_t P4(pthread_once_t) + #define pthread_rwlock_t P4(pthread_rwlock_t) + #define pthread_rwlockattr_t P4(pthread_rwlockattr_t) + #define pthread_t P4(pthread_t) + #define sa_family_t P4(sa_family_t) + #define sem_t P4(sem_t) + #define sigset_t P4(sigset_t) + #define size_t P4(size_t) + #define socklen_t P4(socklen_t) + #define ssize_t P4(ssize_t) + #define stat_t P4(stat_t) + +#endif // #if !defined( POSIX4_ITSELF ) + +#ifdef __cplusplus +} +#endif + +#endif // #ifndef POSIX4_INCL