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]
PackageVersion
build-essential12.1ubuntu2
gyp0.1+20150913git1f374df9-1ubuntu1
mercurial3.7.3-1ubuntu1
cmake3.5.1-1ubuntu3
git1:2.7.4-0ubuntu1.4
python2.72.7.12-1ubuntu016.04.3
valgrind1:3.11.0-1ubuntu4.2
python-pip8.1.1-2ubuntu0.4

2. 以下のコマンドを実行してMbed OS用ビルドツール mbed CLIをインストールします。

$ sudo -H pip install mbed-cli

3. GNU Arm Embedded Toolchainをインストールします。

  • ダウンロードしたファイルを任意のディレクトリに展開します。
    (以下、展開先を${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』と接続します。
/media/uploads/HinoNaka/img1.jpg
シリアルポートは下記設定としてください。

Baud rate115200
Data8 bit
Paritynone
Stop1 bit
Flow controlnone

5. 正常に書込みが終了したらGR-PEACHのRESETボタンを押下します。

6. ターミナルS/W上に下記メッセージが表示されます。
/media/uploads/HinoNaka/img2.jpg

7. Enterキーを押下してコード入力モードに移行します。
/media/uploads/HinoNaka/img3.jpg

8. 実行するJavascriptコードをターミナルソフトウェアに貼り付けてEnterキーを押下すると、実行開始します。Javascriptコード例については、test/case.txtを参照ください。

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