File: lzma_Threads.cpp

package info (click to toggle)
crunch-dxtc 0.55.5-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 3,624 kB
  • sloc: cpp: 64,979; ansic: 633; python: 321; makefile: 116
file content (122 lines) | stat: -rw-r--r-- 3,453 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* Threads.c -- multithreading library
2008-08-05
Igor Pavlov
Public domain */
#include "crn_core.h"
#include "lzma_Threads.h"
#include <process.h>

namespace crnlib {

static WRes GetError() {
  DWORD res = GetLastError();
  return (res) ? (WRes)(res) : 1;
}

WRes HandleToWRes(HANDLE h) {
  return (h != 0) ? 0 : GetError();
}
WRes BOOLToWRes(BOOL v) {
  return v ? 0 : GetError();
}

static WRes MyCloseHandle(HANDLE* h) {
  if (*h != NULL)
    if (!CloseHandle(*h))
      return GetError();
  *h = NULL;
  return 0;
}

WRes Thread_Create(CThread* thread, THREAD_FUNC_RET_TYPE(THREAD_FUNC_CALL_TYPE* startAddress)(void*), LPVOID parameter) {
  unsigned threadId; /* Windows Me/98/95: threadId parameter may not be NULL in _beginthreadex/CreateThread functions */
  thread->handle =
      /* CreateThread(0, 0, startAddress, parameter, 0, &threadId); */
      (HANDLE)_beginthreadex(NULL, 0, startAddress, parameter, 0, &threadId);
  /* maybe we must use errno here, but probably GetLastError() is also OK. */
  return HandleToWRes(thread->handle);
}

WRes WaitObject(HANDLE h) {
  return (WRes)WaitForSingleObject(h, INFINITE);
}

WRes Thread_Wait(CThread* thread) {
  if (thread->handle == NULL)
    return 1;
  return WaitObject(thread->handle);
}

WRes Thread_Close(CThread* thread) {
  return MyCloseHandle(&thread->handle);
}

WRes Event_Create(CEvent* p, BOOL manualReset, int initialSignaled) {
  p->handle = CreateEvent(NULL, manualReset, (initialSignaled ? TRUE : FALSE), NULL);
  return HandleToWRes(p->handle);
}

WRes ManualResetEvent_Create(CManualResetEvent* p, int initialSignaled) {
  return Event_Create(p, TRUE, initialSignaled);
}
WRes ManualResetEvent_CreateNotSignaled(CManualResetEvent* p) {
  return ManualResetEvent_Create(p, 0);
}

WRes AutoResetEvent_Create(CAutoResetEvent* p, int initialSignaled) {
  return Event_Create(p, FALSE, initialSignaled);
}
WRes AutoResetEvent_CreateNotSignaled(CAutoResetEvent* p) {
  return AutoResetEvent_Create(p, 0);
}

WRes Event_Set(CEvent* p) {
  return BOOLToWRes(SetEvent(p->handle));
}
WRes Event_Reset(CEvent* p) {
  return BOOLToWRes(ResetEvent(p->handle));
}
WRes Event_Wait(CEvent* p) {
  return WaitObject(p->handle);
}
WRes Event_Close(CEvent* p) {
  return MyCloseHandle(&p->handle);
}

WRes Semaphore_Create(CSemaphore* p, UInt32 initiallyCount, UInt32 maxCount) {
  p->handle = CreateSemaphore(NULL, (LONG)initiallyCount, (LONG)maxCount, NULL);
  return HandleToWRes(p->handle);
}

WRes Semaphore_Release(CSemaphore* p, LONG releaseCount, LONG* previousCount) {
  return BOOLToWRes(ReleaseSemaphore(p->handle, releaseCount, previousCount));
}
WRes Semaphore_ReleaseN(CSemaphore* p, UInt32 releaseCount) {
  return Semaphore_Release(p, (LONG)releaseCount, NULL);
}
WRes Semaphore_Release1(CSemaphore* p) {
  return Semaphore_ReleaseN(p, 1);
}

WRes Semaphore_Wait(CSemaphore* p) {
  return WaitObject(p->handle);
}
WRes Semaphore_Close(CSemaphore* p) {
  return MyCloseHandle(&p->handle);
}

WRes CriticalSection_Init(CCriticalSection* p) {
#ifdef _MSC_VER
  /* InitializeCriticalSection can raise only STATUS_NO_MEMORY exception */
  __try {
    InitializeCriticalSection(p);
    /* InitializeCriticalSectionAndSpinCount(p, 0); */
  } __except (EXCEPTION_EXECUTE_HANDLER) {
    return 1;
  }
#else
  InitializeCriticalSection(p);
#endif
  return 0;
}
}