1 // SoftEther UT-VPN SourceCode
\r
3 // Copyright (C) 2004-2010 SoftEther Corporation.
\r
4 // Copyright (C) 2004-2010 University of Tsukuba, Japan.
\r
5 // Copyright (C) 2003-2010 Daiyuu Nobori.
\r
6 // All Rights Reserved.
\r
8 // http://utvpn.tsukuba.ac.jp/
\r
10 // This program is free software; you can redistribute it and/or
\r
11 // modify it under the terms of the GNU General Public License
\r
12 // version 2 as published by the Free Software Foundation.
\r
14 // This program is distributed in the hope that it will be useful,
\r
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
17 // GNU General Public License for more details.
\r
19 // You should have received a copy of the GNU General Public License version 2
\r
20 // along with this program; if not, write to the Free Software
\r
21 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
\r
23 // このファイルは GPL バージョン 2 ライセンスで公開されています。
\r
24 // 誰でもこのファイルの内容を複製、改変したり、改変したバージョンを再配布
\r
25 // することができます。ただし、原著作物を改変した場合は、原著作物の著作権表示
\r
26 // を除去することはできません。改変した著作物を配布する場合は、改変実施者の
\r
27 // 著作権表示を原著作物の著作権表示に付随して記載するようにしてください。
\r
29 // この SoftEther UT-VPN オープンソース・プロジェクトは、日本国の
\r
30 // ソフトイーサ株式会社 (SoftEther Corporation, http://www.softether.co.jp/ )
\r
31 // および筑波大学 (University of Tsukuba, http://www.tsukuba.ac.jp/ ) によって
\r
33 // 本プログラムの配布者は、本プログラムを、業としての利用以外のため、
\r
34 // および、試験または研究のために利用が行われることを想定して配布
\r
36 // SoftEther UT-VPN プロジェクトの Web サイトは http://utvpn.tsukuba.ac.jp/ に
\r
38 // 本ソフトウェアの不具合の修正、機能改良、セキュリティホールの修復などのコード
\r
39 // の改変を行った場合で、その成果物を SoftEther UT-VPN プロジェクトに提出して
\r
40 // いただける場合は、 http://utvpn.tsukuba.ac.jp/ までソースコードを送付して
\r
41 // ください。SoftEther UT-VPN プロジェクトの本体リリースまたはブランチリリース
\r
44 // GPL に基づいて原著作物が提供される本ソフトウェアの改良版を配布、販売する
\r
45 // 場合は、そのソースコードを GPL に基づいて誰にでも開示する義務が生じます。
\r
47 // 本ソフトウェアに関連する著作権、特許権、商標権はソフトイーサ株式会社
\r
48 // (SoftEther Corporation) およびその他の著作権保持者が保有しています。
\r
49 // ソフトイーサ株式会社等はこれらの権利を放棄していません。本ソフトウェアの
\r
50 // 二次著作物を配布、販売する場合は、これらの権利を侵害しないようにご注意
\r
53 // お願い: どのような通信ソフトウェアにも通常は必ず未発見の
\r
54 // セキュリティホールが潜んでいます。本ソースコードをご覧いただいた結果、
\r
55 // UT-VPN にセキュリティホールを発見された場合は、当該セキュリティホールの
\r
56 // 情報を不特定多数に開示される前に、必ず、ソフトイーサ株式会社
\r
57 // および脆弱性情報の届出を受け付ける公的機関まで通報いただき、
\r
58 // 公益保護にご協力いただきますようお願い申し上げます。
\r
60 // ソフトイーサ株式会社は、当該セキュリティホールについて迅速に対処を
\r
61 // 行い、UT-VPN および UT-VPN に関連するソフトウェアのユーザー・顧客
\r
64 // ソフトイーサへの届出先: http://www.softether.co.jp/jp/contact/
\r
65 // 日本国内の脆弱性情報届出受付公的機関:
\r
67 // http://www.ipa.go.jp/security/vuln/report/
\r
69 // 上記各事項について不明な点は、ソフトイーサ株式会社までご連絡ください。
\r
70 // 連絡先: http://www.softether.co.jp/jp/contact/
\r
72 // -----------------------------------------------
\r
75 // 新規リリース by SoftEther
\r
76 // -----------------------------------------------
\r
87 #define UNIX_THREAD_STACK_SIZE (200 * 1000) // スタックサイズ
\r
88 #define UNIX_MAX_CHILD_PROCESSES 2000000 // 最大子プロセス数
\r
89 #define UNIX_LINUX_MAX_THREADS 200000000 // 最大スレッド数
\r
90 #define UNIX_MAX_LOCKS 65536 // 最大ロック数
\r
91 #define UNIX_MAX_MEMORY (2147483648UL) // 最大メモリ容量
\r
92 #define UNIX_MAX_FD (655360) // 最大 FD 数
\r
93 #define MAXIMUM_WAIT_OBJECTS 64 // 最大 select 数
\r
95 #define UNIX_SERVICE_STOP_TIMEOUT_1 (600 * 1000) // サービス停止までのタイムアウト
\r
96 #define UNIX_SERVICE_STOP_TIMEOUT_2 (900 * 1000) // サービス停止までのタイムアウト (親プロセス)
\r
100 typedef void (SERVICE_FUNCTION)();
\r
102 #define SVC_NAME "SVC_%s_NAME"
\r
103 #define SVC_TITLE "SVC_%s_TITLE"
\r
105 #define UNIX_SVC_ARG_START "start"
\r
106 #define UNIX_SVC_ARG_STOP "stop"
\r
107 #define UNIX_SVC_ARG_EXEC_SVC "execsvc"
\r
108 #define UNIX_ARG_EXIT "exit"
\r
110 #define UNIX_SVC_MODE_START 1
\r
111 #define UNIX_SVC_MODE_STOP 2
\r
112 #define UNIX_SVC_MODE_EXEC_SVC 3
\r
113 #define UNIX_SVC_MODE_EXIT 4
\r
117 OS_DISPATCH_TABLE *UnixGetDispatchTable();
\r
120 void *UnixMemoryAlloc(UINT size);
\r
121 void *UnixMemoryReAlloc(void *addr, UINT size);
\r
122 void UnixMemoryFree(void *addr);
\r
123 UINT UnixGetTick();
\r
124 void UnixGetSystemTime(SYSTEMTIME *system_time);
\r
125 void UnixInc32(UINT *value);
\r
126 void UnixDec32(UINT *value);
\r
127 void UnixSleep(UINT time);
\r
128 LOCK *UnixNewLock();
\r
129 bool UnixLock(LOCK *lock);
\r
130 void UnixUnlock(LOCK *lock);
\r
131 void UnixUnlockEx(LOCK *lock, bool inner);
\r
132 void UnixDeleteLock(LOCK *lock);
\r
133 void UnixInitEvent(EVENT *event);
\r
134 void UnixSetEvent(EVENT *event);
\r
135 void UnixResetEvent(EVENT *event);
\r
136 bool UnixWaitEvent(EVENT *event, UINT timeout);
\r
137 void UnixFreeEvent(EVENT *event);
\r
138 bool UnixWaitThread(THREAD *t);
\r
139 void UnixFreeThread(THREAD *t);
\r
140 bool UnixInitThread(THREAD *t);
\r
141 UINT UnixThreadId();
\r
142 void *UnixFileOpen(char *name, bool write_mode, bool read_lock);
\r
143 void *UnixFileOpenW(wchar_t *name, bool write_mode, bool read_lock);
\r
144 void *UnixFileCreate(char *name);
\r
145 void *UnixFileCreateW(wchar_t *name);
\r
146 bool UnixFileWrite(void *pData, void *buf, UINT size);
\r
147 bool UnixFileRead(void *pData, void *buf, UINT size);
\r
148 void UnixFileClose(void *pData, bool no_flush);
\r
149 void UnixFileFlush(void *pData);
\r
150 UINT64 UnixFileSize(void *pData);
\r
151 bool UnixFileSeek(void *pData, UINT mode, int offset);
\r
152 bool UnixFileDelete(char *name);
\r
153 bool UnixFileDeleteW(wchar_t *name);
\r
154 bool UnixMakeDir(char *name);
\r
155 bool UnixMakeDirW(wchar_t *name);
\r
156 bool UnixDeleteDir(char *name);
\r
157 bool UnixDeleteDirW(wchar_t *name);
\r
158 CALLSTACK_DATA *UnixGetCallStack();
\r
159 bool UnixGetCallStackSymbolInfo(CALLSTACK_DATA *s);
\r
160 bool UnixFileRename(char *old_name, char *new_name);
\r
161 bool UnixFileRenameW(wchar_t *old_name, wchar_t *new_name);
\r
162 bool UnixRun(char *filename, char *arg, bool hide, bool wait);
\r
163 bool UnixRunW(wchar_t *filename, wchar_t *arg, bool hide, bool wait);
\r
164 bool UnixIsSupportedOs();
\r
165 void UnixGetOsInfo(OS_INFO *info);
\r
166 void UnixAlert(char *msg, char *caption);
\r
167 void UnixAlertW(wchar_t *msg, wchar_t *caption);
\r
168 char *UnixGetProductId();
\r
169 void UnixSetHighPriority();
\r
170 void UnixRestorePriority();
\r
171 void *UnixNewSingleInstance(char *instance_name);
\r
172 void UnixFreeSingleInstance(void *data);
\r
173 void UnixGetMemInfo(MEMINFO *info);
\r
177 void UnixSetThreadPriorityRealtime();
\r
178 void UnixSetThreadPriorityLow();
\r
179 void UnixSetThreadPriorityHigh();
\r
180 void UnixSetThreadPriorityIdle();
\r
181 void UnixRestoreThreadPriority();
\r
182 void UnixSetResourceLimit(UINT id, UINT value);
\r
183 UINT64 UnixGetTick64();
\r
184 void UnixSigChldHandler(int sig);
\r
185 void UnixCloseIO();
\r
186 void UnixDaemon(bool debug_mode);
\r
187 void UnixGetCurrentDir(char *dir, UINT size);
\r
188 void UnixGetCurrentDirW(wchar_t *dir, UINT size);
\r
189 bool UnixCheckExecAccess(char *name);
\r
190 bool UnixCheckExecAccessW(wchar_t *name);
\r
191 DIRLIST *UnixEnumDirEx(char *dirname, COMPARE *compare);
\r
192 DIRLIST *UnixEnumDirExW(wchar_t *dirname, COMPARE *compare);
\r
193 bool UnixGetDiskFreeMain(char *path, UINT64 *free_size, UINT64 *used_size, UINT64 *total_size);
\r
194 bool UnixGetDiskFree(char *path, UINT64 *free_size, UINT64 *used_size, UINT64 *total_size);
\r
195 bool UnixGetDiskFreeW(wchar_t *path, UINT64 *free_size, UINT64 *used_size, UINT64 *total_size);
\r
196 void UnixInitSolarisSleep();
\r
197 void UnixFreeSolarisSleep();
\r
198 void UnixSolarisSleep(UINT msec);
\r
200 UINT UnixService(int argc, char *argv[], char *name, SERVICE_FUNCTION *start, SERVICE_FUNCTION *stop);
\r
201 void UnixServiceMain(int argc, char *argv[], char *name, SERVICE_FUNCTION *start, SERVICE_FUNCTION *stop);
\r
202 void UnixGenPidFileName(char *name, UINT size);
\r
203 void UnixStartService(char *name);
\r
204 void UnixStopService(char *name);
\r
205 void UnixExecService(char *name, SERVICE_FUNCTION *start, SERVICE_FUNCTION *stop);
\r
206 void UnixUsage(char *name);
\r
207 void UnixWritePidFile(UINT pid);
\r
208 UINT UnixReadPidFile();
\r
209 bool UnixIsProcess(UINT pid);
\r
210 bool UnixWaitProcessEx(UINT pid, UINT timeout);
\r
211 void UnixWaitProcess(UINT pid);
\r
212 void UnixDeletePidFile();
\r
213 void UnixStopThread(THREAD *t, void *param);
\r