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
88 #include <Mayaqua/Mayaqua.h>
\r
91 void CheckDeadLockThread(THREAD *t, void *param)
\r
93 DEADCHECK *c = (DEADCHECK *)param;
\r
95 if (t == NULL || c == NULL)
\r
100 NoticeThreadInit(t);
\r
104 c->Unlocked = true;
\r
108 void CheckDeadLock(LOCK *lock, UINT timeout, char *name)
\r
112 char msg[MAX_PATH];
\r
123 Format(msg, sizeof(msg), "error: CheckDeadLock() Failed: %s\n", name);
\r
125 Zero(&c, sizeof(c));
\r
127 c.Timeout = timeout;
\r
128 c.Unlocked = false;
\r
130 t = NewThread(CheckDeadLockThread, &c);
\r
132 if (WaitThread(t, timeout) == false)
\r
134 if (c.Unlocked == false)
\r
141 WaitThread(t, INFINITE);
\r
149 LOCK *NewLockMain()
\r
156 if ((retry++) > OBJECT_ALLOC__MAX_RETRY)
\r
158 AbortExitEx("error: OSNewLock() failed.\n\n");
\r
160 lock = OSNewLock();
\r
165 SleepThread(OBJECT_ALLOC_FAIL_SLEEP_TIME);
\r
172 LOCK *lock = NewLockMain();
\r
175 KS_INC(KS_NEWLOCK_COUNT);
\r
176 KS_INC(KS_CURRENT_LOCK_COUNT);
\r
182 void DeleteLock(LOCK *lock)
\r
191 KS_INC(KS_DELETELOCK_COUNT);
\r
192 KS_DEC(KS_CURRENT_LOCK_COUNT);
\r
194 OSDeleteLock(lock);
\r
198 bool LockInner(LOCK *lock)
\r
207 KS_INC(KS_LOCK_COUNT);
\r
208 KS_INC(KS_CURRENT_LOCKED_COUNT);
\r
210 return OSLock(lock);
\r
214 void UnlockInner(LOCK *lock)
\r
223 KS_INC(KS_UNLOCK_COUNT);
\r
224 KS_DEC(KS_CURRENT_LOCKED_COUNT);
\r
230 COUNTER *NewCounter()
\r
235 c = Malloc(sizeof(COUNTER));
\r
242 c->lock = NewLock();
\r
245 KS_INC(KS_NEW_COUNTER_COUNT);
\r
251 void DeleteCounter(COUNTER *c)
\r
260 KS_INC(KS_DELETE_COUNTER_COUNT);
\r
261 KS_SUB(KS_CURRENT_COUNT, c->c);
\r
263 DeleteLock(c->lock);
\r
268 UINT Count(COUNTER *c)
\r
276 if (c->Ready == false)
\r
283 if (c->Ready == false)
\r
298 UINT Inc(COUNTER *c)
\r
306 if (c->Ready == false)
\r
313 if (c->Ready == false)
\r
326 KS_INC(KS_INC_COUNT);
\r
327 KS_INC(KS_CURRENT_COUNT);
\r
333 UINT Dec(COUNTER *c)
\r
341 if (c->Ready == false)
\r
348 if (c->Ready == false)
\r
368 KS_INC(KS_DEC_COUNT);
\r
369 KS_DEC(KS_CURRENT_COUNT);
\r
376 UINT Release(REF *ref)
\r
386 KS_INC(KS_RELEASE_COUNT);
\r
387 KS_DEC(KS_CURRENT_REFED_COUNT);
\r
393 KS_DEC(KS_CURRENT_REF_COUNT);
\r
394 KS_INC(KS_FREEREF_COUNT);
\r
396 DeleteCounter(ref->c);
\r
404 UINT AddRef(REF *ref)
\r
416 KS_INC(KS_ADDREF_COUNT);
\r
417 KS_INC(KS_CURRENT_REFED_COUNT);
\r
428 ref = Malloc(sizeof(REF));
\r
431 ref->c = NewCounter();
\r
437 KS_INC(KS_NEWREF_COUNT);
\r
438 KS_INC(KS_CURRENT_REF_COUNT);
\r
439 KS_INC(KS_ADDREF_COUNT);
\r
440 KS_INC(KS_CURRENT_REFED_COUNT);
\r
449 EVENT *e = Malloc(sizeof(EVENT));
\r
458 KS_INC(KS_NEWEVENT_COUNT);
\r
464 void ReleaseEvent(EVENT *e)
\r
472 if (Release(e->ref) == 0)
\r
479 void CleanupEvent(EVENT *e)
\r
494 KS_INC(KS_FREEEVENT_COUNT);
\r
510 bool Wait(EVENT *e, UINT timeout)
\r
519 KS_INC(KS_WAIT_COUNT);
\r
521 return OSWaitEvent(e, timeout);
\r