Modernize Mutex
- Based on C++11's `mutex` - No more need to allocate-deallocate or check for null - No pointer anymore, just a member variable - Platform-specific implementations no longer needed - Simpler for `NO_THREADS` - `BinaryMutex` added for special cases as the non-recursive version - `MutexLock` now takes a reference. At this point the cases of null `Mutex`es are rare. If you ever need that, just don't use `MutexLock`. - `ScopedMutexLock` is dropped and replaced by `MutexLock`, because they were pretty much the same.
This commit is contained in:
parent
b450036120
commit
4ddcdc031b
@ -2717,17 +2717,17 @@ _Semaphore::~_Semaphore() {
|
|||||||
|
|
||||||
void _Mutex::lock() {
|
void _Mutex::lock() {
|
||||||
|
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
Error _Mutex::try_lock() {
|
Error _Mutex::try_lock() {
|
||||||
|
|
||||||
return mutex->try_lock();
|
return mutex.try_lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void _Mutex::unlock() {
|
void _Mutex::unlock() {
|
||||||
|
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void _Mutex::_bind_methods() {
|
void _Mutex::_bind_methods() {
|
||||||
@ -2737,16 +2737,6 @@ void _Mutex::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("unlock"), &_Mutex::unlock);
|
ClassDB::bind_method(D_METHOD("unlock"), &_Mutex::unlock);
|
||||||
}
|
}
|
||||||
|
|
||||||
_Mutex::_Mutex() {
|
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
}
|
|
||||||
|
|
||||||
_Mutex::~_Mutex() {
|
|
||||||
|
|
||||||
memdelete(mutex);
|
|
||||||
}
|
|
||||||
|
|
||||||
///////////////
|
///////////////
|
||||||
|
|
||||||
void _Thread::_start_func(void *ud) {
|
void _Thread::_start_func(void *ud) {
|
||||||
|
@ -652,7 +652,7 @@ public:
|
|||||||
class _Mutex : public Reference {
|
class _Mutex : public Reference {
|
||||||
|
|
||||||
GDCLASS(_Mutex, Reference);
|
GDCLASS(_Mutex, Reference);
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
@ -660,9 +660,6 @@ public:
|
|||||||
void lock();
|
void lock();
|
||||||
Error try_lock();
|
Error try_lock();
|
||||||
void unlock();
|
void unlock();
|
||||||
|
|
||||||
_Mutex();
|
|
||||||
~_Mutex();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class _Semaphore : public Reference {
|
class _Semaphore : public Reference {
|
||||||
|
@ -35,14 +35,12 @@
|
|||||||
|
|
||||||
void CommandQueueMT::lock() {
|
void CommandQueueMT::lock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CommandQueueMT::unlock() {
|
void CommandQueueMT::unlock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CommandQueueMT::wait_for_flush() {
|
void CommandQueueMT::wait_for_flush() {
|
||||||
@ -107,7 +105,6 @@ CommandQueueMT::CommandQueueMT(bool p_sync) {
|
|||||||
read_ptr_and_epoch = 0;
|
read_ptr_and_epoch = 0;
|
||||||
write_ptr_and_epoch = 0;
|
write_ptr_and_epoch = 0;
|
||||||
dealloc_ptr = 0;
|
dealloc_ptr = 0;
|
||||||
mutex = Mutex::create();
|
|
||||||
|
|
||||||
command_mem_size = GLOBAL_DEF_RST("memory/limits/command_queue/multithreading_queue_size_kb", DEFAULT_COMMAND_MEM_SIZE_KB);
|
command_mem_size = GLOBAL_DEF_RST("memory/limits/command_queue/multithreading_queue_size_kb", DEFAULT_COMMAND_MEM_SIZE_KB);
|
||||||
ProjectSettings::get_singleton()->set_custom_property_info("memory/limits/command_queue/multithreading_queue_size_kb", PropertyInfo(Variant::INT, "memory/limits/command_queue/multithreading_queue_size_kb", PROPERTY_HINT_RANGE, "1,4096,1,or_greater"));
|
ProjectSettings::get_singleton()->set_custom_property_info("memory/limits/command_queue/multithreading_queue_size_kb", PropertyInfo(Variant::INT, "memory/limits/command_queue/multithreading_queue_size_kb", PROPERTY_HINT_RANGE, "1,4096,1,or_greater"));
|
||||||
@ -130,7 +127,6 @@ CommandQueueMT::~CommandQueueMT() {
|
|||||||
|
|
||||||
if (sync)
|
if (sync)
|
||||||
memdelete(sync);
|
memdelete(sync);
|
||||||
memdelete(mutex);
|
|
||||||
for (int i = 0; i < SYNC_SEMAPHORES; i++) {
|
for (int i = 0; i < SYNC_SEMAPHORES; i++) {
|
||||||
|
|
||||||
memdelete(sync_sems[i].sem);
|
memdelete(sync_sems[i].sem);
|
||||||
|
@ -321,7 +321,7 @@ class CommandQueueMT {
|
|||||||
uint32_t dealloc_ptr;
|
uint32_t dealloc_ptr;
|
||||||
uint32_t command_mem_size;
|
uint32_t command_mem_size;
|
||||||
SyncSemaphore sync_sems[SYNC_SEMAPHORES];
|
SyncSemaphore sync_sems[SYNC_SEMAPHORES];
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
Semaphore *sync;
|
Semaphore *sync;
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
|
@ -42,14 +42,14 @@
|
|||||||
|
|
||||||
void FileAccessNetworkClient::lock_mutex() {
|
void FileAccessNetworkClient::lock_mutex() {
|
||||||
|
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
lockcount++;
|
lockcount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileAccessNetworkClient::unlock_mutex() {
|
void FileAccessNetworkClient::unlock_mutex() {
|
||||||
|
|
||||||
lockcount--;
|
lockcount--;
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileAccessNetworkClient::put_32(int p_32) {
|
void FileAccessNetworkClient::put_32(int p_32) {
|
||||||
@ -97,7 +97,7 @@ void FileAccessNetworkClient::_thread_func() {
|
|||||||
lock_mutex();
|
lock_mutex();
|
||||||
DEBUG_PRINT("MUTEX PASS");
|
DEBUG_PRINT("MUTEX PASS");
|
||||||
|
|
||||||
blockrequest_mutex->lock();
|
blockrequest_mutex.lock();
|
||||||
while (block_requests.size()) {
|
while (block_requests.size()) {
|
||||||
put_32(block_requests.front()->get().id);
|
put_32(block_requests.front()->get().id);
|
||||||
put_32(FileAccessNetwork::COMMAND_READ_BLOCK);
|
put_32(FileAccessNetwork::COMMAND_READ_BLOCK);
|
||||||
@ -105,7 +105,7 @@ void FileAccessNetworkClient::_thread_func() {
|
|||||||
put_32(block_requests.front()->get().size);
|
put_32(block_requests.front()->get().size);
|
||||||
block_requests.pop_front();
|
block_requests.pop_front();
|
||||||
}
|
}
|
||||||
blockrequest_mutex->unlock();
|
blockrequest_mutex.unlock();
|
||||||
|
|
||||||
DEBUG_PRINT("THREAD ITER");
|
DEBUG_PRINT("THREAD ITER");
|
||||||
|
|
||||||
@ -225,8 +225,6 @@ FileAccessNetworkClient *FileAccessNetworkClient::singleton = NULL;
|
|||||||
FileAccessNetworkClient::FileAccessNetworkClient() {
|
FileAccessNetworkClient::FileAccessNetworkClient() {
|
||||||
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
mutex = Mutex::create();
|
|
||||||
blockrequest_mutex = Mutex::create();
|
|
||||||
quit = false;
|
quit = false;
|
||||||
singleton = this;
|
singleton = this;
|
||||||
last_id = 0;
|
last_id = 0;
|
||||||
@ -244,8 +242,6 @@ FileAccessNetworkClient::~FileAccessNetworkClient() {
|
|||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
memdelete(blockrequest_mutex);
|
|
||||||
memdelete(mutex);
|
|
||||||
memdelete(sem);
|
memdelete(sem);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,10 +255,10 @@ void FileAccessNetwork::_set_block(int p_offset, const Vector<uint8_t> &p_block)
|
|||||||
ERR_FAIL_COND((p_block.size() != (int)(total_size % page_size)));
|
ERR_FAIL_COND((p_block.size() != (int)(total_size % page_size)));
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer_mutex->lock();
|
buffer_mutex.lock();
|
||||||
pages.write[page].buffer = p_block;
|
pages.write[page].buffer = p_block;
|
||||||
pages.write[page].queued = false;
|
pages.write[page].queued = false;
|
||||||
buffer_mutex->unlock();
|
buffer_mutex.unlock();
|
||||||
|
|
||||||
if (waiting_on_page == page) {
|
if (waiting_on_page == page) {
|
||||||
waiting_on_page = -1;
|
waiting_on_page = -1;
|
||||||
@ -385,14 +381,14 @@ void FileAccessNetwork::_queue_page(int p_page) const {
|
|||||||
|
|
||||||
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
||||||
|
|
||||||
nc->blockrequest_mutex->lock();
|
nc->blockrequest_mutex.lock();
|
||||||
FileAccessNetworkClient::BlockRequest br;
|
FileAccessNetworkClient::BlockRequest br;
|
||||||
br.id = id;
|
br.id = id;
|
||||||
br.offset = size_t(p_page) * page_size;
|
br.offset = size_t(p_page) * page_size;
|
||||||
br.size = page_size;
|
br.size = page_size;
|
||||||
nc->block_requests.push_back(br);
|
nc->block_requests.push_back(br);
|
||||||
pages.write[p_page].queued = true;
|
pages.write[p_page].queued = true;
|
||||||
nc->blockrequest_mutex->unlock();
|
nc->blockrequest_mutex.unlock();
|
||||||
DEBUG_PRINT("QUEUE PAGE POST");
|
DEBUG_PRINT("QUEUE PAGE POST");
|
||||||
nc->sem->post();
|
nc->sem->post();
|
||||||
DEBUG_PRINT("queued " + itos(p_page));
|
DEBUG_PRINT("queued " + itos(p_page));
|
||||||
@ -418,14 +414,14 @@ int FileAccessNetwork::get_buffer(uint8_t *p_dst, int p_length) const {
|
|||||||
int page = pos / page_size;
|
int page = pos / page_size;
|
||||||
|
|
||||||
if (page != last_page) {
|
if (page != last_page) {
|
||||||
buffer_mutex->lock();
|
buffer_mutex.lock();
|
||||||
if (pages[page].buffer.empty()) {
|
if (pages[page].buffer.empty()) {
|
||||||
waiting_on_page = page;
|
waiting_on_page = page;
|
||||||
for (int j = 0; j < read_ahead; j++) {
|
for (int j = 0; j < read_ahead; j++) {
|
||||||
|
|
||||||
_queue_page(page + j);
|
_queue_page(page + j);
|
||||||
}
|
}
|
||||||
buffer_mutex->unlock();
|
buffer_mutex.unlock();
|
||||||
DEBUG_PRINT("wait");
|
DEBUG_PRINT("wait");
|
||||||
page_sem->wait();
|
page_sem->wait();
|
||||||
DEBUG_PRINT("done");
|
DEBUG_PRINT("done");
|
||||||
@ -436,7 +432,7 @@ int FileAccessNetwork::get_buffer(uint8_t *p_dst, int p_length) const {
|
|||||||
_queue_page(page + j);
|
_queue_page(page + j);
|
||||||
}
|
}
|
||||||
//queue pages
|
//queue pages
|
||||||
buffer_mutex->unlock();
|
buffer_mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
buff = pages.write[page].buffer.ptrw();
|
buff = pages.write[page].buffer.ptrw();
|
||||||
@ -524,7 +520,6 @@ FileAccessNetwork::FileAccessNetwork() {
|
|||||||
pos = 0;
|
pos = 0;
|
||||||
sem = Semaphore::create();
|
sem = Semaphore::create();
|
||||||
page_sem = Semaphore::create();
|
page_sem = Semaphore::create();
|
||||||
buffer_mutex = Mutex::create();
|
|
||||||
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
||||||
nc->lock_mutex();
|
nc->lock_mutex();
|
||||||
id = nc->last_id++;
|
id = nc->last_id++;
|
||||||
@ -542,7 +537,6 @@ FileAccessNetwork::~FileAccessNetwork() {
|
|||||||
close();
|
close();
|
||||||
memdelete(sem);
|
memdelete(sem);
|
||||||
memdelete(page_sem);
|
memdelete(page_sem);
|
||||||
memdelete(buffer_mutex);
|
|
||||||
|
|
||||||
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
FileAccessNetworkClient *nc = FileAccessNetworkClient::singleton;
|
||||||
nc->lock_mutex();
|
nc->lock_mutex();
|
||||||
|
@ -52,8 +52,8 @@ class FileAccessNetworkClient {
|
|||||||
Semaphore *sem;
|
Semaphore *sem;
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
bool quit;
|
bool quit;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
Mutex *blockrequest_mutex;
|
Mutex blockrequest_mutex;
|
||||||
Map<int, FileAccessNetwork *> accesses;
|
Map<int, FileAccessNetwork *> accesses;
|
||||||
Ref<StreamPeerTCP> client;
|
Ref<StreamPeerTCP> client;
|
||||||
int last_id;
|
int last_id;
|
||||||
@ -87,7 +87,7 @@ class FileAccessNetwork : public FileAccess {
|
|||||||
|
|
||||||
Semaphore *sem;
|
Semaphore *sem;
|
||||||
Semaphore *page_sem;
|
Semaphore *page_sem;
|
||||||
Mutex *buffer_mutex;
|
Mutex buffer_mutex;
|
||||||
bool opened;
|
bool opened;
|
||||||
size_t total_size;
|
size_t total_size;
|
||||||
mutable size_t pos;
|
mutable size_t pos;
|
||||||
|
@ -70,7 +70,7 @@ struct _IP_ResolverPrivate {
|
|||||||
return IP::RESOLVER_INVALID_ID;
|
return IP::RESOLVER_INVALID_ID;
|
||||||
}
|
}
|
||||||
|
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
Semaphore *sem;
|
Semaphore *sem;
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
@ -100,9 +100,9 @@ struct _IP_ResolverPrivate {
|
|||||||
|
|
||||||
ipr->sem->wait();
|
ipr->sem->wait();
|
||||||
|
|
||||||
ipr->mutex->lock();
|
ipr->mutex.lock();
|
||||||
ipr->resolve_queues();
|
ipr->resolve_queues();
|
||||||
ipr->mutex->unlock();
|
ipr->mutex.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -115,30 +115,30 @@ struct _IP_ResolverPrivate {
|
|||||||
|
|
||||||
IP_Address IP::resolve_hostname(const String &p_hostname, IP::Type p_type) {
|
IP_Address IP::resolve_hostname(const String &p_hostname, IP::Type p_type) {
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
|
|
||||||
String key = _IP_ResolverPrivate::get_cache_key(p_hostname, p_type);
|
String key = _IP_ResolverPrivate::get_cache_key(p_hostname, p_type);
|
||||||
if (resolver->cache.has(key) && resolver->cache[key].is_valid()) {
|
if (resolver->cache.has(key) && resolver->cache[key].is_valid()) {
|
||||||
IP_Address res = resolver->cache[key];
|
IP_Address res = resolver->cache[key];
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
IP_Address res = _resolve_hostname(p_hostname, p_type);
|
IP_Address res = _resolve_hostname(p_hostname, p_type);
|
||||||
resolver->cache[key] = res;
|
resolver->cache[key] = res;
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
IP::ResolverID IP::resolve_hostname_queue_item(const String &p_hostname, IP::Type p_type) {
|
IP::ResolverID IP::resolve_hostname_queue_item(const String &p_hostname, IP::Type p_type) {
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
|
|
||||||
ResolverID id = resolver->find_empty_id();
|
ResolverID id = resolver->find_empty_id();
|
||||||
|
|
||||||
if (id == RESOLVER_INVALID_ID) {
|
if (id == RESOLVER_INVALID_ID) {
|
||||||
WARN_PRINT("Out of resolver queries");
|
WARN_PRINT("Out of resolver queries");
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +157,7 @@ IP::ResolverID IP::resolve_hostname_queue_item(const String &p_hostname, IP::Typ
|
|||||||
resolver->resolve_queues();
|
resolver->resolve_queues();
|
||||||
}
|
}
|
||||||
|
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,15 +165,15 @@ IP::ResolverStatus IP::get_resolve_item_status(ResolverID p_id) const {
|
|||||||
|
|
||||||
ERR_FAIL_INDEX_V(p_id, IP::RESOLVER_MAX_QUERIES, IP::RESOLVER_STATUS_NONE);
|
ERR_FAIL_INDEX_V(p_id, IP::RESOLVER_MAX_QUERIES, IP::RESOLVER_STATUS_NONE);
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
if (resolver->queue[p_id].status == IP::RESOLVER_STATUS_NONE) {
|
if (resolver->queue[p_id].status == IP::RESOLVER_STATUS_NONE) {
|
||||||
ERR_PRINT("Condition status == IP::RESOLVER_STATUS_NONE");
|
ERR_PRINT("Condition status == IP::RESOLVER_STATUS_NONE");
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return IP::RESOLVER_STATUS_NONE;
|
return IP::RESOLVER_STATUS_NONE;
|
||||||
}
|
}
|
||||||
IP::ResolverStatus res = resolver->queue[p_id].status;
|
IP::ResolverStatus res = resolver->queue[p_id].status;
|
||||||
|
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -181,17 +181,17 @@ IP_Address IP::get_resolve_item_address(ResolverID p_id) const {
|
|||||||
|
|
||||||
ERR_FAIL_INDEX_V(p_id, IP::RESOLVER_MAX_QUERIES, IP_Address());
|
ERR_FAIL_INDEX_V(p_id, IP::RESOLVER_MAX_QUERIES, IP_Address());
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
|
|
||||||
if (resolver->queue[p_id].status != IP::RESOLVER_STATUS_DONE) {
|
if (resolver->queue[p_id].status != IP::RESOLVER_STATUS_DONE) {
|
||||||
ERR_PRINTS("Resolve of '" + resolver->queue[p_id].hostname + "'' didn't complete yet.");
|
ERR_PRINTS("Resolve of '" + resolver->queue[p_id].hostname + "'' didn't complete yet.");
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return IP_Address();
|
return IP_Address();
|
||||||
}
|
}
|
||||||
|
|
||||||
IP_Address res = resolver->queue[p_id].response;
|
IP_Address res = resolver->queue[p_id].response;
|
||||||
|
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,16 +199,16 @@ void IP::erase_resolve_item(ResolverID p_id) {
|
|||||||
|
|
||||||
ERR_FAIL_INDEX(p_id, IP::RESOLVER_MAX_QUERIES);
|
ERR_FAIL_INDEX(p_id, IP::RESOLVER_MAX_QUERIES);
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
|
|
||||||
resolver->queue[p_id].status = IP::RESOLVER_STATUS_NONE;
|
resolver->queue[p_id].status = IP::RESOLVER_STATUS_NONE;
|
||||||
|
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IP::clear_cache(const String &p_hostname) {
|
void IP::clear_cache(const String &p_hostname) {
|
||||||
|
|
||||||
resolver->mutex->lock();
|
resolver->mutex.lock();
|
||||||
|
|
||||||
if (p_hostname.empty()) {
|
if (p_hostname.empty()) {
|
||||||
resolver->cache.clear();
|
resolver->cache.clear();
|
||||||
@ -219,7 +219,7 @@ void IP::clear_cache(const String &p_hostname) {
|
|||||||
resolver->cache.erase(_IP_ResolverPrivate::get_cache_key(p_hostname, IP::TYPE_ANY));
|
resolver->cache.erase(_IP_ResolverPrivate::get_cache_key(p_hostname, IP::TYPE_ANY));
|
||||||
}
|
}
|
||||||
|
|
||||||
resolver->mutex->unlock();
|
resolver->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
Array IP::_get_local_addresses() const {
|
Array IP::_get_local_addresses() const {
|
||||||
@ -315,7 +315,6 @@ IP::IP() {
|
|||||||
singleton = this;
|
singleton = this;
|
||||||
resolver = memnew(_IP_ResolverPrivate);
|
resolver = memnew(_IP_ResolverPrivate);
|
||||||
resolver->sem = NULL;
|
resolver->sem = NULL;
|
||||||
resolver->mutex = Mutex::create();
|
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
|
|
||||||
@ -349,6 +348,5 @@ IP::~IP() {
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
memdelete(resolver->mutex);
|
|
||||||
memdelete(resolver);
|
memdelete(resolver);
|
||||||
}
|
}
|
||||||
|
@ -289,9 +289,7 @@ RES ResourceLoader::_load(const String &p_path, const String &p_original_path, c
|
|||||||
bool ResourceLoader::_add_to_loading_map(const String &p_path) {
|
bool ResourceLoader::_add_to_loading_map(const String &p_path) {
|
||||||
|
|
||||||
bool success;
|
bool success;
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.lock();
|
||||||
loading_map_mutex->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
LoadingMapKey key;
|
LoadingMapKey key;
|
||||||
key.path = p_path;
|
key.path = p_path;
|
||||||
@ -304,17 +302,13 @@ bool ResourceLoader::_add_to_loading_map(const String &p_path) {
|
|||||||
success = true;
|
success = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.unlock();
|
||||||
loading_map_mutex->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResourceLoader::_remove_from_loading_map(const String &p_path) {
|
void ResourceLoader::_remove_from_loading_map(const String &p_path) {
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.lock();
|
||||||
loading_map_mutex->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
LoadingMapKey key;
|
LoadingMapKey key;
|
||||||
key.path = p_path;
|
key.path = p_path;
|
||||||
@ -322,15 +316,11 @@ void ResourceLoader::_remove_from_loading_map(const String &p_path) {
|
|||||||
|
|
||||||
loading_map.erase(key);
|
loading_map.erase(key);
|
||||||
|
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.unlock();
|
||||||
loading_map_mutex->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResourceLoader::_remove_from_loading_map_and_thread(const String &p_path, Thread::ID p_thread) {
|
void ResourceLoader::_remove_from_loading_map_and_thread(const String &p_path, Thread::ID p_thread) {
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.lock();
|
||||||
loading_map_mutex->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
LoadingMapKey key;
|
LoadingMapKey key;
|
||||||
key.path = p_path;
|
key.path = p_path;
|
||||||
@ -338,9 +328,7 @@ void ResourceLoader::_remove_from_loading_map_and_thread(const String &p_path, T
|
|||||||
|
|
||||||
loading_map.erase(key);
|
loading_map.erase(key);
|
||||||
|
|
||||||
if (loading_map_mutex) {
|
loading_map_mutex.unlock();
|
||||||
loading_map_mutex->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p_no_cache, Error *r_error) {
|
RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p_no_cache, Error *r_error) {
|
||||||
@ -994,15 +982,9 @@ void ResourceLoader::remove_custom_loaders() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Mutex *ResourceLoader::loading_map_mutex = NULL;
|
Mutex ResourceLoader::loading_map_mutex;
|
||||||
HashMap<ResourceLoader::LoadingMapKey, int, ResourceLoader::LoadingMapKeyHasher> ResourceLoader::loading_map;
|
HashMap<ResourceLoader::LoadingMapKey, int, ResourceLoader::LoadingMapKeyHasher> ResourceLoader::loading_map;
|
||||||
|
|
||||||
void ResourceLoader::initialize() {
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
loading_map_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void ResourceLoader::finalize() {
|
void ResourceLoader::finalize() {
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
const LoadingMapKey *K = NULL;
|
const LoadingMapKey *K = NULL;
|
||||||
@ -1010,8 +992,6 @@ void ResourceLoader::finalize() {
|
|||||||
ERR_PRINTS("Exited while resource is being loaded: " + K->path);
|
ERR_PRINTS("Exited while resource is being loaded: " + K->path);
|
||||||
}
|
}
|
||||||
loading_map.clear();
|
loading_map.clear();
|
||||||
memdelete(loading_map_mutex);
|
|
||||||
loading_map_mutex = NULL;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ class ResourceLoader {
|
|||||||
static ResourceLoadedCallback _loaded_callback;
|
static ResourceLoadedCallback _loaded_callback;
|
||||||
|
|
||||||
static Ref<ResourceFormatLoader> _find_custom_resource_format_loader(String path);
|
static Ref<ResourceFormatLoader> _find_custom_resource_format_loader(String path);
|
||||||
static Mutex *loading_map_mutex;
|
static Mutex loading_map_mutex;
|
||||||
|
|
||||||
//used to track paths being loaded in a thread, avoids cyclic recursion
|
//used to track paths being loaded in a thread, avoids cyclic recursion
|
||||||
struct LoadingMapKey {
|
struct LoadingMapKey {
|
||||||
@ -197,7 +197,6 @@ public:
|
|||||||
static void add_custom_loaders();
|
static void add_custom_loaders();
|
||||||
static void remove_custom_loaders();
|
static void remove_custom_loaders();
|
||||||
|
|
||||||
static void initialize();
|
|
||||||
static void finalize();
|
static void finalize();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -30,31 +30,19 @@
|
|||||||
|
|
||||||
#include "mutex.h"
|
#include "mutex.h"
|
||||||
|
|
||||||
#include "core/error_macros.h"
|
static Mutex _global_mutex;
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
|
|
||||||
Mutex *(*Mutex::create_func)(bool) = 0;
|
|
||||||
|
|
||||||
Mutex *Mutex::create(bool p_recursive) {
|
|
||||||
|
|
||||||
ERR_FAIL_COND_V(!create_func, 0);
|
|
||||||
|
|
||||||
return create_func(p_recursive);
|
|
||||||
}
|
|
||||||
|
|
||||||
Mutex::~Mutex() {
|
|
||||||
}
|
|
||||||
|
|
||||||
Mutex *_global_mutex = NULL;
|
|
||||||
|
|
||||||
void _global_lock() {
|
void _global_lock() {
|
||||||
|
_global_mutex.lock();
|
||||||
if (_global_mutex)
|
|
||||||
_global_mutex->lock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void _global_unlock() {
|
void _global_unlock() {
|
||||||
|
_global_mutex.unlock();
|
||||||
if (_global_mutex)
|
|
||||||
_global_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef NO_THREADS
|
||||||
|
|
||||||
|
template class MutexImpl<std::recursive_mutex>;
|
||||||
|
template class MutexImpl<std::mutex>;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
101
core/os/mutex.h
101
core/os/mutex.h
@ -32,42 +32,89 @@
|
|||||||
#define MUTEX_H
|
#define MUTEX_H
|
||||||
|
|
||||||
#include "core/error_list.h"
|
#include "core/error_list.h"
|
||||||
|
#include "core/typedefs.h"
|
||||||
|
|
||||||
/**
|
#if !defined(NO_THREADS)
|
||||||
* @class Mutex
|
|
||||||
* @author Juan Linietsky
|
|
||||||
* Portable Mutex (thread-safe locking) implementation.
|
|
||||||
* Mutexes are always recursive ( they don't self-lock in a single thread ).
|
|
||||||
* Mutexes can be used with a Lockp object like this, to avoid having to worry about unlocking:
|
|
||||||
* Lockp( mutex );
|
|
||||||
*/
|
|
||||||
|
|
||||||
class Mutex {
|
#include <mutex>
|
||||||
protected:
|
|
||||||
static Mutex *(*create_func)(bool);
|
template <class StdMutexT>
|
||||||
|
class MutexImpl {
|
||||||
|
mutable StdMutexT mutex;
|
||||||
|
friend class MutexLock;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void lock() = 0; ///< Lock the mutex, block if locked by someone else
|
_ALWAYS_INLINE_ void lock() const {
|
||||||
virtual void unlock() = 0; ///< Unlock the mutex, let other threads continue
|
mutex.lock();
|
||||||
virtual Error try_lock() = 0; ///< Attempt to lock the mutex, OK on success, ERROR means it can't lock.
|
}
|
||||||
|
|
||||||
static Mutex *create(bool p_recursive = true); ///< Create a mutex
|
_ALWAYS_INLINE_ void unlock() const {
|
||||||
|
mutex.unlock();
|
||||||
|
}
|
||||||
|
|
||||||
virtual ~Mutex();
|
_ALWAYS_INLINE_ Error try_lock() const {
|
||||||
|
return mutex.try_lock() ? OK : ERR_BUSY;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// This is written this way instead of being a template to overcome a limitation of C++ pre-17
|
||||||
|
// that would require MutexLock to be used like this: MutexLock<Mutex> lock;
|
||||||
|
class MutexLock {
|
||||||
|
union {
|
||||||
|
std::recursive_mutex *recursive_mutex;
|
||||||
|
std::mutex *mutex;
|
||||||
|
};
|
||||||
|
bool recursive;
|
||||||
|
|
||||||
|
public:
|
||||||
|
_ALWAYS_INLINE_ explicit MutexLock(const MutexImpl<std::recursive_mutex> &p_mutex) :
|
||||||
|
recursive_mutex(&p_mutex.mutex),
|
||||||
|
recursive(true) {
|
||||||
|
recursive_mutex->lock();
|
||||||
|
}
|
||||||
|
_ALWAYS_INLINE_ explicit MutexLock(const MutexImpl<std::mutex> &p_mutex) :
|
||||||
|
mutex(&p_mutex.mutex),
|
||||||
|
recursive(false) {
|
||||||
|
mutex->lock();
|
||||||
|
}
|
||||||
|
|
||||||
|
_ALWAYS_INLINE_ ~MutexLock() {
|
||||||
|
if (recursive) {
|
||||||
|
recursive_mutex->unlock();
|
||||||
|
} else {
|
||||||
|
mutex->unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
using Mutex = MutexImpl<std::recursive_mutex>; // Recursive, for general use
|
||||||
|
using BinaryMutex = MutexImpl<std::mutex>; // Non-recursive, handle with care
|
||||||
|
|
||||||
|
extern template class MutexImpl<std::recursive_mutex>;
|
||||||
|
extern template class MutexImpl<std::mutex>;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
class FakeMutex {
|
||||||
|
FakeMutex() {}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class MutexT>
|
||||||
|
class MutexImpl {
|
||||||
|
public:
|
||||||
|
_ALWAYS_INLINE_ void lock() const {}
|
||||||
|
_ALWAYS_INLINE_ void unlock() const {}
|
||||||
|
_ALWAYS_INLINE_ Error try_lock() const { return OK; }
|
||||||
};
|
};
|
||||||
|
|
||||||
class MutexLock {
|
class MutexLock {
|
||||||
|
|
||||||
Mutex *mutex;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MutexLock(Mutex *p_mutex) {
|
explicit MutexLock(const MutexImpl<FakeMutex> &p_mutex) {}
|
||||||
mutex = p_mutex;
|
|
||||||
if (mutex) mutex->lock();
|
|
||||||
}
|
|
||||||
~MutexLock() {
|
|
||||||
if (mutex) mutex->unlock();
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
using Mutex = MutexImpl<FakeMutex>;
|
||||||
|
using BinaryMutex = MutexImpl<FakeMutex>; // Non-recursive, handle with care
|
||||||
|
|
||||||
|
#endif // !NO_THREADS
|
||||||
|
|
||||||
|
#endif // MUTEX_H
|
||||||
|
@ -41,8 +41,6 @@
|
|||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
class Mutex;
|
|
||||||
|
|
||||||
class OS {
|
class OS {
|
||||||
|
|
||||||
static OS *singleton;
|
static OS *singleton;
|
||||||
|
@ -40,14 +40,6 @@ void ThreadDummy::make_default() {
|
|||||||
Thread::create_func = &ThreadDummy::create;
|
Thread::create_func = &ThreadDummy::create;
|
||||||
};
|
};
|
||||||
|
|
||||||
Mutex *MutexDummy::create(bool p_recursive) {
|
|
||||||
return memnew(MutexDummy);
|
|
||||||
};
|
|
||||||
|
|
||||||
void MutexDummy::make_default() {
|
|
||||||
Mutex::create_func = &MutexDummy::create;
|
|
||||||
};
|
|
||||||
|
|
||||||
Semaphore *SemaphoreDummy::create() {
|
Semaphore *SemaphoreDummy::create() {
|
||||||
return memnew(SemaphoreDummy);
|
return memnew(SemaphoreDummy);
|
||||||
};
|
};
|
||||||
|
@ -45,18 +45,6 @@ public:
|
|||||||
static void make_default();
|
static void make_default();
|
||||||
};
|
};
|
||||||
|
|
||||||
class MutexDummy : public Mutex {
|
|
||||||
|
|
||||||
static Mutex *create(bool p_recursive);
|
|
||||||
|
|
||||||
public:
|
|
||||||
virtual void lock(){};
|
|
||||||
virtual void unlock(){};
|
|
||||||
virtual Error try_lock() { return OK; };
|
|
||||||
|
|
||||||
static void make_default();
|
|
||||||
};
|
|
||||||
|
|
||||||
class SemaphoreDummy : public Semaphore {
|
class SemaphoreDummy : public Semaphore {
|
||||||
|
|
||||||
static Semaphore *create();
|
static Semaphore *create();
|
||||||
|
@ -1,49 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* thread_safe.cpp */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#include "thread_safe.h"
|
|
||||||
|
|
||||||
#include "core/error_macros.h"
|
|
||||||
#include "core/os/memory.h"
|
|
||||||
|
|
||||||
ThreadSafe::ThreadSafe() {
|
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
if (!mutex) {
|
|
||||||
|
|
||||||
WARN_PRINT("THREAD_SAFE defined, but no default mutex type");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ThreadSafe::~ThreadSafe() {
|
|
||||||
|
|
||||||
if (mutex)
|
|
||||||
memdelete(mutex);
|
|
||||||
}
|
|
@ -33,50 +33,9 @@
|
|||||||
|
|
||||||
#include "core/os/mutex.h"
|
#include "core/os/mutex.h"
|
||||||
|
|
||||||
class ThreadSafe {
|
#define _THREAD_SAFE_CLASS_ mutable Mutex _thread_safe_;
|
||||||
|
#define _THREAD_SAFE_METHOD_ MutexLock _thread_safe_method_(_thread_safe_);
|
||||||
Mutex *mutex;
|
#define _THREAD_SAFE_LOCK_ _thread_safe_.lock();
|
||||||
|
#define _THREAD_SAFE_UNLOCK_ _thread_safe_.unlock();
|
||||||
public:
|
|
||||||
inline void lock() const {
|
|
||||||
if (mutex) mutex->lock();
|
|
||||||
}
|
|
||||||
inline void unlock() const {
|
|
||||||
if (mutex) mutex->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
ThreadSafe();
|
|
||||||
~ThreadSafe();
|
|
||||||
};
|
|
||||||
|
|
||||||
class ThreadSafeMethod {
|
|
||||||
|
|
||||||
const ThreadSafe *_ts;
|
|
||||||
|
|
||||||
public:
|
|
||||||
ThreadSafeMethod(const ThreadSafe *p_ts) {
|
|
||||||
|
|
||||||
_ts = p_ts;
|
|
||||||
_ts->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
~ThreadSafeMethod() { _ts->unlock(); }
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
|
|
||||||
#define _THREAD_SAFE_CLASS_ ThreadSafe __thread__safe__;
|
|
||||||
#define _THREAD_SAFE_METHOD_ ThreadSafeMethod __thread_safe_method__(&__thread__safe__);
|
|
||||||
#define _THREAD_SAFE_LOCK_ __thread__safe__.lock();
|
|
||||||
#define _THREAD_SAFE_UNLOCK_ __thread__safe__.unlock();
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define _THREAD_SAFE_CLASS_
|
|
||||||
#define _THREAD_SAFE_METHOD_
|
|
||||||
#define _THREAD_SAFE_LOCK_
|
|
||||||
#define _THREAD_SAFE_UNLOCK_
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
|
|
||||||
#include "pool_vector.h"
|
#include "pool_vector.h"
|
||||||
|
|
||||||
Mutex *pool_vector_lock = NULL;
|
Mutex pool_vector_lock;
|
||||||
|
|
||||||
PoolAllocator *MemoryPool::memory_pool = NULL;
|
PoolAllocator *MemoryPool::memory_pool = NULL;
|
||||||
uint8_t *MemoryPool::pool_memory = NULL;
|
uint8_t *MemoryPool::pool_memory = NULL;
|
||||||
@ -40,7 +40,7 @@ MemoryPool::Alloc *MemoryPool::allocs = NULL;
|
|||||||
MemoryPool::Alloc *MemoryPool::free_list = NULL;
|
MemoryPool::Alloc *MemoryPool::free_list = NULL;
|
||||||
uint32_t MemoryPool::alloc_count = 0;
|
uint32_t MemoryPool::alloc_count = 0;
|
||||||
uint32_t MemoryPool::allocs_used = 0;
|
uint32_t MemoryPool::allocs_used = 0;
|
||||||
Mutex *MemoryPool::alloc_mutex = NULL;
|
Mutex MemoryPool::alloc_mutex;
|
||||||
|
|
||||||
size_t MemoryPool::total_memory = 0;
|
size_t MemoryPool::total_memory = 0;
|
||||||
size_t MemoryPool::max_memory = 0;
|
size_t MemoryPool::max_memory = 0;
|
||||||
@ -57,14 +57,11 @@ void MemoryPool::setup(uint32_t p_max_allocs) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
free_list = &allocs[0];
|
free_list = &allocs[0];
|
||||||
|
|
||||||
alloc_mutex = Mutex::create();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemoryPool::cleanup() {
|
void MemoryPool::cleanup() {
|
||||||
|
|
||||||
memdelete_arr(allocs);
|
memdelete_arr(allocs);
|
||||||
memdelete(alloc_mutex);
|
|
||||||
|
|
||||||
ERR_FAIL_COND_MSG(allocs_used > 0, "There are still MemoryPool allocs in use at exit!");
|
ERR_FAIL_COND_MSG(allocs_used > 0, "There are still MemoryPool allocs in use at exit!");
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ struct MemoryPool {
|
|||||||
static Alloc *free_list;
|
static Alloc *free_list;
|
||||||
static uint32_t alloc_count;
|
static uint32_t alloc_count;
|
||||||
static uint32_t allocs_used;
|
static uint32_t allocs_used;
|
||||||
static Mutex *alloc_mutex;
|
static Mutex alloc_mutex;
|
||||||
static size_t total_memory;
|
static size_t total_memory;
|
||||||
static size_t max_memory;
|
static size_t max_memory;
|
||||||
|
|
||||||
@ -95,9 +95,9 @@ class PoolVector {
|
|||||||
|
|
||||||
//must allocate something
|
//must allocate something
|
||||||
|
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
if (MemoryPool::allocs_used == MemoryPool::alloc_count) {
|
if (MemoryPool::allocs_used == MemoryPool::alloc_count) {
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
ERR_FAIL_MSG("All memory pool allocations are in use, can't COW.");
|
ERR_FAIL_MSG("All memory pool allocations are in use, can't COW.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -122,7 +122,7 @@ class PoolVector {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
|
|
||||||
if (MemoryPool::memory_pool) {
|
if (MemoryPool::memory_pool) {
|
||||||
|
|
||||||
@ -148,9 +148,9 @@ class PoolVector {
|
|||||||
//this should never happen but..
|
//this should never happen but..
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
MemoryPool::total_memory -= old_alloc->size;
|
MemoryPool::total_memory -= old_alloc->size;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -174,11 +174,11 @@ class PoolVector {
|
|||||||
old_alloc->mem = NULL;
|
old_alloc->mem = NULL;
|
||||||
old_alloc->size = 0;
|
old_alloc->size = 0;
|
||||||
|
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
old_alloc->free_list = MemoryPool::free_list;
|
old_alloc->free_list = MemoryPool::free_list;
|
||||||
MemoryPool::free_list = old_alloc;
|
MemoryPool::free_list = old_alloc;
|
||||||
MemoryPool::allocs_used--;
|
MemoryPool::allocs_used--;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -227,9 +227,9 @@ class PoolVector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
MemoryPool::total_memory -= alloc->size;
|
MemoryPool::total_memory -= alloc->size;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (MemoryPool::memory_pool) {
|
if (MemoryPool::memory_pool) {
|
||||||
@ -242,11 +242,11 @@ class PoolVector {
|
|||||||
alloc->mem = NULL;
|
alloc->mem = NULL;
|
||||||
alloc->size = 0;
|
alloc->size = 0;
|
||||||
|
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
alloc->free_list = MemoryPool::free_list;
|
alloc->free_list = MemoryPool::free_list;
|
||||||
MemoryPool::free_list = alloc;
|
MemoryPool::free_list = alloc;
|
||||||
MemoryPool::allocs_used--;
|
MemoryPool::allocs_used--;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
alloc = NULL;
|
alloc = NULL;
|
||||||
@ -523,9 +523,9 @@ Error PoolVector<T>::resize(int p_size) {
|
|||||||
return OK; //nothing to do here
|
return OK; //nothing to do here
|
||||||
|
|
||||||
//must allocate something
|
//must allocate something
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
if (MemoryPool::allocs_used == MemoryPool::alloc_count) {
|
if (MemoryPool::allocs_used == MemoryPool::alloc_count) {
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
ERR_FAIL_V_MSG(ERR_OUT_OF_MEMORY, "All memory pool allocations are in use.");
|
ERR_FAIL_V_MSG(ERR_OUT_OF_MEMORY, "All memory pool allocations are in use.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -539,7 +539,7 @@ Error PoolVector<T>::resize(int p_size) {
|
|||||||
alloc->size = 0;
|
alloc->size = 0;
|
||||||
alloc->refcount.init();
|
alloc->refcount.init();
|
||||||
alloc->pool_id = POOL_ALLOCATOR_INVALID_ID;
|
alloc->pool_id = POOL_ALLOCATOR_INVALID_ID;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@ -559,13 +559,13 @@ Error PoolVector<T>::resize(int p_size) {
|
|||||||
_copy_on_write(); // make it unique
|
_copy_on_write(); // make it unique
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
MemoryPool::total_memory -= alloc->size;
|
MemoryPool::total_memory -= alloc->size;
|
||||||
MemoryPool::total_memory += new_size;
|
MemoryPool::total_memory += new_size;
|
||||||
if (MemoryPool::total_memory > MemoryPool::max_memory) {
|
if (MemoryPool::total_memory > MemoryPool::max_memory) {
|
||||||
MemoryPool::max_memory = MemoryPool::total_memory;
|
MemoryPool::max_memory = MemoryPool::total_memory;
|
||||||
}
|
}
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int cur_elements = alloc->size / sizeof(T);
|
int cur_elements = alloc->size / sizeof(T);
|
||||||
@ -615,11 +615,11 @@ Error PoolVector<T>::resize(int p_size) {
|
|||||||
alloc->mem = NULL;
|
alloc->mem = NULL;
|
||||||
alloc->size = 0;
|
alloc->size = 0;
|
||||||
|
|
||||||
MemoryPool::alloc_mutex->lock();
|
MemoryPool::alloc_mutex.lock();
|
||||||
alloc->free_list = MemoryPool::free_list;
|
alloc->free_list = MemoryPool::free_list;
|
||||||
MemoryPool::free_list = alloc;
|
MemoryPool::free_list = alloc;
|
||||||
MemoryPool::allocs_used--;
|
MemoryPool::allocs_used--;
|
||||||
MemoryPool::alloc_mutex->unlock();
|
MemoryPool::alloc_mutex.unlock();
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
alloc->mem = memrealloc(alloc->mem, new_size);
|
alloc->mem = memrealloc(alloc->mem, new_size);
|
||||||
|
@ -90,7 +90,7 @@ static IP *ip = NULL;
|
|||||||
|
|
||||||
static _Geometry *_geometry = NULL;
|
static _Geometry *_geometry = NULL;
|
||||||
|
|
||||||
extern Mutex *_global_mutex;
|
extern Mutex _global_mutex;
|
||||||
|
|
||||||
extern void register_global_constants();
|
extern void register_global_constants();
|
||||||
extern void unregister_global_constants();
|
extern void unregister_global_constants();
|
||||||
@ -101,10 +101,7 @@ void register_core_types() {
|
|||||||
|
|
||||||
MemoryPool::setup();
|
MemoryPool::setup();
|
||||||
|
|
||||||
_global_mutex = Mutex::create();
|
|
||||||
|
|
||||||
StringName::setup();
|
StringName::setup();
|
||||||
ResourceLoader::initialize();
|
|
||||||
|
|
||||||
register_global_constants();
|
register_global_constants();
|
||||||
register_variant_methods();
|
register_variant_methods();
|
||||||
@ -316,10 +313,5 @@ void unregister_core_types() {
|
|||||||
CoreStringNames::free();
|
CoreStringNames::free();
|
||||||
StringName::cleanup();
|
StringName::cleanup();
|
||||||
|
|
||||||
if (_global_mutex) {
|
|
||||||
memdelete(_global_mutex);
|
|
||||||
_global_mutex = NULL; //still needed at a few places
|
|
||||||
};
|
|
||||||
|
|
||||||
MemoryPool::cleanup();
|
MemoryPool::cleanup();
|
||||||
}
|
}
|
||||||
|
@ -47,12 +47,10 @@ StringName _scs_create(const char *p_chr) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool StringName::configured = false;
|
bool StringName::configured = false;
|
||||||
Mutex *StringName::lock = NULL;
|
Mutex StringName::lock;
|
||||||
|
|
||||||
void StringName::setup() {
|
void StringName::setup() {
|
||||||
|
|
||||||
lock = Mutex::create();
|
|
||||||
|
|
||||||
ERR_FAIL_COND(configured);
|
ERR_FAIL_COND(configured);
|
||||||
for (int i = 0; i < STRING_TABLE_LEN; i++) {
|
for (int i = 0; i < STRING_TABLE_LEN; i++) {
|
||||||
|
|
||||||
@ -63,7 +61,7 @@ void StringName::setup() {
|
|||||||
|
|
||||||
void StringName::cleanup() {
|
void StringName::cleanup() {
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
int lost_strings = 0;
|
int lost_strings = 0;
|
||||||
for (int i = 0; i < STRING_TABLE_LEN; i++) {
|
for (int i = 0; i < STRING_TABLE_LEN; i++) {
|
||||||
@ -87,9 +85,7 @@ void StringName::cleanup() {
|
|||||||
if (lost_strings) {
|
if (lost_strings) {
|
||||||
print_verbose("StringName: " + itos(lost_strings) + " unclaimed string names at exit.");
|
print_verbose("StringName: " + itos(lost_strings) + " unclaimed string names at exit.");
|
||||||
}
|
}
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
|
|
||||||
memdelete(lock);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void StringName::unref() {
|
void StringName::unref() {
|
||||||
@ -98,7 +94,7 @@ void StringName::unref() {
|
|||||||
|
|
||||||
if (_data && _data->refcount.unref()) {
|
if (_data && _data->refcount.unref()) {
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
if (_data->prev) {
|
if (_data->prev) {
|
||||||
_data->prev->next = _data->next;
|
_data->prev->next = _data->next;
|
||||||
@ -113,7 +109,7 @@ void StringName::unref() {
|
|||||||
_data->next->prev = _data->prev;
|
_data->next->prev = _data->prev;
|
||||||
}
|
}
|
||||||
memdelete(_data);
|
memdelete(_data);
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
_data = NULL;
|
_data = NULL;
|
||||||
@ -184,7 +180,7 @@ StringName::StringName(const char *p_name) {
|
|||||||
if (!p_name || p_name[0] == 0)
|
if (!p_name || p_name[0] == 0)
|
||||||
return; //empty, ignore
|
return; //empty, ignore
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = String::hash(p_name);
|
uint32_t hash = String::hash(p_name);
|
||||||
|
|
||||||
@ -203,7 +199,7 @@ StringName::StringName(const char *p_name) {
|
|||||||
if (_data) {
|
if (_data) {
|
||||||
if (_data->refcount.ref()) {
|
if (_data->refcount.ref()) {
|
||||||
// exists
|
// exists
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -220,7 +216,7 @@ StringName::StringName(const char *p_name) {
|
|||||||
_table[idx]->prev = _data;
|
_table[idx]->prev = _data;
|
||||||
_table[idx] = _data;
|
_table[idx] = _data;
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
StringName::StringName(const StaticCString &p_static_string) {
|
StringName::StringName(const StaticCString &p_static_string) {
|
||||||
@ -231,7 +227,7 @@ StringName::StringName(const StaticCString &p_static_string) {
|
|||||||
|
|
||||||
ERR_FAIL_COND(!p_static_string.ptr || !p_static_string.ptr[0]);
|
ERR_FAIL_COND(!p_static_string.ptr || !p_static_string.ptr[0]);
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = String::hash(p_static_string.ptr);
|
uint32_t hash = String::hash(p_static_string.ptr);
|
||||||
|
|
||||||
@ -250,7 +246,7 @@ StringName::StringName(const StaticCString &p_static_string) {
|
|||||||
if (_data) {
|
if (_data) {
|
||||||
if (_data->refcount.ref()) {
|
if (_data->refcount.ref()) {
|
||||||
// exists
|
// exists
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -267,7 +263,7 @@ StringName::StringName(const StaticCString &p_static_string) {
|
|||||||
_table[idx]->prev = _data;
|
_table[idx]->prev = _data;
|
||||||
_table[idx] = _data;
|
_table[idx] = _data;
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
StringName::StringName(const String &p_name) {
|
StringName::StringName(const String &p_name) {
|
||||||
@ -279,7 +275,7 @@ StringName::StringName(const String &p_name) {
|
|||||||
if (p_name == String())
|
if (p_name == String())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = p_name.hash();
|
uint32_t hash = p_name.hash();
|
||||||
|
|
||||||
@ -297,7 +293,7 @@ StringName::StringName(const String &p_name) {
|
|||||||
if (_data) {
|
if (_data) {
|
||||||
if (_data->refcount.ref()) {
|
if (_data->refcount.ref()) {
|
||||||
// exists
|
// exists
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -314,7 +310,7 @@ StringName::StringName(const String &p_name) {
|
|||||||
_table[idx]->prev = _data;
|
_table[idx]->prev = _data;
|
||||||
_table[idx] = _data;
|
_table[idx] = _data;
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
StringName StringName::search(const char *p_name) {
|
StringName StringName::search(const char *p_name) {
|
||||||
@ -325,7 +321,7 @@ StringName StringName::search(const char *p_name) {
|
|||||||
if (!p_name[0])
|
if (!p_name[0])
|
||||||
return StringName();
|
return StringName();
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = String::hash(p_name);
|
uint32_t hash = String::hash(p_name);
|
||||||
|
|
||||||
@ -342,12 +338,12 @@ StringName StringName::search(const char *p_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (_data && _data->refcount.ref()) {
|
if (_data && _data->refcount.ref()) {
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
|
|
||||||
return StringName(_data);
|
return StringName(_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return StringName(); //does not exist
|
return StringName(); //does not exist
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -359,7 +355,7 @@ StringName StringName::search(const CharType *p_name) {
|
|||||||
if (!p_name[0])
|
if (!p_name[0])
|
||||||
return StringName();
|
return StringName();
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = String::hash(p_name);
|
uint32_t hash = String::hash(p_name);
|
||||||
|
|
||||||
@ -376,18 +372,18 @@ StringName StringName::search(const CharType *p_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (_data && _data->refcount.ref()) {
|
if (_data && _data->refcount.ref()) {
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return StringName(_data);
|
return StringName(_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return StringName(); //does not exist
|
return StringName(); //does not exist
|
||||||
}
|
}
|
||||||
StringName StringName::search(const String &p_name) {
|
StringName StringName::search(const String &p_name) {
|
||||||
|
|
||||||
ERR_FAIL_COND_V(p_name == "", StringName());
|
ERR_FAIL_COND_V(p_name == "", StringName());
|
||||||
|
|
||||||
lock->lock();
|
lock.lock();
|
||||||
|
|
||||||
uint32_t hash = p_name.hash();
|
uint32_t hash = p_name.hash();
|
||||||
|
|
||||||
@ -404,11 +400,11 @@ StringName StringName::search(const String &p_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (_data && _data->refcount.ref()) {
|
if (_data && _data->refcount.ref()) {
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return StringName(_data);
|
return StringName(_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
lock->unlock();
|
lock.unlock();
|
||||||
return StringName(); //does not exist
|
return StringName(); //does not exist
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,7 +82,7 @@ class StringName {
|
|||||||
friend void register_core_types();
|
friend void register_core_types();
|
||||||
friend void unregister_core_types();
|
friend void unregister_core_types();
|
||||||
|
|
||||||
static Mutex *lock;
|
static Mutex lock;
|
||||||
static void setup();
|
static void setup();
|
||||||
static void cleanup();
|
static void cleanup();
|
||||||
static bool configured;
|
static bool configured;
|
||||||
|
@ -169,7 +169,6 @@ Error AudioDriverALSA::init() {
|
|||||||
|
|
||||||
Error err = init_device();
|
Error err = init_device();
|
||||||
if (err == OK) {
|
if (err == OK) {
|
||||||
mutex = Mutex::create();
|
|
||||||
thread = Thread::create(AudioDriverALSA::thread_func, this);
|
thread = Thread::create(AudioDriverALSA::thread_func, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -314,16 +313,16 @@ void AudioDriverALSA::set_device(String device) {
|
|||||||
|
|
||||||
void AudioDriverALSA::lock() {
|
void AudioDriverALSA::lock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverALSA::unlock() {
|
void AudioDriverALSA::unlock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverALSA::finish_device() {
|
void AudioDriverALSA::finish_device() {
|
||||||
@ -342,11 +341,6 @@ void AudioDriverALSA::finish() {
|
|||||||
|
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
|
|
||||||
if (mutex) {
|
|
||||||
memdelete(mutex);
|
|
||||||
mutex = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
finish_device();
|
finish_device();
|
||||||
@ -354,7 +348,6 @@ void AudioDriverALSA::finish() {
|
|||||||
|
|
||||||
AudioDriverALSA::AudioDriverALSA() :
|
AudioDriverALSA::AudioDriverALSA() :
|
||||||
thread(NULL),
|
thread(NULL),
|
||||||
mutex(NULL),
|
|
||||||
pcm_handle(NULL),
|
pcm_handle(NULL),
|
||||||
device_name("Default"),
|
device_name("Default"),
|
||||||
new_device("Default") {
|
new_device("Default") {
|
||||||
|
@ -42,7 +42,7 @@
|
|||||||
class AudioDriverALSA : public AudioDriver {
|
class AudioDriverALSA : public AudioDriver {
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
snd_pcm_t *pcm_handle;
|
snd_pcm_t *pcm_handle;
|
||||||
|
|
||||||
|
@ -148,7 +148,6 @@ Error MIDIDriverALSAMidi::open() {
|
|||||||
}
|
}
|
||||||
snd_device_name_free_hint(hints);
|
snd_device_name_free_hint(hints);
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
exit_thread = false;
|
exit_thread = false;
|
||||||
thread = Thread::create(MIDIDriverALSAMidi::thread_func, this);
|
thread = Thread::create(MIDIDriverALSAMidi::thread_func, this);
|
||||||
|
|
||||||
@ -165,11 +164,6 @@ void MIDIDriverALSAMidi::close() {
|
|||||||
thread = NULL;
|
thread = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mutex) {
|
|
||||||
memdelete(mutex);
|
|
||||||
mutex = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < connected_inputs.size(); i++) {
|
for (int i = 0; i < connected_inputs.size(); i++) {
|
||||||
snd_rawmidi_t *midi_in = connected_inputs[i];
|
snd_rawmidi_t *midi_in = connected_inputs[i];
|
||||||
snd_rawmidi_close(midi_in);
|
snd_rawmidi_close(midi_in);
|
||||||
@ -179,14 +173,12 @@ void MIDIDriverALSAMidi::close() {
|
|||||||
|
|
||||||
void MIDIDriverALSAMidi::lock() const {
|
void MIDIDriverALSAMidi::lock() const {
|
||||||
|
|
||||||
if (mutex)
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MIDIDriverALSAMidi::unlock() const {
|
void MIDIDriverALSAMidi::unlock() const {
|
||||||
|
|
||||||
if (mutex)
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PoolStringArray MIDIDriverALSAMidi::get_connected_inputs() {
|
PoolStringArray MIDIDriverALSAMidi::get_connected_inputs() {
|
||||||
@ -210,7 +202,6 @@ PoolStringArray MIDIDriverALSAMidi::get_connected_inputs() {
|
|||||||
|
|
||||||
MIDIDriverALSAMidi::MIDIDriverALSAMidi() {
|
MIDIDriverALSAMidi::MIDIDriverALSAMidi() {
|
||||||
|
|
||||||
mutex = NULL;
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
|
|
||||||
exit_thread = false;
|
exit_thread = false;
|
||||||
|
@ -44,7 +44,7 @@
|
|||||||
class MIDIDriverALSAMidi : public MIDIDriver {
|
class MIDIDriverALSAMidi : public MIDIDriver {
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
Vector<snd_rawmidi_t *> connected_inputs;
|
Vector<snd_rawmidi_t *> connected_inputs;
|
||||||
|
|
||||||
|
@ -69,8 +69,6 @@ OSStatus AudioDriverCoreAudio::output_device_address_cb(AudioObjectID inObjectID
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
Error AudioDriverCoreAudio::init() {
|
Error AudioDriverCoreAudio::init() {
|
||||||
mutex = Mutex::create();
|
|
||||||
|
|
||||||
AudioComponentDescription desc;
|
AudioComponentDescription desc;
|
||||||
zeromem(&desc, sizeof(desc));
|
zeromem(&desc, sizeof(desc));
|
||||||
desc.componentType = kAudioUnitType_Output;
|
desc.componentType = kAudioUnitType_Output;
|
||||||
@ -280,19 +278,15 @@ AudioDriver::SpeakerMode AudioDriverCoreAudio::get_speaker_mode() const {
|
|||||||
};
|
};
|
||||||
|
|
||||||
void AudioDriverCoreAudio::lock() {
|
void AudioDriverCoreAudio::lock() {
|
||||||
if (mutex)
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void AudioDriverCoreAudio::unlock() {
|
void AudioDriverCoreAudio::unlock() {
|
||||||
if (mutex)
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
bool AudioDriverCoreAudio::try_lock() {
|
bool AudioDriverCoreAudio::try_lock() {
|
||||||
if (mutex)
|
return mutex.try_lock() == OK;
|
||||||
return mutex->try_lock() == OK;
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverCoreAudio::finish() {
|
void AudioDriverCoreAudio::finish() {
|
||||||
@ -344,11 +338,6 @@ void AudioDriverCoreAudio::finish() {
|
|||||||
audio_unit = NULL;
|
audio_unit = NULL;
|
||||||
unlock();
|
unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mutex) {
|
|
||||||
memdelete(mutex);
|
|
||||||
mutex = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Error AudioDriverCoreAudio::capture_init() {
|
Error AudioDriverCoreAudio::capture_init() {
|
||||||
@ -691,7 +680,6 @@ AudioDriverCoreAudio::AudioDriverCoreAudio() :
|
|||||||
audio_unit(NULL),
|
audio_unit(NULL),
|
||||||
input_unit(NULL),
|
input_unit(NULL),
|
||||||
active(false),
|
active(false),
|
||||||
mutex(NULL),
|
|
||||||
device_name("Default"),
|
device_name("Default"),
|
||||||
capture_device_name("Default"),
|
capture_device_name("Default"),
|
||||||
mix_rate(0),
|
mix_rate(0),
|
||||||
|
@ -46,7 +46,7 @@ class AudioDriverCoreAudio : public AudioDriver {
|
|||||||
AudioComponentInstance input_unit;
|
AudioComponentInstance input_unit;
|
||||||
|
|
||||||
bool active;
|
bool active;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
String device_name;
|
String device_name;
|
||||||
String capture_device_name;
|
String capture_device_name;
|
||||||
|
@ -294,7 +294,6 @@ Error AudioDriverPulseAudio::init() {
|
|||||||
|
|
||||||
Error err = init_device();
|
Error err = init_device();
|
||||||
if (err == OK) {
|
if (err == OK) {
|
||||||
mutex = Mutex::create();
|
|
||||||
thread = Thread::create(AudioDriverPulseAudio::thread_func, this);
|
thread = Thread::create(AudioDriverPulseAudio::thread_func, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -600,16 +599,16 @@ void AudioDriverPulseAudio::set_device(String device) {
|
|||||||
|
|
||||||
void AudioDriverPulseAudio::lock() {
|
void AudioDriverPulseAudio::lock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverPulseAudio::unlock() {
|
void AudioDriverPulseAudio::unlock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverPulseAudio::finish_device() {
|
void AudioDriverPulseAudio::finish_device() {
|
||||||
@ -643,10 +642,6 @@ void AudioDriverPulseAudio::finish() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
if (mutex) {
|
|
||||||
memdelete(mutex);
|
|
||||||
mutex = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
}
|
}
|
||||||
@ -803,7 +798,6 @@ String AudioDriverPulseAudio::capture_get_device() {
|
|||||||
|
|
||||||
AudioDriverPulseAudio::AudioDriverPulseAudio() :
|
AudioDriverPulseAudio::AudioDriverPulseAudio() :
|
||||||
thread(NULL),
|
thread(NULL),
|
||||||
mutex(NULL),
|
|
||||||
pa_ml(NULL),
|
pa_ml(NULL),
|
||||||
pa_ctx(NULL),
|
pa_ctx(NULL),
|
||||||
pa_str(NULL),
|
pa_str(NULL),
|
||||||
|
@ -42,7 +42,7 @@
|
|||||||
class AudioDriverPulseAudio : public AudioDriver {
|
class AudioDriverPulseAudio : public AudioDriver {
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
pa_mainloop *pa_ml;
|
pa_mainloop *pa_ml;
|
||||||
pa_context *pa_ctx;
|
pa_context *pa_ctx;
|
||||||
|
@ -1,73 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* mutex_posix.cpp */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#include "mutex_posix.h"
|
|
||||||
|
|
||||||
#include "core/os/memory.h"
|
|
||||||
|
|
||||||
#if defined(UNIX_ENABLED) || defined(PTHREAD_ENABLED)
|
|
||||||
|
|
||||||
void MutexPosix::lock() {
|
|
||||||
|
|
||||||
pthread_mutex_lock(&mutex);
|
|
||||||
}
|
|
||||||
void MutexPosix::unlock() {
|
|
||||||
|
|
||||||
pthread_mutex_unlock(&mutex);
|
|
||||||
}
|
|
||||||
Error MutexPosix::try_lock() {
|
|
||||||
|
|
||||||
return (pthread_mutex_trylock(&mutex) == 0) ? OK : ERR_BUSY;
|
|
||||||
}
|
|
||||||
|
|
||||||
Mutex *MutexPosix::create_func_posix(bool p_recursive) {
|
|
||||||
|
|
||||||
return memnew(MutexPosix(p_recursive));
|
|
||||||
}
|
|
||||||
|
|
||||||
void MutexPosix::make_default() {
|
|
||||||
|
|
||||||
create_func = create_func_posix;
|
|
||||||
}
|
|
||||||
|
|
||||||
MutexPosix::MutexPosix(bool p_recursive) {
|
|
||||||
|
|
||||||
pthread_mutexattr_init(&attr);
|
|
||||||
if (p_recursive)
|
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE);
|
|
||||||
pthread_mutex_init(&mutex, &attr);
|
|
||||||
}
|
|
||||||
|
|
||||||
MutexPosix::~MutexPosix() {
|
|
||||||
|
|
||||||
pthread_mutex_destroy(&mutex);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,61 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* mutex_posix.h */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#ifndef MUTEX_POSIX_H
|
|
||||||
#define MUTEX_POSIX_H
|
|
||||||
|
|
||||||
#if defined(UNIX_ENABLED) || defined(PTHREAD_ENABLED)
|
|
||||||
|
|
||||||
#include "core/os/mutex.h"
|
|
||||||
|
|
||||||
#include <pthread.h>
|
|
||||||
|
|
||||||
class MutexPosix : public Mutex {
|
|
||||||
|
|
||||||
pthread_mutexattr_t attr;
|
|
||||||
pthread_mutex_t mutex;
|
|
||||||
|
|
||||||
static Mutex *create_func_posix(bool p_recursive);
|
|
||||||
|
|
||||||
public:
|
|
||||||
virtual void lock();
|
|
||||||
virtual void unlock();
|
|
||||||
virtual Error try_lock();
|
|
||||||
|
|
||||||
static void make_default();
|
|
||||||
|
|
||||||
MutexPosix(bool p_recursive);
|
|
||||||
|
|
||||||
~MutexPosix();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
@ -36,7 +36,6 @@
|
|||||||
#include "core/project_settings.h"
|
#include "core/project_settings.h"
|
||||||
#include "drivers/unix/dir_access_unix.h"
|
#include "drivers/unix/dir_access_unix.h"
|
||||||
#include "drivers/unix/file_access_unix.h"
|
#include "drivers/unix/file_access_unix.h"
|
||||||
#include "drivers/unix/mutex_posix.h"
|
|
||||||
#include "drivers/unix/net_socket_posix.h"
|
#include "drivers/unix/net_socket_posix.h"
|
||||||
#include "drivers/unix/semaphore_posix.h"
|
#include "drivers/unix/semaphore_posix.h"
|
||||||
#include "drivers/unix/thread_posix.h"
|
#include "drivers/unix/thread_posix.h"
|
||||||
@ -63,6 +62,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
#include <time.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
/// Clock Setup function (used by get_ticks_usec)
|
/// Clock Setup function (used by get_ticks_usec)
|
||||||
@ -122,13 +122,11 @@ void OS_Unix::initialize_core() {
|
|||||||
#ifdef NO_THREADS
|
#ifdef NO_THREADS
|
||||||
ThreadDummy::make_default();
|
ThreadDummy::make_default();
|
||||||
SemaphoreDummy::make_default();
|
SemaphoreDummy::make_default();
|
||||||
MutexDummy::make_default();
|
|
||||||
#else
|
#else
|
||||||
ThreadPosix::make_default();
|
ThreadPosix::make_default();
|
||||||
#if !defined(OSX_ENABLED) && !defined(IPHONE_ENABLED)
|
#if !defined(OSX_ENABLED) && !defined(IPHONE_ENABLED)
|
||||||
SemaphorePosix::make_default();
|
SemaphorePosix::make_default();
|
||||||
#endif
|
#endif
|
||||||
MutexPosix::make_default();
|
|
||||||
#endif
|
#endif
|
||||||
FileAccess::make_default<FileAccessUnix>(FileAccess::ACCESS_RESOURCES);
|
FileAccess::make_default<FileAccessUnix>(FileAccess::ACCESS_RESOURCES);
|
||||||
FileAccess::make_default<FileAccessUnix>(FileAccess::ACCESS_USERDATA);
|
FileAccess::make_default<FileAccessUnix>(FileAccess::ACCESS_USERDATA);
|
||||||
@ -307,14 +305,10 @@ Error OS_Unix::execute(const String &p_path, const List<String> &p_arguments, bo
|
|||||||
|
|
||||||
while (fgets(buf, 65535, f)) {
|
while (fgets(buf, 65535, f)) {
|
||||||
|
|
||||||
if (p_pipe_mutex) {
|
|
||||||
p_pipe_mutex->lock();
|
p_pipe_mutex->lock();
|
||||||
}
|
|
||||||
(*r_pipe) += String::utf8(buf);
|
(*r_pipe) += String::utf8(buf);
|
||||||
if (p_pipe_mutex) {
|
|
||||||
p_pipe_mutex->unlock();
|
p_pipe_mutex->unlock();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
int rv = pclose(f);
|
int rv = pclose(f);
|
||||||
if (r_exitcode)
|
if (r_exitcode)
|
||||||
*r_exitcode = WEXITSTATUS(rv);
|
*r_exitcode = WEXITSTATUS(rv);
|
||||||
|
@ -406,7 +406,6 @@ Error AudioDriverWASAPI::init() {
|
|||||||
exit_thread = false;
|
exit_thread = false;
|
||||||
thread_exited = false;
|
thread_exited = false;
|
||||||
|
|
||||||
mutex = Mutex::create(true);
|
|
||||||
thread = Thread::create(thread_func, this);
|
thread = Thread::create(thread_func, this);
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
@ -782,14 +781,12 @@ void AudioDriverWASAPI::start() {
|
|||||||
|
|
||||||
void AudioDriverWASAPI::lock() {
|
void AudioDriverWASAPI::lock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverWASAPI::unlock() {
|
void AudioDriverWASAPI::unlock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverWASAPI::finish() {
|
void AudioDriverWASAPI::finish() {
|
||||||
@ -804,11 +801,6 @@ void AudioDriverWASAPI::finish() {
|
|||||||
|
|
||||||
finish_capture_device();
|
finish_capture_device();
|
||||||
finish_render_device();
|
finish_render_device();
|
||||||
|
|
||||||
if (mutex) {
|
|
||||||
memdelete(mutex);
|
|
||||||
mutex = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Error AudioDriverWASAPI::capture_start() {
|
Error AudioDriverWASAPI::capture_start() {
|
||||||
@ -863,7 +855,6 @@ String AudioDriverWASAPI::capture_get_device() {
|
|||||||
|
|
||||||
AudioDriverWASAPI::AudioDriverWASAPI() {
|
AudioDriverWASAPI::AudioDriverWASAPI() {
|
||||||
|
|
||||||
mutex = NULL;
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
|
|
||||||
samples_in.clear();
|
samples_in.clear();
|
||||||
|
@ -75,7 +75,7 @@ class AudioDriverWASAPI : public AudioDriver {
|
|||||||
AudioDeviceWASAPI audio_input;
|
AudioDeviceWASAPI audio_input;
|
||||||
AudioDeviceWASAPI audio_output;
|
AudioDeviceWASAPI audio_output;
|
||||||
|
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
|
|
||||||
Vector<int32_t> samples_in;
|
Vector<int32_t> samples_in;
|
||||||
|
@ -1,101 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* mutex_windows.cpp */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#include "mutex_windows.h"
|
|
||||||
|
|
||||||
#include "core/os/memory.h"
|
|
||||||
|
|
||||||
#ifdef WINDOWS_ENABLED
|
|
||||||
|
|
||||||
void MutexWindows::lock() {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
WaitForSingleObject(mutex, INFINITE);
|
|
||||||
#else
|
|
||||||
EnterCriticalSection(&mutex);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void MutexWindows::unlock() {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
ReleaseMutex(mutex);
|
|
||||||
#else
|
|
||||||
LeaveCriticalSection(&mutex);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
Error MutexWindows::try_lock() {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
return (WaitForSingleObject(mutex, 0) == WAIT_TIMEOUT) ? ERR_BUSY : OK;
|
|
||||||
#else
|
|
||||||
|
|
||||||
if (TryEnterCriticalSection(&mutex))
|
|
||||||
return OK;
|
|
||||||
else
|
|
||||||
return ERR_BUSY;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
Mutex *MutexWindows::create_func_windows(bool p_recursive) {
|
|
||||||
|
|
||||||
return memnew(MutexWindows);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MutexWindows::make_default() {
|
|
||||||
|
|
||||||
create_func = create_func_windows;
|
|
||||||
}
|
|
||||||
|
|
||||||
MutexWindows::MutexWindows() {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
mutex = CreateMutex(NULL, FALSE, NULL);
|
|
||||||
#else
|
|
||||||
#ifdef UWP_ENABLED
|
|
||||||
InitializeCriticalSectionEx(&mutex, 0, 0);
|
|
||||||
#else
|
|
||||||
InitializeCriticalSection(&mutex);
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
MutexWindows::~MutexWindows() {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
CloseHandle(mutex);
|
|
||||||
#else
|
|
||||||
|
|
||||||
DeleteCriticalSection(&mutex);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,63 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* mutex_windows.h */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#ifndef MUTEX_WINDOWS_H
|
|
||||||
#define MUTEX_WINDOWS_H
|
|
||||||
|
|
||||||
#ifdef WINDOWS_ENABLED
|
|
||||||
|
|
||||||
#include "core/os/mutex.h"
|
|
||||||
|
|
||||||
#include <windows.h>
|
|
||||||
|
|
||||||
class MutexWindows : public Mutex {
|
|
||||||
|
|
||||||
#ifdef WINDOWS_USE_MUTEX
|
|
||||||
HANDLE mutex;
|
|
||||||
#else
|
|
||||||
CRITICAL_SECTION mutex;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static Mutex *create_func_windows(bool p_recursive);
|
|
||||||
|
|
||||||
public:
|
|
||||||
virtual void lock();
|
|
||||||
virtual void unlock();
|
|
||||||
virtual Error try_lock();
|
|
||||||
|
|
||||||
static void make_default();
|
|
||||||
|
|
||||||
MutexWindows();
|
|
||||||
~MutexWindows();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
@ -79,7 +79,6 @@ Error AudioDriverXAudio2::init() {
|
|||||||
hr = xaudio->CreateSourceVoice(&source_voice, &wave_format, 0, XAUDIO2_MAX_FREQ_RATIO, &voice_callback);
|
hr = xaudio->CreateSourceVoice(&source_voice, &wave_format, 0, XAUDIO2_MAX_FREQ_RATIO, &voice_callback);
|
||||||
ERR_FAIL_COND_V_MSG(hr != S_OK, ERR_UNAVAILABLE, "Error creating XAudio2 source voice. Error code: " + itos(hr) + ".");
|
ERR_FAIL_COND_V_MSG(hr != S_OK, ERR_UNAVAILABLE, "Error creating XAudio2 source voice. Error code: " + itos(hr) + ".");
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
thread = Thread::create(AudioDriverXAudio2::thread_func, this);
|
thread = Thread::create(AudioDriverXAudio2::thread_func, this);
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
@ -158,15 +157,15 @@ float AudioDriverXAudio2::get_latency() {
|
|||||||
|
|
||||||
void AudioDriverXAudio2::lock() {
|
void AudioDriverXAudio2::lock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
}
|
}
|
||||||
void AudioDriverXAudio2::unlock() {
|
void AudioDriverXAudio2::unlock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverXAudio2::finish() {
|
void AudioDriverXAudio2::finish() {
|
||||||
@ -194,14 +193,11 @@ void AudioDriverXAudio2::finish() {
|
|||||||
mastering_voice->DestroyVoice();
|
mastering_voice->DestroyVoice();
|
||||||
|
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
if (mutex)
|
|
||||||
memdelete(mutex);
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
AudioDriverXAudio2::AudioDriverXAudio2() :
|
AudioDriverXAudio2::AudioDriverXAudio2() :
|
||||||
thread(NULL),
|
thread(NULL),
|
||||||
mutex(NULL),
|
|
||||||
current_buffer(0) {
|
current_buffer(0) {
|
||||||
wave_format = { 0 };
|
wave_format = { 0 };
|
||||||
for (int i = 0; i < AUDIO_BUFFERS; i++) {
|
for (int i = 0; i < AUDIO_BUFFERS; i++) {
|
||||||
|
@ -65,7 +65,7 @@ class AudioDriverXAudio2 : public AudioDriver {
|
|||||||
};
|
};
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
int32_t *samples_in;
|
int32_t *samples_in;
|
||||||
int16_t *samples_out[AUDIO_BUFFERS];
|
int16_t *samples_out[AUDIO_BUFFERS];
|
||||||
|
@ -5736,7 +5736,7 @@ void EditorNode::_print_handler(void *p_this, const String &p_string, bool p_err
|
|||||||
static void _execute_thread(void *p_ud) {
|
static void _execute_thread(void *p_ud) {
|
||||||
|
|
||||||
EditorNode::ExecuteThreadArgs *eta = (EditorNode::ExecuteThreadArgs *)p_ud;
|
EditorNode::ExecuteThreadArgs *eta = (EditorNode::ExecuteThreadArgs *)p_ud;
|
||||||
Error err = OS::get_singleton()->execute(eta->path, eta->args, true, NULL, &eta->output, &eta->exitcode, true, eta->execute_output_mutex);
|
Error err = OS::get_singleton()->execute(eta->path, eta->args, true, NULL, &eta->output, &eta->exitcode, true, &eta->execute_output_mutex);
|
||||||
print_verbose("Thread exit status: " + itos(eta->exitcode));
|
print_verbose("Thread exit status: " + itos(eta->exitcode));
|
||||||
if (err != OK) {
|
if (err != OK) {
|
||||||
eta->exitcode = err;
|
eta->exitcode = err;
|
||||||
@ -5756,7 +5756,6 @@ int EditorNode::execute_and_show_output(const String &p_title, const String &p_p
|
|||||||
ExecuteThreadArgs eta;
|
ExecuteThreadArgs eta;
|
||||||
eta.path = p_path;
|
eta.path = p_path;
|
||||||
eta.args = p_arguments;
|
eta.args = p_arguments;
|
||||||
eta.execute_output_mutex = Mutex::create();
|
|
||||||
eta.exitcode = 255;
|
eta.exitcode = 255;
|
||||||
eta.done = false;
|
eta.done = false;
|
||||||
|
|
||||||
@ -5767,20 +5766,19 @@ int EditorNode::execute_and_show_output(const String &p_title, const String &p_p
|
|||||||
ERR_FAIL_COND_V(!eta.execute_output_thread, 0);
|
ERR_FAIL_COND_V(!eta.execute_output_thread, 0);
|
||||||
|
|
||||||
while (!eta.done) {
|
while (!eta.done) {
|
||||||
eta.execute_output_mutex->lock();
|
eta.execute_output_mutex.lock();
|
||||||
if (prev_len != eta.output.length()) {
|
if (prev_len != eta.output.length()) {
|
||||||
String to_add = eta.output.substr(prev_len, eta.output.length());
|
String to_add = eta.output.substr(prev_len, eta.output.length());
|
||||||
prev_len = eta.output.length();
|
prev_len = eta.output.length();
|
||||||
execute_outputs->add_text(to_add);
|
execute_outputs->add_text(to_add);
|
||||||
Main::iteration();
|
Main::iteration();
|
||||||
}
|
}
|
||||||
eta.execute_output_mutex->unlock();
|
eta.execute_output_mutex.unlock();
|
||||||
OS::get_singleton()->delay_usec(1000);
|
OS::get_singleton()->delay_usec(1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
Thread::wait_to_finish(eta.execute_output_thread);
|
Thread::wait_to_finish(eta.execute_output_thread);
|
||||||
memdelete(eta.execute_output_thread);
|
memdelete(eta.execute_output_thread);
|
||||||
memdelete(eta.execute_output_mutex);
|
|
||||||
execute_outputs->add_text("\nExit Code: " + itos(eta.exitcode));
|
execute_outputs->add_text("\nExit Code: " + itos(eta.exitcode));
|
||||||
|
|
||||||
if (p_close_on_errors && eta.exitcode != 0) {
|
if (p_close_on_errors && eta.exitcode != 0) {
|
||||||
|
@ -107,7 +107,7 @@ public:
|
|||||||
List<String> args;
|
List<String> args;
|
||||||
String output;
|
String output;
|
||||||
Thread *execute_output_thread;
|
Thread *execute_output_thread;
|
||||||
Mutex *execute_output_mutex;
|
Mutex execute_output_mutex;
|
||||||
int exitcode;
|
int exitcode;
|
||||||
volatile bool done;
|
volatile bool done;
|
||||||
};
|
};
|
||||||
|
@ -109,7 +109,7 @@ void EditorResourcePreview::_thread_func(void *ud) {
|
|||||||
|
|
||||||
void EditorResourcePreview::_preview_ready(const String &p_str, const Ref<Texture> &p_texture, const Ref<Texture> &p_small_texture, ObjectID id, const StringName &p_func, const Variant &p_ud) {
|
void EditorResourcePreview::_preview_ready(const String &p_str, const Ref<Texture> &p_texture, const Ref<Texture> &p_small_texture, ObjectID id, const StringName &p_func, const Variant &p_ud) {
|
||||||
|
|
||||||
preview_mutex->lock();
|
preview_mutex.lock();
|
||||||
|
|
||||||
String path = p_str;
|
String path = p_str;
|
||||||
uint32_t hash = 0;
|
uint32_t hash = 0;
|
||||||
@ -131,7 +131,7 @@ void EditorResourcePreview::_preview_ready(const String &p_str, const Ref<Textur
|
|||||||
|
|
||||||
cache[path] = item;
|
cache[path] = item;
|
||||||
|
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
|
|
||||||
MessageQueue::get_singleton()->push_call(id, p_func, path, p_texture, p_small_texture, p_ud);
|
MessageQueue::get_singleton()->push_call(id, p_func, path, p_texture, p_small_texture, p_ud);
|
||||||
}
|
}
|
||||||
@ -221,7 +221,7 @@ void EditorResourcePreview::_thread() {
|
|||||||
while (!exit) {
|
while (!exit) {
|
||||||
|
|
||||||
preview_sem->wait();
|
preview_sem->wait();
|
||||||
preview_mutex->lock();
|
preview_mutex.lock();
|
||||||
|
|
||||||
if (queue.size()) {
|
if (queue.size()) {
|
||||||
|
|
||||||
@ -237,10 +237,10 @@ void EditorResourcePreview::_thread() {
|
|||||||
|
|
||||||
_preview_ready(path, cache[item.path].preview, cache[item.path].small_preview, item.id, item.function, item.userdata);
|
_preview_ready(path, cache[item.path].preview, cache[item.path].small_preview, item.id, item.function, item.userdata);
|
||||||
|
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
|
|
||||||
Ref<ImageTexture> texture;
|
Ref<ImageTexture> texture;
|
||||||
Ref<ImageTexture> small_texture;
|
Ref<ImageTexture> small_texture;
|
||||||
@ -347,7 +347,7 @@ void EditorResourcePreview::_thread() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exited = true;
|
exited = true;
|
||||||
@ -358,7 +358,7 @@ void EditorResourcePreview::queue_edited_resource_preview(const Ref<Resource> &p
|
|||||||
ERR_FAIL_NULL(p_receiver);
|
ERR_FAIL_NULL(p_receiver);
|
||||||
ERR_FAIL_COND(!p_res.is_valid());
|
ERR_FAIL_COND(!p_res.is_valid());
|
||||||
|
|
||||||
preview_mutex->lock();
|
preview_mutex.lock();
|
||||||
|
|
||||||
String path_id = "ID:" + itos(p_res->get_instance_id());
|
String path_id = "ID:" + itos(p_res->get_instance_id());
|
||||||
|
|
||||||
@ -366,7 +366,7 @@ void EditorResourcePreview::queue_edited_resource_preview(const Ref<Resource> &p
|
|||||||
|
|
||||||
cache[path_id].order = order++;
|
cache[path_id].order = order++;
|
||||||
p_receiver->call(p_receiver_func, path_id, cache[path_id].preview, cache[path_id].small_preview, p_userdata);
|
p_receiver->call(p_receiver_func, path_id, cache[path_id].preview, cache[path_id].small_preview, p_userdata);
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -380,18 +380,18 @@ void EditorResourcePreview::queue_edited_resource_preview(const Ref<Resource> &p
|
|||||||
item.userdata = p_userdata;
|
item.userdata = p_userdata;
|
||||||
|
|
||||||
queue.push_back(item);
|
queue.push_back(item);
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
preview_sem->post();
|
preview_sem->post();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditorResourcePreview::queue_resource_preview(const String &p_path, Object *p_receiver, const StringName &p_receiver_func, const Variant &p_userdata) {
|
void EditorResourcePreview::queue_resource_preview(const String &p_path, Object *p_receiver, const StringName &p_receiver_func, const Variant &p_userdata) {
|
||||||
|
|
||||||
ERR_FAIL_NULL(p_receiver);
|
ERR_FAIL_NULL(p_receiver);
|
||||||
preview_mutex->lock();
|
preview_mutex.lock();
|
||||||
if (cache.has(p_path)) {
|
if (cache.has(p_path)) {
|
||||||
cache[p_path].order = order++;
|
cache[p_path].order = order++;
|
||||||
p_receiver->call(p_receiver_func, p_path, cache[p_path].preview, cache[p_path].small_preview, p_userdata);
|
p_receiver->call(p_receiver_func, p_path, cache[p_path].preview, cache[p_path].small_preview, p_userdata);
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -402,7 +402,7 @@ void EditorResourcePreview::queue_resource_preview(const String &p_path, Object
|
|||||||
item.userdata = p_userdata;
|
item.userdata = p_userdata;
|
||||||
|
|
||||||
queue.push_back(item);
|
queue.push_back(item);
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
preview_sem->post();
|
preview_sem->post();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -436,7 +436,7 @@ void EditorResourcePreview::_bind_methods() {
|
|||||||
|
|
||||||
void EditorResourcePreview::check_for_invalidation(const String &p_path) {
|
void EditorResourcePreview::check_for_invalidation(const String &p_path) {
|
||||||
|
|
||||||
preview_mutex->lock();
|
preview_mutex.lock();
|
||||||
|
|
||||||
bool call_invalidated = false;
|
bool call_invalidated = false;
|
||||||
if (cache.has(p_path)) {
|
if (cache.has(p_path)) {
|
||||||
@ -448,7 +448,7 @@ void EditorResourcePreview::check_for_invalidation(const String &p_path) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
preview_mutex->unlock();
|
preview_mutex.unlock();
|
||||||
|
|
||||||
if (call_invalidated) { //do outside mutex
|
if (call_invalidated) { //do outside mutex
|
||||||
call_deferred("emit_signal", "preview_invalidated", p_path);
|
call_deferred("emit_signal", "preview_invalidated", p_path);
|
||||||
@ -477,7 +477,6 @@ void EditorResourcePreview::stop() {
|
|||||||
EditorResourcePreview::EditorResourcePreview() {
|
EditorResourcePreview::EditorResourcePreview() {
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
singleton = this;
|
singleton = this;
|
||||||
preview_mutex = Mutex::create();
|
|
||||||
preview_sem = Semaphore::create();
|
preview_sem = Semaphore::create();
|
||||||
order = 0;
|
order = 0;
|
||||||
exit = false;
|
exit = false;
|
||||||
@ -487,6 +486,5 @@ EditorResourcePreview::EditorResourcePreview() {
|
|||||||
EditorResourcePreview::~EditorResourcePreview() {
|
EditorResourcePreview::~EditorResourcePreview() {
|
||||||
|
|
||||||
stop();
|
stop();
|
||||||
memdelete(preview_mutex);
|
|
||||||
memdelete(preview_sem);
|
memdelete(preview_sem);
|
||||||
}
|
}
|
||||||
|
@ -70,7 +70,7 @@ class EditorResourcePreview : public Node {
|
|||||||
|
|
||||||
List<QueueItem> queue;
|
List<QueueItem> queue;
|
||||||
|
|
||||||
Mutex *preview_mutex;
|
Mutex preview_mutex;
|
||||||
Semaphore *preview_sem;
|
Semaphore *preview_sem;
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
volatile bool exit;
|
volatile bool exit;
|
||||||
|
@ -42,9 +42,9 @@
|
|||||||
void EditorFileServer::_close_client(ClientData *cd) {
|
void EditorFileServer::_close_client(ClientData *cd) {
|
||||||
|
|
||||||
cd->connection->disconnect_from_host();
|
cd->connection->disconnect_from_host();
|
||||||
cd->efs->wait_mutex->lock();
|
cd->efs->wait_mutex.lock();
|
||||||
cd->efs->to_wait.insert(cd->thread);
|
cd->efs->to_wait.insert(cd->thread);
|
||||||
cd->efs->wait_mutex->unlock();
|
cd->efs->wait_mutex.unlock();
|
||||||
while (cd->files.size()) {
|
while (cd->files.size()) {
|
||||||
memdelete(cd->files.front()->get());
|
memdelete(cd->files.front()->get());
|
||||||
cd->files.erase(cd->files.front());
|
cd->files.erase(cd->files.front());
|
||||||
@ -295,16 +295,16 @@ void EditorFileServer::_thread_start(void *s) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
self->wait_mutex->lock();
|
self->wait_mutex.lock();
|
||||||
while (self->to_wait.size()) {
|
while (self->to_wait.size()) {
|
||||||
Thread *w = self->to_wait.front()->get();
|
Thread *w = self->to_wait.front()->get();
|
||||||
self->to_wait.erase(w);
|
self->to_wait.erase(w);
|
||||||
self->wait_mutex->unlock();
|
self->wait_mutex.unlock();
|
||||||
Thread::wait_to_finish(w);
|
Thread::wait_to_finish(w);
|
||||||
memdelete(w);
|
memdelete(w);
|
||||||
self->wait_mutex->lock();
|
self->wait_mutex.lock();
|
||||||
}
|
}
|
||||||
self->wait_mutex->unlock();
|
self->wait_mutex.unlock();
|
||||||
|
|
||||||
OS::get_singleton()->delay_usec(100000);
|
OS::get_singleton()->delay_usec(100000);
|
||||||
}
|
}
|
||||||
@ -331,7 +331,6 @@ void EditorFileServer::stop() {
|
|||||||
EditorFileServer::EditorFileServer() {
|
EditorFileServer::EditorFileServer() {
|
||||||
|
|
||||||
server.instance();
|
server.instance();
|
||||||
wait_mutex = Mutex::create();
|
|
||||||
quit = false;
|
quit = false;
|
||||||
active = false;
|
active = false;
|
||||||
cmd = CMD_NONE;
|
cmd = CMD_NONE;
|
||||||
@ -346,5 +345,4 @@ EditorFileServer::~EditorFileServer() {
|
|||||||
quit = true;
|
quit = true;
|
||||||
Thread::wait_to_finish(thread);
|
Thread::wait_to_finish(thread);
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
memdelete(wait_mutex);
|
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ class EditorFileServer : public Object {
|
|||||||
static void _close_client(ClientData *cd);
|
static void _close_client(ClientData *cd);
|
||||||
static void _subthread_start(void *s);
|
static void _subthread_start(void *s);
|
||||||
|
|
||||||
Mutex *wait_mutex;
|
Mutex wait_mutex;
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
static void _thread_start(void *);
|
static void _thread_start(void *);
|
||||||
bool quit;
|
bool quit;
|
||||||
|
@ -38,7 +38,7 @@
|
|||||||
|
|
||||||
void ResourceImporterTexture::_texture_reimport_srgb(const Ref<StreamTexture> &p_tex) {
|
void ResourceImporterTexture::_texture_reimport_srgb(const Ref<StreamTexture> &p_tex) {
|
||||||
|
|
||||||
singleton->mutex->lock();
|
singleton->mutex.lock();
|
||||||
StringName path = p_tex->get_path();
|
StringName path = p_tex->get_path();
|
||||||
|
|
||||||
if (!singleton->make_flags.has(path)) {
|
if (!singleton->make_flags.has(path)) {
|
||||||
@ -47,12 +47,12 @@ void ResourceImporterTexture::_texture_reimport_srgb(const Ref<StreamTexture> &p
|
|||||||
|
|
||||||
singleton->make_flags[path] |= MAKE_SRGB_FLAG;
|
singleton->make_flags[path] |= MAKE_SRGB_FLAG;
|
||||||
|
|
||||||
singleton->mutex->unlock();
|
singleton->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResourceImporterTexture::_texture_reimport_3d(const Ref<StreamTexture> &p_tex) {
|
void ResourceImporterTexture::_texture_reimport_3d(const Ref<StreamTexture> &p_tex) {
|
||||||
|
|
||||||
singleton->mutex->lock();
|
singleton->mutex.lock();
|
||||||
StringName path = p_tex->get_path();
|
StringName path = p_tex->get_path();
|
||||||
|
|
||||||
if (!singleton->make_flags.has(path)) {
|
if (!singleton->make_flags.has(path)) {
|
||||||
@ -61,12 +61,12 @@ void ResourceImporterTexture::_texture_reimport_3d(const Ref<StreamTexture> &p_t
|
|||||||
|
|
||||||
singleton->make_flags[path] |= MAKE_3D_FLAG;
|
singleton->make_flags[path] |= MAKE_3D_FLAG;
|
||||||
|
|
||||||
singleton->mutex->unlock();
|
singleton->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResourceImporterTexture::_texture_reimport_normal(const Ref<StreamTexture> &p_tex) {
|
void ResourceImporterTexture::_texture_reimport_normal(const Ref<StreamTexture> &p_tex) {
|
||||||
|
|
||||||
singleton->mutex->lock();
|
singleton->mutex.lock();
|
||||||
StringName path = p_tex->get_path();
|
StringName path = p_tex->get_path();
|
||||||
|
|
||||||
if (!singleton->make_flags.has(path)) {
|
if (!singleton->make_flags.has(path)) {
|
||||||
@ -75,7 +75,7 @@ void ResourceImporterTexture::_texture_reimport_normal(const Ref<StreamTexture>
|
|||||||
|
|
||||||
singleton->make_flags[path] |= MAKE_NORMAL_FLAG;
|
singleton->make_flags[path] |= MAKE_NORMAL_FLAG;
|
||||||
|
|
||||||
singleton->mutex->unlock();
|
singleton->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ResourceImporterTexture::update_imports() {
|
void ResourceImporterTexture::update_imports() {
|
||||||
@ -83,10 +83,10 @@ void ResourceImporterTexture::update_imports() {
|
|||||||
if (EditorFileSystem::get_singleton()->is_scanning() || EditorFileSystem::get_singleton()->is_importing()) {
|
if (EditorFileSystem::get_singleton()->is_scanning() || EditorFileSystem::get_singleton()->is_importing()) {
|
||||||
return; // do nothing for now
|
return; // do nothing for now
|
||||||
}
|
}
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
|
|
||||||
if (make_flags.empty()) {
|
if (make_flags.empty()) {
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +128,7 @@ void ResourceImporterTexture::update_imports() {
|
|||||||
|
|
||||||
make_flags.clear();
|
make_flags.clear();
|
||||||
|
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
|
|
||||||
if (to_reimport.size()) {
|
if (to_reimport.size()) {
|
||||||
EditorFileSystem::get_singleton()->reimport_files(to_reimport);
|
EditorFileSystem::get_singleton()->reimport_files(to_reimport);
|
||||||
@ -611,10 +611,4 @@ ResourceImporterTexture::ResourceImporterTexture() {
|
|||||||
StreamTexture::request_3d_callback = _texture_reimport_3d;
|
StreamTexture::request_3d_callback = _texture_reimport_3d;
|
||||||
StreamTexture::request_srgb_callback = _texture_reimport_srgb;
|
StreamTexture::request_srgb_callback = _texture_reimport_srgb;
|
||||||
StreamTexture::request_normal_callback = _texture_reimport_normal;
|
StreamTexture::request_normal_callback = _texture_reimport_normal;
|
||||||
mutex = Mutex::create();
|
|
||||||
}
|
|
||||||
|
|
||||||
ResourceImporterTexture::~ResourceImporterTexture() {
|
|
||||||
|
|
||||||
memdelete(mutex);
|
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ protected:
|
|||||||
MAKE_NORMAL_FLAG = 4
|
MAKE_NORMAL_FLAG = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
Map<StringName, int> make_flags;
|
Map<StringName, int> make_flags;
|
||||||
|
|
||||||
static void _texture_reimport_srgb(const Ref<StreamTexture> &p_tex);
|
static void _texture_reimport_srgb(const Ref<StreamTexture> &p_tex);
|
||||||
@ -94,7 +94,6 @@ public:
|
|||||||
virtual String get_import_settings_string() const;
|
virtual String get_import_settings_string() const;
|
||||||
|
|
||||||
ResourceImporterTexture();
|
ResourceImporterTexture();
|
||||||
~ResourceImporterTexture();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // RESOURCEIMPORTTEXTURE_H
|
#endif // RESOURCEIMPORTTEXTURE_H
|
||||||
|
@ -220,15 +220,9 @@ ScriptInstance *NativeScript::instance_create(Object *p_this) {
|
|||||||
nsi->userdata = script_data->create_func.create_func((godot_object *)p_this, script_data->create_func.method_data);
|
nsi->userdata = script_data->create_func.create_func((godot_object *)p_this, script_data->create_func.method_data);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
owners_lock.lock();
|
||||||
owners_lock->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
instance_owners.insert(p_this);
|
instance_owners.insert(p_this);
|
||||||
|
owners_lock.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
owners_lock->unlock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return nsi;
|
return nsi;
|
||||||
}
|
}
|
||||||
@ -524,17 +518,10 @@ NativeScript::NativeScript() {
|
|||||||
library = Ref<GDNative>();
|
library = Ref<GDNative>();
|
||||||
lib_path = "";
|
lib_path = "";
|
||||||
class_name = "";
|
class_name = "";
|
||||||
#ifndef NO_THREADS
|
|
||||||
owners_lock = Mutex::create();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
NativeScript::~NativeScript() {
|
NativeScript::~NativeScript() {
|
||||||
NSL->unregister_script(this);
|
NSL->unregister_script(this);
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(owners_lock);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define GET_SCRIPT_DESC() script->get_script_desc()
|
#define GET_SCRIPT_DESC() script->get_script_desc()
|
||||||
@ -911,15 +898,9 @@ NativeScriptInstance::~NativeScriptInstance() {
|
|||||||
|
|
||||||
if (owner) {
|
if (owner) {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
script->owners_lock.lock();
|
||||||
script->owners_lock->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
script->instance_owners.erase(owner);
|
script->instance_owners.erase(owner);
|
||||||
|
script->owners_lock.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
script->owners_lock->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1016,7 +997,6 @@ NativeScriptLanguage::NativeScriptLanguage() {
|
|||||||
NativeScriptLanguage::singleton = this;
|
NativeScriptLanguage::singleton = this;
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
has_objects_to_register = false;
|
has_objects_to_register = false;
|
||||||
mutex = Mutex::create();
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
@ -1053,10 +1033,6 @@ NativeScriptLanguage::~NativeScriptLanguage() {
|
|||||||
NSL->library_classes.clear();
|
NSL->library_classes.clear();
|
||||||
NSL->library_gdnatives.clear();
|
NSL->library_gdnatives.clear();
|
||||||
NSL->library_script_users.clear();
|
NSL->library_script_users.clear();
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(mutex);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String NativeScriptLanguage::get_name() const {
|
String NativeScriptLanguage::get_name() const {
|
||||||
|
@ -121,9 +121,7 @@ class NativeScript : public Script {
|
|||||||
String script_class_name;
|
String script_class_name;
|
||||||
String script_class_icon_path;
|
String script_class_icon_path;
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
Mutex owners_lock;
|
||||||
Mutex *owners_lock;
|
|
||||||
#endif
|
|
||||||
Set<Object *> instance_owners;
|
Set<Object *> instance_owners;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -238,7 +236,7 @@ private:
|
|||||||
void _unload_stuff(bool p_reload = false);
|
void _unload_stuff(bool p_reload = false);
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
Set<Ref<GDNativeLibrary> > libs_to_init;
|
Set<Ref<GDNativeLibrary> > libs_to_init;
|
||||||
Set<NativeScript *> scripts_to_register;
|
Set<NativeScript *> scripts_to_register;
|
||||||
|
@ -400,39 +400,15 @@ void PluginScriptLanguage::reload_tool_script(const Ref<Script> &p_script, bool
|
|||||||
}
|
}
|
||||||
|
|
||||||
void PluginScriptLanguage::lock() {
|
void PluginScriptLanguage::lock() {
|
||||||
#ifndef NO_THREADS
|
_lock.lock();
|
||||||
if (_lock) {
|
|
||||||
_lock->lock();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PluginScriptLanguage::unlock() {
|
void PluginScriptLanguage::unlock() {
|
||||||
#ifndef NO_THREADS
|
_lock.unlock();
|
||||||
if (_lock) {
|
|
||||||
_lock->unlock();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PluginScriptLanguage::PluginScriptLanguage(const godot_pluginscript_language_desc *desc) :
|
PluginScriptLanguage::PluginScriptLanguage(const godot_pluginscript_language_desc *desc) :
|
||||||
_desc(*desc) {
|
_desc(*desc) {
|
||||||
_resource_loader = Ref<ResourceFormatLoaderPluginScript>(memnew(ResourceFormatLoaderPluginScript(this)));
|
_resource_loader = Ref<ResourceFormatLoaderPluginScript>(memnew(ResourceFormatLoaderPluginScript(this)));
|
||||||
_resource_saver = Ref<ResourceFormatSaverPluginScript>(memnew(ResourceFormatSaverPluginScript(this)));
|
_resource_saver = Ref<ResourceFormatSaverPluginScript>(memnew(ResourceFormatSaverPluginScript(this)));
|
||||||
|
|
||||||
// TODO: totally remove _lock attribute if NO_THREADS is set
|
|
||||||
#ifdef NO_THREADS
|
|
||||||
_lock = NULL;
|
|
||||||
#else
|
|
||||||
_lock = Mutex::create();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
PluginScriptLanguage::~PluginScriptLanguage() {
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
if (_lock) {
|
|
||||||
memdelete(_lock);
|
|
||||||
_lock = NULL;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ class PluginScriptLanguage : public ScriptLanguage {
|
|||||||
const godot_pluginscript_language_desc _desc;
|
const godot_pluginscript_language_desc _desc;
|
||||||
godot_pluginscript_language_data *_data;
|
godot_pluginscript_language_data *_data;
|
||||||
|
|
||||||
Mutex *_lock;
|
Mutex _lock;
|
||||||
SelfList<PluginScript>::List _script_list;
|
SelfList<PluginScript>::List _script_list;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -126,7 +126,7 @@ public:
|
|||||||
void unlock();
|
void unlock();
|
||||||
|
|
||||||
PluginScriptLanguage(const godot_pluginscript_language_desc *desc);
|
PluginScriptLanguage(const godot_pluginscript_language_desc *desc);
|
||||||
virtual ~PluginScriptLanguage();
|
virtual ~PluginScriptLanguage() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // PLUGINSCRIPT_LANGUAGE_H
|
#endif // PLUGINSCRIPT_LANGUAGE_H
|
||||||
|
@ -101,15 +101,9 @@ GDScriptInstance *GDScript::_create_instance(const Variant **p_args, int p_argco
|
|||||||
|
|
||||||
/* STEP 2, INITIALIZE AND CONSTRUCT */
|
/* STEP 2, INITIALIZE AND CONSTRUCT */
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
instances.insert(instance->owner);
|
instances.insert(instance->owner);
|
||||||
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
initializer->call(instance, p_args, p_argcount, r_error);
|
initializer->call(instance, p_args, p_argcount, r_error);
|
||||||
|
|
||||||
@ -117,11 +111,11 @@ GDScriptInstance *GDScript::_create_instance(const Variant **p_args, int p_argco
|
|||||||
instance->script = Ref<GDScript>();
|
instance->script = Ref<GDScript>();
|
||||||
instance->owner->set_script_instance(NULL);
|
instance->owner->set_script_instance(NULL);
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
#endif
|
#endif
|
||||||
instances.erase(p_owner);
|
instances.erase(p_owner);
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ERR_FAIL_COND_V(r_error.error != Variant::CallError::CALL_OK, NULL); //error constructing
|
ERR_FAIL_COND_V(r_error.error != Variant::CallError::CALL_OK, NULL); //error constructing
|
||||||
@ -343,14 +337,9 @@ PlaceHolderScriptInstance *GDScript::placeholder_instance_create(Object *p_this)
|
|||||||
|
|
||||||
bool GDScript::instance_has(const Object *p_this) const {
|
bool GDScript::instance_has(const Object *p_this) const {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
bool hasit = instances.has((Object *)p_this);
|
bool hasit = instances.has((Object *)p_this);
|
||||||
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return hasit;
|
return hasit;
|
||||||
}
|
}
|
||||||
@ -564,14 +553,9 @@ void GDScript::_set_subclass_path(Ref<GDScript> &p_sc, const String &p_path) {
|
|||||||
|
|
||||||
Error GDScript::reload(bool p_keep_state) {
|
Error GDScript::reload(bool p_keep_state) {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
bool has_instances = instances.size();
|
bool has_instances = instances.size();
|
||||||
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ERR_FAIL_COND_V(!p_keep_state && has_instances, ERR_ALREADY_IN_USE);
|
ERR_FAIL_COND_V(!p_keep_state && has_instances, ERR_ALREADY_IN_USE);
|
||||||
|
|
||||||
@ -926,14 +910,9 @@ GDScript::GDScript() :
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.lock();
|
||||||
GDScriptLanguage::get_singleton()->lock->lock();
|
|
||||||
}
|
|
||||||
GDScriptLanguage::get_singleton()->script_list.add(&script_list);
|
GDScriptLanguage::get_singleton()->script_list.add(&script_list);
|
||||||
|
GDScriptLanguage::get_singleton()->lock.unlock();
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
|
||||||
GDScriptLanguage::get_singleton()->lock->unlock();
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -970,18 +949,14 @@ void GDScript::_save_orphaned_subclasses() {
|
|||||||
|
|
||||||
GDScript::~GDScript() {
|
GDScript::~GDScript() {
|
||||||
|
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.lock();
|
||||||
GDScriptLanguage::get_singleton()->lock->lock();
|
|
||||||
}
|
|
||||||
while (SelfList<GDScriptFunctionState> *E = pending_func_states.first()) {
|
while (SelfList<GDScriptFunctionState> *E = pending_func_states.first()) {
|
||||||
// Order matters since clearing the stack may already cause
|
// Order matters since clearing the stack may already cause
|
||||||
// the GDSCriptFunctionState to be destroyed and thus removed from the list.
|
// the GDSCriptFunctionState to be destroyed and thus removed from the list.
|
||||||
pending_func_states.remove(E);
|
pending_func_states.remove(E);
|
||||||
E->self()->_clear_stack();
|
E->self()->_clear_stack();
|
||||||
}
|
}
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.unlock();
|
||||||
GDScriptLanguage::get_singleton()->lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (Map<StringName, GDScriptFunction *>::Element *E = member_functions.front(); E; E = E->next()) {
|
for (Map<StringName, GDScriptFunction *>::Element *E = member_functions.front(); E; E = E->next()) {
|
||||||
memdelete(E->get());
|
memdelete(E->get());
|
||||||
@ -990,14 +965,9 @@ GDScript::~GDScript() {
|
|||||||
_save_orphaned_subclasses();
|
_save_orphaned_subclasses();
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.lock();
|
||||||
GDScriptLanguage::get_singleton()->lock->lock();
|
|
||||||
}
|
|
||||||
GDScriptLanguage::get_singleton()->script_list.remove(&script_list);
|
GDScriptLanguage::get_singleton()->script_list.remove(&script_list);
|
||||||
|
GDScriptLanguage::get_singleton()->lock.unlock();
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
|
||||||
GDScriptLanguage::get_singleton()->lock->unlock();
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1400,9 +1370,7 @@ GDScriptInstance::GDScriptInstance() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
GDScriptInstance::~GDScriptInstance() {
|
GDScriptInstance::~GDScriptInstance() {
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
while (SelfList<GDScriptFunctionState> *E = pending_func_states.first()) {
|
while (SelfList<GDScriptFunctionState> *E = pending_func_states.first()) {
|
||||||
// Order matters since clearing the stack may already cause
|
// Order matters since clearing the stack may already cause
|
||||||
@ -1415,9 +1383,7 @@ GDScriptInstance::~GDScriptInstance() {
|
|||||||
script->instances.erase(owner);
|
script->instances.erase(owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/************* SCRIPT LANGUAGE **************/
|
/************* SCRIPT LANGUAGE **************/
|
||||||
@ -1517,9 +1483,7 @@ void GDScriptLanguage::finish() {
|
|||||||
void GDScriptLanguage::profiling_start() {
|
void GDScriptLanguage::profiling_start() {
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
SelfList<GDScriptFunction> *elem = function_list.first();
|
SelfList<GDScriptFunction> *elem = function_list.first();
|
||||||
while (elem) {
|
while (elem) {
|
||||||
@ -1536,25 +1500,16 @@ void GDScriptLanguage::profiling_start() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
profiling = true;
|
profiling = true;
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void GDScriptLanguage::profiling_stop() {
|
void GDScriptLanguage::profiling_stop() {
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
profiling = false;
|
profiling = false;
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1562,9 +1517,7 @@ int GDScriptLanguage::profiling_get_accumulated_data(ProfilingInfo *p_info_arr,
|
|||||||
|
|
||||||
int current = 0;
|
int current = 0;
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
SelfList<GDScriptFunction> *elem = function_list.first();
|
SelfList<GDScriptFunction> *elem = function_list.first();
|
||||||
while (elem) {
|
while (elem) {
|
||||||
@ -1578,10 +1531,7 @@ int GDScriptLanguage::profiling_get_accumulated_data(ProfilingInfo *p_info_arr,
|
|||||||
current++;
|
current++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return current;
|
return current;
|
||||||
@ -1592,9 +1542,7 @@ int GDScriptLanguage::profiling_get_frame_data(ProfilingInfo *p_info_arr, int p_
|
|||||||
int current = 0;
|
int current = 0;
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
SelfList<GDScriptFunction> *elem = function_list.first();
|
SelfList<GDScriptFunction> *elem = function_list.first();
|
||||||
while (elem) {
|
while (elem) {
|
||||||
@ -1610,10 +1558,7 @@ int GDScriptLanguage::profiling_get_frame_data(ProfilingInfo *p_info_arr, int p_
|
|||||||
elem = elem->next();
|
elem = elem->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return current;
|
return current;
|
||||||
@ -1644,9 +1589,7 @@ void GDScriptLanguage::reload_all_scripts() {
|
|||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
print_verbose("GDScript: Reloading all scripts");
|
print_verbose("GDScript: Reloading all scripts");
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
List<Ref<GDScript> > scripts;
|
List<Ref<GDScript> > scripts;
|
||||||
|
|
||||||
@ -1659,9 +1602,7 @@ void GDScriptLanguage::reload_all_scripts() {
|
|||||||
elem = elem->next();
|
elem = elem->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
//as scripts are going to be reloaded, must proceed without locking here
|
//as scripts are going to be reloaded, must proceed without locking here
|
||||||
|
|
||||||
@ -1680,9 +1621,7 @@ void GDScriptLanguage::reload_tool_script(const Ref<Script> &p_script, bool p_so
|
|||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
|
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
List<Ref<GDScript> > scripts;
|
List<Ref<GDScript> > scripts;
|
||||||
|
|
||||||
@ -1695,9 +1634,7 @@ void GDScriptLanguage::reload_tool_script(const Ref<Script> &p_script, bool p_so
|
|||||||
elem = elem->next();
|
elem = elem->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
//when someone asks you why dynamically typed languages are easier to write....
|
//when someone asks you why dynamically typed languages are easier to write....
|
||||||
|
|
||||||
@ -1816,9 +1753,7 @@ void GDScriptLanguage::frame() {
|
|||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (profiling) {
|
if (profiling) {
|
||||||
if (lock) {
|
lock.lock();
|
||||||
lock->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
SelfList<GDScriptFunction> *elem = function_list.first();
|
SelfList<GDScriptFunction> *elem = function_list.first();
|
||||||
while (elem) {
|
while (elem) {
|
||||||
@ -1831,9 +1766,7 @@ void GDScriptLanguage::frame() {
|
|||||||
elem = elem->next();
|
elem = elem->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lock) {
|
lock.unlock();
|
||||||
lock->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@ -2202,11 +2135,6 @@ GDScriptLanguage::GDScriptLanguage() {
|
|||||||
_debug_parse_err_line = -1;
|
_debug_parse_err_line = -1;
|
||||||
_debug_parse_err_file = "";
|
_debug_parse_err_file = "";
|
||||||
|
|
||||||
#ifdef NO_THREADS
|
|
||||||
lock = NULL;
|
|
||||||
#else
|
|
||||||
lock = Mutex::create();
|
|
||||||
#endif
|
|
||||||
profiling = false;
|
profiling = false;
|
||||||
script_frame_time = 0;
|
script_frame_time = 0;
|
||||||
|
|
||||||
@ -2240,10 +2168,6 @@ GDScriptLanguage::GDScriptLanguage() {
|
|||||||
|
|
||||||
GDScriptLanguage::~GDScriptLanguage() {
|
GDScriptLanguage::~GDScriptLanguage() {
|
||||||
|
|
||||||
if (lock) {
|
|
||||||
memdelete(lock);
|
|
||||||
lock = NULL;
|
|
||||||
}
|
|
||||||
if (_call_stack) {
|
if (_call_stack) {
|
||||||
memdelete_arr(_call_stack);
|
memdelete_arr(_call_stack);
|
||||||
}
|
}
|
||||||
|
@ -351,7 +351,7 @@ class GDScriptLanguage : public ScriptLanguage {
|
|||||||
|
|
||||||
friend class GDScriptInstance;
|
friend class GDScriptInstance;
|
||||||
|
|
||||||
Mutex *lock;
|
Mutex lock;
|
||||||
|
|
||||||
friend class GDScript;
|
friend class GDScript;
|
||||||
|
|
||||||
|
@ -1279,9 +1279,7 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
|||||||
gdfs->state.ip = ip + ipofs;
|
gdfs->state.ip = ip + ipofs;
|
||||||
gdfs->state.line = line;
|
gdfs->state.line = line;
|
||||||
gdfs->state.script = _script;
|
gdfs->state.script = _script;
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_script->pending_func_states.add(&gdfs->scripts_list);
|
_script->pending_func_states.add(&gdfs->scripts_list);
|
||||||
if (p_instance) {
|
if (p_instance) {
|
||||||
@ -1290,9 +1288,7 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
|||||||
} else {
|
} else {
|
||||||
gdfs->state.instance = NULL;
|
gdfs->state.instance = NULL;
|
||||||
}
|
}
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
gdfs->state.function_name = name;
|
gdfs->state.function_name = name;
|
||||||
gdfs->state.script_path = _script->get_path();
|
gdfs->state.script_path = _script->get_path();
|
||||||
@ -1776,14 +1772,9 @@ GDScriptFunction::GDScriptFunction() :
|
|||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
_func_cname = NULL;
|
_func_cname = NULL;
|
||||||
|
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.lock();
|
||||||
GDScriptLanguage::get_singleton()->lock->lock();
|
|
||||||
}
|
|
||||||
GDScriptLanguage::get_singleton()->function_list.add(&function_list);
|
GDScriptLanguage::get_singleton()->function_list.add(&function_list);
|
||||||
|
GDScriptLanguage::get_singleton()->lock.unlock();
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
|
||||||
GDScriptLanguage::get_singleton()->lock->unlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
profile.call_count = 0;
|
profile.call_count = 0;
|
||||||
profile.self_time = 0;
|
profile.self_time = 0;
|
||||||
@ -1800,14 +1791,9 @@ GDScriptFunction::GDScriptFunction() :
|
|||||||
|
|
||||||
GDScriptFunction::~GDScriptFunction() {
|
GDScriptFunction::~GDScriptFunction() {
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
GDScriptLanguage::get_singleton()->lock.lock();
|
||||||
GDScriptLanguage::get_singleton()->lock->lock();
|
|
||||||
}
|
|
||||||
GDScriptLanguage::get_singleton()->function_list.remove(&function_list);
|
GDScriptLanguage::get_singleton()->function_list.remove(&function_list);
|
||||||
|
GDScriptLanguage::get_singleton()->lock.unlock();
|
||||||
if (GDScriptLanguage::get_singleton()->lock) {
|
|
||||||
GDScriptLanguage::get_singleton()->lock->unlock();
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1958,12 +1944,8 @@ GDScriptFunctionState::GDScriptFunctionState() :
|
|||||||
GDScriptFunctionState::~GDScriptFunctionState() {
|
GDScriptFunctionState::~GDScriptFunctionState() {
|
||||||
|
|
||||||
_clear_stack();
|
_clear_stack();
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.lock();
|
||||||
GDScriptLanguage::singleton->lock->lock();
|
|
||||||
#endif
|
|
||||||
scripts_list.remove_from_list();
|
scripts_list.remove_from_list();
|
||||||
instances_list.remove_from_list();
|
instances_list.remove_from_list();
|
||||||
#ifndef NO_THREADS
|
GDScriptLanguage::singleton->lock.unlock();
|
||||||
GDScriptLanguage::singleton->lock->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,6 @@
|
|||||||
#include "mono_gd/gd_mono_utils.h"
|
#include "mono_gd/gd_mono_utils.h"
|
||||||
#include "signal_awaiter_utils.h"
|
#include "signal_awaiter_utils.h"
|
||||||
#include "utils/macros.h"
|
#include "utils/macros.h"
|
||||||
#include "utils/mutex_utils.h"
|
|
||||||
#include "utils/string_utils.h"
|
#include "utils/string_utils.h"
|
||||||
#include "utils/thread_local.h"
|
#include "utils/thread_local.h"
|
||||||
|
|
||||||
@ -638,7 +637,7 @@ Vector<ScriptLanguage::StackInfo> CSharpLanguage::stack_trace_get_info(MonoObjec
|
|||||||
|
|
||||||
void CSharpLanguage::post_unsafe_reference(Object *p_obj) {
|
void CSharpLanguage::post_unsafe_reference(Object *p_obj) {
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
SCOPED_MUTEX_LOCK(unsafe_object_references_lock);
|
MutexLock lock(unsafe_object_references_lock);
|
||||||
ObjectID id = p_obj->get_instance_id();
|
ObjectID id = p_obj->get_instance_id();
|
||||||
unsafe_object_references[id]++;
|
unsafe_object_references[id]++;
|
||||||
#endif
|
#endif
|
||||||
@ -646,7 +645,7 @@ void CSharpLanguage::post_unsafe_reference(Object *p_obj) {
|
|||||||
|
|
||||||
void CSharpLanguage::pre_unsafe_unreference(Object *p_obj) {
|
void CSharpLanguage::pre_unsafe_unreference(Object *p_obj) {
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
SCOPED_MUTEX_LOCK(unsafe_object_references_lock);
|
MutexLock lock(unsafe_object_references_lock);
|
||||||
ObjectID id = p_obj->get_instance_id();
|
ObjectID id = p_obj->get_instance_id();
|
||||||
Map<ObjectID, int>::Element *elem = unsafe_object_references.find(id);
|
Map<ObjectID, int>::Element *elem = unsafe_object_references.find(id);
|
||||||
ERR_FAIL_NULL(elem);
|
ERR_FAIL_NULL(elem);
|
||||||
@ -769,7 +768,7 @@ void CSharpLanguage::reload_assemblies(bool p_soft_reload) {
|
|||||||
List<Ref<CSharpScript> > scripts;
|
List<Ref<CSharpScript> > scripts;
|
||||||
|
|
||||||
{
|
{
|
||||||
SCOPED_MUTEX_LOCK(script_instances_mutex);
|
MutexLock lock(script_instances_mutex);
|
||||||
|
|
||||||
for (SelfList<CSharpScript> *elem = script_list.first(); elem; elem = elem->next()) {
|
for (SelfList<CSharpScript> *elem = script_list.first(); elem; elem = elem->next()) {
|
||||||
// Cast to CSharpScript to avoid being erased by accident
|
// Cast to CSharpScript to avoid being erased by accident
|
||||||
@ -1209,7 +1208,7 @@ void CSharpLanguage::set_language_index(int p_idx) {
|
|||||||
void CSharpLanguage::release_script_gchandle(Ref<MonoGCHandle> &p_gchandle) {
|
void CSharpLanguage::release_script_gchandle(Ref<MonoGCHandle> &p_gchandle) {
|
||||||
|
|
||||||
if (!p_gchandle->is_released()) { // Do not lock unnecessarily
|
if (!p_gchandle->is_released()) { // Do not lock unnecessarily
|
||||||
SCOPED_MUTEX_LOCK(get_singleton()->script_gchandle_release_mutex);
|
MutexLock lock(get_singleton()->script_gchandle_release_mutex);
|
||||||
p_gchandle->release();
|
p_gchandle->release();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1219,7 +1218,7 @@ void CSharpLanguage::release_script_gchandle(MonoObject *p_expected_obj, Ref<Mon
|
|||||||
uint32_t pinned_gchandle = MonoGCHandle::new_strong_handle_pinned(p_expected_obj); // We might lock after this, so pin it
|
uint32_t pinned_gchandle = MonoGCHandle::new_strong_handle_pinned(p_expected_obj); // We might lock after this, so pin it
|
||||||
|
|
||||||
if (!p_gchandle->is_released()) { // Do not lock unnecessarily
|
if (!p_gchandle->is_released()) { // Do not lock unnecessarily
|
||||||
SCOPED_MUTEX_LOCK(get_singleton()->script_gchandle_release_mutex);
|
MutexLock lock(get_singleton()->script_gchandle_release_mutex);
|
||||||
|
|
||||||
MonoObject *target = p_gchandle->get_target();
|
MonoObject *target = p_gchandle->get_target();
|
||||||
|
|
||||||
@ -1244,24 +1243,6 @@ CSharpLanguage::CSharpLanguage() {
|
|||||||
|
|
||||||
gdmono = NULL;
|
gdmono = NULL;
|
||||||
|
|
||||||
#ifdef NO_THREADS
|
|
||||||
script_instances_mutex = NULL;
|
|
||||||
script_gchandle_release_mutex = NULL;
|
|
||||||
language_bind_mutex = NULL;
|
|
||||||
#else
|
|
||||||
script_instances_mutex = Mutex::create();
|
|
||||||
script_gchandle_release_mutex = Mutex::create();
|
|
||||||
language_bind_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
|
||||||
#ifdef NO_THREADS
|
|
||||||
unsafe_object_references_lock = NULL;
|
|
||||||
#else
|
|
||||||
unsafe_object_references_lock = Mutex::create();
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
lang_idx = -1;
|
lang_idx = -1;
|
||||||
|
|
||||||
scripts_metadata_invalidated = true;
|
scripts_metadata_invalidated = true;
|
||||||
@ -1274,29 +1255,6 @@ CSharpLanguage::CSharpLanguage() {
|
|||||||
CSharpLanguage::~CSharpLanguage() {
|
CSharpLanguage::~CSharpLanguage() {
|
||||||
|
|
||||||
finish();
|
finish();
|
||||||
|
|
||||||
if (script_instances_mutex) {
|
|
||||||
memdelete(script_instances_mutex);
|
|
||||||
script_instances_mutex = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (language_bind_mutex) {
|
|
||||||
memdelete(language_bind_mutex);
|
|
||||||
language_bind_mutex = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (script_gchandle_release_mutex) {
|
|
||||||
memdelete(script_gchandle_release_mutex);
|
|
||||||
script_gchandle_release_mutex = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
|
||||||
if (unsafe_object_references_lock) {
|
|
||||||
memdelete(unsafe_object_references_lock);
|
|
||||||
unsafe_object_references_lock = NULL;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
singleton = NULL;
|
singleton = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1351,7 +1309,7 @@ bool CSharpLanguage::setup_csharp_script_binding(CSharpScriptBinding &r_script_b
|
|||||||
|
|
||||||
void *CSharpLanguage::alloc_instance_binding_data(Object *p_object) {
|
void *CSharpLanguage::alloc_instance_binding_data(Object *p_object) {
|
||||||
|
|
||||||
SCOPED_MUTEX_LOCK(language_bind_mutex);
|
MutexLock lock(language_bind_mutex);
|
||||||
|
|
||||||
Map<Object *, CSharpScriptBinding>::Element *match = script_bindings.find(p_object);
|
Map<Object *, CSharpScriptBinding>::Element *match = script_bindings.find(p_object);
|
||||||
if (match)
|
if (match)
|
||||||
@ -1386,7 +1344,7 @@ void CSharpLanguage::free_instance_binding_data(void *p_data) {
|
|||||||
GD_MONO_ASSERT_THREAD_ATTACHED;
|
GD_MONO_ASSERT_THREAD_ATTACHED;
|
||||||
|
|
||||||
{
|
{
|
||||||
SCOPED_MUTEX_LOCK(language_bind_mutex);
|
MutexLock lock(language_bind_mutex);
|
||||||
|
|
||||||
Map<Object *, CSharpScriptBinding>::Element *data = (Map<Object *, CSharpScriptBinding>::Element *)p_data;
|
Map<Object *, CSharpScriptBinding>::Element *data = (Map<Object *, CSharpScriptBinding>::Element *)p_data;
|
||||||
|
|
||||||
@ -2216,7 +2174,7 @@ CSharpInstance::~CSharpInstance() {
|
|||||||
CSharpScriptBinding &script_binding = ((Map<Object *, CSharpScriptBinding>::Element *)data)->get();
|
CSharpScriptBinding &script_binding = ((Map<Object *, CSharpScriptBinding>::Element *)data)->get();
|
||||||
|
|
||||||
if (!script_binding.inited) {
|
if (!script_binding.inited) {
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->get_language_bind_mutex());
|
MutexLock lock(CSharpLanguage::get_singleton()->get_language_bind_mutex());
|
||||||
|
|
||||||
if (!script_binding.inited) { // Other thread may have set it up
|
if (!script_binding.inited) { // Other thread may have set it up
|
||||||
// Already had a binding that needs to be setup
|
// Already had a binding that needs to be setup
|
||||||
@ -2232,7 +2190,7 @@ CSharpInstance::~CSharpInstance() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (script.is_valid() && owner) {
|
if (script.is_valid() && owner) {
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
// CSharpInstance must not be created unless it's going to be added to the list for sure
|
// CSharpInstance must not be created unless it's going to be added to the list for sure
|
||||||
@ -3034,7 +2992,7 @@ CSharpInstance *CSharpScript::_create_instance(const Variant **p_args, int p_arg
|
|||||||
instance->_reference_owner_unsafe(); // Here, after assigning the gchandle (for the refcount_incremented callback)
|
instance->_reference_owner_unsafe(); // Here, after assigning the gchandle (for the refcount_incremented callback)
|
||||||
|
|
||||||
{
|
{
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
instances.insert(instance->owner);
|
instances.insert(instance->owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3122,7 +3080,7 @@ PlaceHolderScriptInstance *CSharpScript::placeholder_instance_create(Object *p_t
|
|||||||
|
|
||||||
bool CSharpScript::instance_has(const Object *p_this) const {
|
bool CSharpScript::instance_has(const Object *p_this) const {
|
||||||
|
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
return instances.has((Object *)p_this);
|
return instances.has((Object *)p_this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3195,7 +3153,7 @@ Error CSharpScript::reload(bool p_keep_state) {
|
|||||||
|
|
||||||
bool has_instances;
|
bool has_instances;
|
||||||
{
|
{
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
has_instances = instances.size();
|
has_instances = instances.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3394,7 +3352,7 @@ CSharpScript::CSharpScript() :
|
|||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
{
|
{
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
CSharpLanguage::get_singleton()->script_list.add(&this->script_list);
|
CSharpLanguage::get_singleton()->script_list.add(&this->script_list);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -3403,7 +3361,7 @@ CSharpScript::CSharpScript() :
|
|||||||
CSharpScript::~CSharpScript() {
|
CSharpScript::~CSharpScript() {
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->script_instances_mutex);
|
MutexLock lock(CSharpLanguage::get_singleton()->script_instances_mutex);
|
||||||
CSharpLanguage::get_singleton()->script_list.remove(&this->script_list);
|
CSharpLanguage::get_singleton()->script_list.remove(&this->script_list);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -307,16 +307,16 @@ class CSharpLanguage : public ScriptLanguage {
|
|||||||
GDMono *gdmono;
|
GDMono *gdmono;
|
||||||
SelfList<CSharpScript>::List script_list;
|
SelfList<CSharpScript>::List script_list;
|
||||||
|
|
||||||
Mutex *script_instances_mutex;
|
Mutex script_instances_mutex;
|
||||||
Mutex *script_gchandle_release_mutex;
|
Mutex script_gchandle_release_mutex;
|
||||||
Mutex *language_bind_mutex;
|
Mutex language_bind_mutex;
|
||||||
|
|
||||||
Map<Object *, CSharpScriptBinding> script_bindings;
|
Map<Object *, CSharpScriptBinding> script_bindings;
|
||||||
|
|
||||||
#ifdef DEBUG_ENABLED
|
#ifdef DEBUG_ENABLED
|
||||||
// List of unsafe object references
|
// List of unsafe object references
|
||||||
Map<ObjectID, int> unsafe_object_references;
|
Map<ObjectID, int> unsafe_object_references;
|
||||||
Mutex *unsafe_object_references_lock;
|
Mutex unsafe_object_references_lock;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct StringNameCache {
|
struct StringNameCache {
|
||||||
@ -358,7 +358,7 @@ class CSharpLanguage : public ScriptLanguage {
|
|||||||
public:
|
public:
|
||||||
StringNameCache string_names;
|
StringNameCache string_names;
|
||||||
|
|
||||||
Mutex *get_language_bind_mutex() { return language_bind_mutex; }
|
Mutex &get_language_bind_mutex() { return language_bind_mutex; }
|
||||||
|
|
||||||
_FORCE_INLINE_ int get_language_index() { return lang_idx; }
|
_FORCE_INLINE_ int get_language_index() { return lang_idx; }
|
||||||
void set_language_index(int p_idx);
|
void set_language_index(int p_idx);
|
||||||
|
@ -44,7 +44,6 @@
|
|||||||
|
|
||||||
#include "../csharp_script.h"
|
#include "../csharp_script.h"
|
||||||
#include "../utils/macros.h"
|
#include "../utils/macros.h"
|
||||||
#include "../utils/mutex_utils.h"
|
|
||||||
#include "gd_mono.h"
|
#include "gd_mono.h"
|
||||||
#include "gd_mono_cache.h"
|
#include "gd_mono_cache.h"
|
||||||
#include "gd_mono_class.h"
|
#include "gd_mono_class.h"
|
||||||
@ -75,7 +74,7 @@ MonoObject *unmanaged_get_managed(Object *unmanaged) {
|
|||||||
CSharpScriptBinding &script_binding = ((Map<Object *, CSharpScriptBinding>::Element *)data)->value();
|
CSharpScriptBinding &script_binding = ((Map<Object *, CSharpScriptBinding>::Element *)data)->value();
|
||||||
|
|
||||||
if (!script_binding.inited) {
|
if (!script_binding.inited) {
|
||||||
SCOPED_MUTEX_LOCK(CSharpLanguage::get_singleton()->get_language_bind_mutex());
|
MutexLock lock(CSharpLanguage::get_singleton()->get_language_bind_mutex());
|
||||||
|
|
||||||
if (!script_binding.inited) { // Other thread may have set it up
|
if (!script_binding.inited) { // Other thread may have set it up
|
||||||
// Already had a binding that needs to be setup
|
// Already had a binding that needs to be setup
|
||||||
|
@ -1,67 +0,0 @@
|
|||||||
/*************************************************************************/
|
|
||||||
/* mutex_utils.h */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* This file is part of: */
|
|
||||||
/* GODOT ENGINE */
|
|
||||||
/* https://godotengine.org */
|
|
||||||
/*************************************************************************/
|
|
||||||
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
||||||
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
||||||
/* */
|
|
||||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
||||||
/* a copy of this software and associated documentation files (the */
|
|
||||||
/* "Software"), to deal in the Software without restriction, including */
|
|
||||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
||||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
||||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
||||||
/* the following conditions: */
|
|
||||||
/* */
|
|
||||||
/* The above copyright notice and this permission notice shall be */
|
|
||||||
/* included in all copies or substantial portions of the Software. */
|
|
||||||
/* */
|
|
||||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
||||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
||||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
||||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
||||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
||||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
||||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
||||||
/*************************************************************************/
|
|
||||||
|
|
||||||
#ifndef MUTEX_UTILS_H
|
|
||||||
#define MUTEX_UTILS_H
|
|
||||||
|
|
||||||
#include "core/error_macros.h"
|
|
||||||
#include "core/os/mutex.h"
|
|
||||||
|
|
||||||
#include "macros.h"
|
|
||||||
|
|
||||||
class ScopedMutexLock {
|
|
||||||
Mutex *mutex;
|
|
||||||
|
|
||||||
public:
|
|
||||||
ScopedMutexLock(Mutex *mutex) {
|
|
||||||
this->mutex = mutex;
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
#ifdef DEBUG_ENABLED
|
|
||||||
CRASH_COND(!mutex);
|
|
||||||
#endif
|
|
||||||
this->mutex->lock();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
~ScopedMutexLock() {
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
#ifdef DEBUG_ENABLED
|
|
||||||
CRASH_COND(!mutex);
|
|
||||||
#endif
|
|
||||||
mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
#define SCOPED_MUTEX_LOCK(m_mutex) ScopedMutexLock GD_UNIQUE_NAME(__scoped_mutex_lock__)(m_mutex);
|
|
||||||
|
|
||||||
// TODO: Add version that receives a lambda instead, once C++11 is allowed
|
|
||||||
|
|
||||||
#endif // MUTEX_UTILS_H
|
|
@ -926,13 +926,9 @@ ScriptInstance *VisualScript::instance_create(Object *p_this) {
|
|||||||
VisualScriptInstance *instance = memnew(VisualScriptInstance);
|
VisualScriptInstance *instance = memnew(VisualScriptInstance);
|
||||||
instance->create(Ref<VisualScript>(this), p_this);
|
instance->create(Ref<VisualScript>(this), p_this);
|
||||||
|
|
||||||
if (VisualScriptLanguage::singleton->lock)
|
VisualScriptLanguage::singleton->lock.lock();
|
||||||
VisualScriptLanguage::singleton->lock->lock();
|
|
||||||
|
|
||||||
instances[p_this] = instance;
|
instances[p_this] = instance;
|
||||||
|
VisualScriptLanguage::singleton->lock.unlock();
|
||||||
if (VisualScriptLanguage::singleton->lock)
|
|
||||||
VisualScriptLanguage::singleton->lock->unlock();
|
|
||||||
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
@ -2298,13 +2294,9 @@ VisualScriptInstance::VisualScriptInstance() {
|
|||||||
|
|
||||||
VisualScriptInstance::~VisualScriptInstance() {
|
VisualScriptInstance::~VisualScriptInstance() {
|
||||||
|
|
||||||
if (VisualScriptLanguage::singleton->lock)
|
VisualScriptLanguage::singleton->lock.lock();
|
||||||
VisualScriptLanguage::singleton->lock->lock();
|
|
||||||
|
|
||||||
script->instances.erase(owner);
|
script->instances.erase(owner);
|
||||||
|
VisualScriptLanguage::singleton->lock.unlock();
|
||||||
if (VisualScriptLanguage::singleton->lock)
|
|
||||||
VisualScriptLanguage::singleton->lock->unlock();
|
|
||||||
|
|
||||||
for (Map<int, VisualScriptNodeInstance *>::Element *E = instances.front(); E; E = E->next()) {
|
for (Map<int, VisualScriptNodeInstance *>::Element *E = instances.front(); E; E = E->next()) {
|
||||||
memdelete(E->get());
|
memdelete(E->get());
|
||||||
@ -2743,9 +2735,6 @@ VisualScriptLanguage::VisualScriptLanguage() {
|
|||||||
_step = "_step";
|
_step = "_step";
|
||||||
_subcall = "_subcall";
|
_subcall = "_subcall";
|
||||||
singleton = this;
|
singleton = this;
|
||||||
#ifndef NO_THREADS
|
|
||||||
lock = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_debug_parse_err_node = -1;
|
_debug_parse_err_node = -1;
|
||||||
_debug_parse_err_file = "";
|
_debug_parse_err_file = "";
|
||||||
@ -2766,9 +2755,6 @@ VisualScriptLanguage::VisualScriptLanguage() {
|
|||||||
|
|
||||||
VisualScriptLanguage::~VisualScriptLanguage() {
|
VisualScriptLanguage::~VisualScriptLanguage() {
|
||||||
|
|
||||||
if (lock)
|
|
||||||
memdelete(lock);
|
|
||||||
|
|
||||||
if (_call_stack) {
|
if (_call_stack) {
|
||||||
memdelete_arr(_call_stack);
|
memdelete_arr(_call_stack);
|
||||||
}
|
}
|
||||||
|
@ -507,7 +507,7 @@ public:
|
|||||||
|
|
||||||
static VisualScriptLanguage *singleton;
|
static VisualScriptLanguage *singleton;
|
||||||
|
|
||||||
Mutex *lock;
|
Mutex lock;
|
||||||
|
|
||||||
bool debug_break(const String &p_error, bool p_allow_continue = true);
|
bool debug_break(const String &p_error, bool p_allow_continue = true);
|
||||||
bool debug_break_parse(const String &p_file, int p_node, const String &p_error);
|
bool debug_break_parse(const String &p_file, int p_node, const String &p_error);
|
||||||
|
@ -48,7 +48,7 @@ int AudioDriverAndroid::mix_rate = 44100;
|
|||||||
bool AudioDriverAndroid::quit = false;
|
bool AudioDriverAndroid::quit = false;
|
||||||
jobject AudioDriverAndroid::audioBuffer = NULL;
|
jobject AudioDriverAndroid::audioBuffer = NULL;
|
||||||
void *AudioDriverAndroid::audioBufferPinned = NULL;
|
void *AudioDriverAndroid::audioBufferPinned = NULL;
|
||||||
Mutex *AudioDriverAndroid::mutex = NULL;
|
Mutex AudioDriverAndroid::mutex;
|
||||||
int32_t *AudioDriverAndroid::audioBuffer32 = NULL;
|
int32_t *AudioDriverAndroid::audioBuffer32 = NULL;
|
||||||
|
|
||||||
const char *AudioDriverAndroid::get_name() const {
|
const char *AudioDriverAndroid::get_name() const {
|
||||||
@ -58,7 +58,6 @@ const char *AudioDriverAndroid::get_name() const {
|
|||||||
|
|
||||||
Error AudioDriverAndroid::init() {
|
Error AudioDriverAndroid::init() {
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
/*
|
/*
|
||||||
// TODO: pass in/return a (Java) device ID, also whether we're opening for input or output
|
// TODO: pass in/return a (Java) device ID, also whether we're opening for input or output
|
||||||
this->spec.samples = Android_JNI_OpenAudioDevice(this->spec.freq, this->spec.format == AUDIO_U8 ? 0 : 1, this->spec.channels, this->spec.samples);
|
this->spec.samples = Android_JNI_OpenAudioDevice(this->spec.freq, this->spec.format == AUDIO_U8 ? 0 : 1, this->spec.channels, this->spec.samples);
|
||||||
@ -133,7 +132,7 @@ void AudioDriverAndroid::thread_func(JNIEnv *env) {
|
|||||||
int16_t *ptr = (int16_t *)audioBufferPinned;
|
int16_t *ptr = (int16_t *)audioBufferPinned;
|
||||||
int fc = audioBufferFrames;
|
int fc = audioBufferFrames;
|
||||||
|
|
||||||
if (!s_ad->active || mutex->try_lock() != OK) {
|
if (!s_ad->active || mutex.try_lock() != OK) {
|
||||||
|
|
||||||
for (int i = 0; i < fc; i++) {
|
for (int i = 0; i < fc; i++) {
|
||||||
ptr[i] = 0;
|
ptr[i] = 0;
|
||||||
@ -143,7 +142,7 @@ void AudioDriverAndroid::thread_func(JNIEnv *env) {
|
|||||||
|
|
||||||
s_ad->audio_server_process(fc / 2, audioBuffer32);
|
s_ad->audio_server_process(fc / 2, audioBuffer32);
|
||||||
|
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
|
|
||||||
for (int i = 0; i < fc; i++) {
|
for (int i = 0; i < fc; i++) {
|
||||||
|
|
||||||
@ -167,14 +166,12 @@ AudioDriver::SpeakerMode AudioDriverAndroid::get_speaker_mode() const {
|
|||||||
|
|
||||||
void AudioDriverAndroid::lock() {
|
void AudioDriverAndroid::lock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverAndroid::unlock() {
|
void AudioDriverAndroid::unlock() {
|
||||||
|
|
||||||
if (mutex)
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverAndroid::finish() {
|
void AudioDriverAndroid::finish() {
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
class AudioDriverAndroid : public AudioDriver {
|
class AudioDriverAndroid : public AudioDriver {
|
||||||
|
|
||||||
static Mutex *mutex;
|
static Mutex mutex;
|
||||||
static AudioDriverAndroid *s_ad;
|
static AudioDriverAndroid *s_ad;
|
||||||
static jobject io;
|
static jobject io;
|
||||||
static jmethodID _init_audio;
|
static jmethodID _init_audio;
|
||||||
|
@ -44,8 +44,8 @@ void AudioDriverOpenSL::_buffer_callback(
|
|||||||
|
|
||||||
if (pause) {
|
if (pause) {
|
||||||
mix = false;
|
mix = false;
|
||||||
} else if (mutex) {
|
} else {
|
||||||
mix = mutex->try_lock() == OK;
|
mix = mutex.try_lock() == OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mix) {
|
if (mix) {
|
||||||
@ -58,8 +58,8 @@ void AudioDriverOpenSL::_buffer_callback(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mutex && mix)
|
if (mix)
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
|
|
||||||
const int32_t *src_buff = mixdown_buffer;
|
const int32_t *src_buff = mixdown_buffer;
|
||||||
|
|
||||||
@ -107,7 +107,6 @@ Error AudioDriverOpenSL::init() {
|
|||||||
|
|
||||||
void AudioDriverOpenSL::start() {
|
void AudioDriverOpenSL::start() {
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
active = false;
|
active = false;
|
||||||
|
|
||||||
SLresult res;
|
SLresult res;
|
||||||
@ -329,14 +328,14 @@ AudioDriver::SpeakerMode AudioDriverOpenSL::get_speaker_mode() const {
|
|||||||
|
|
||||||
void AudioDriverOpenSL::lock() {
|
void AudioDriverOpenSL::lock() {
|
||||||
|
|
||||||
if (active && mutex)
|
if (active)
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverOpenSL::unlock() {
|
void AudioDriverOpenSL::unlock() {
|
||||||
|
|
||||||
if (active && mutex)
|
if (active)
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverOpenSL::finish() {
|
void AudioDriverOpenSL::finish() {
|
||||||
@ -359,7 +358,6 @@ void AudioDriverOpenSL::set_pause(bool p_pause) {
|
|||||||
|
|
||||||
AudioDriverOpenSL::AudioDriverOpenSL() {
|
AudioDriverOpenSL::AudioDriverOpenSL() {
|
||||||
s_ad = this;
|
s_ad = this;
|
||||||
mutex = Mutex::create(); //NULL;
|
|
||||||
pause = false;
|
pause = false;
|
||||||
active = false;
|
active = false;
|
||||||
}
|
}
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
class AudioDriverOpenSL : public AudioDriver {
|
class AudioDriverOpenSL : public AudioDriver {
|
||||||
|
|
||||||
bool active;
|
bool active;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
|
||||||
|
@ -268,10 +268,10 @@ class EditorExportPlatformAndroid : public EditorExportPlatform {
|
|||||||
String last_plugin_names;
|
String last_plugin_names;
|
||||||
uint64_t last_custom_build_time = 0;
|
uint64_t last_custom_build_time = 0;
|
||||||
volatile bool plugins_changed;
|
volatile bool plugins_changed;
|
||||||
Mutex *plugins_lock;
|
Mutex plugins_lock;
|
||||||
Vector<Device> devices;
|
Vector<Device> devices;
|
||||||
volatile bool devices_changed;
|
volatile bool devices_changed;
|
||||||
Mutex *device_lock;
|
Mutex device_lock;
|
||||||
Thread *check_for_changes_thread;
|
Thread *check_for_changes_thread;
|
||||||
volatile bool quit_request;
|
volatile bool quit_request;
|
||||||
|
|
||||||
@ -285,7 +285,7 @@ class EditorExportPlatformAndroid : public EditorExportPlatform {
|
|||||||
if (!ea->plugins_changed) {
|
if (!ea->plugins_changed) {
|
||||||
Vector<PluginConfigAndroid> loaded_plugins = get_plugins();
|
Vector<PluginConfigAndroid> loaded_plugins = get_plugins();
|
||||||
|
|
||||||
ea->plugins_lock->lock();
|
ea->plugins_lock.lock();
|
||||||
|
|
||||||
if (ea->plugins.size() != loaded_plugins.size()) {
|
if (ea->plugins.size() != loaded_plugins.size()) {
|
||||||
ea->plugins_changed = true;
|
ea->plugins_changed = true;
|
||||||
@ -302,7 +302,7 @@ class EditorExportPlatformAndroid : public EditorExportPlatform {
|
|||||||
ea->plugins = loaded_plugins;
|
ea->plugins = loaded_plugins;
|
||||||
}
|
}
|
||||||
|
|
||||||
ea->plugins_lock->unlock();
|
ea->plugins_lock.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -328,7 +328,7 @@ class EditorExportPlatformAndroid : public EditorExportPlatform {
|
|||||||
ldevices.push_back(d);
|
ldevices.push_back(d);
|
||||||
}
|
}
|
||||||
|
|
||||||
ea->device_lock->lock();
|
ea->device_lock.lock();
|
||||||
|
|
||||||
bool different = false;
|
bool different = false;
|
||||||
|
|
||||||
@ -418,7 +418,7 @@ class EditorExportPlatformAndroid : public EditorExportPlatform {
|
|||||||
ea->devices_changed = true;
|
ea->devices_changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
ea->device_lock->unlock();
|
ea->device_lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t sleep = OS::get_singleton()->get_power_state() == OS::POWERSTATE_ON_BATTERY ? 1000 : 100;
|
uint64_t sleep = OS::get_singleton()->get_power_state() == OS::POWERSTATE_ON_BATTERY ? 1000 : 100;
|
||||||
@ -1770,9 +1770,9 @@ public:
|
|||||||
|
|
||||||
virtual int get_options_count() const {
|
virtual int get_options_count() const {
|
||||||
|
|
||||||
device_lock->lock();
|
device_lock.lock();
|
||||||
int dc = devices.size();
|
int dc = devices.size();
|
||||||
device_lock->unlock();
|
device_lock.unlock();
|
||||||
|
|
||||||
return dc;
|
return dc;
|
||||||
}
|
}
|
||||||
@ -1785,16 +1785,16 @@ public:
|
|||||||
virtual String get_option_label(int p_index) const {
|
virtual String get_option_label(int p_index) const {
|
||||||
|
|
||||||
ERR_FAIL_INDEX_V(p_index, devices.size(), "");
|
ERR_FAIL_INDEX_V(p_index, devices.size(), "");
|
||||||
device_lock->lock();
|
device_lock.lock();
|
||||||
String s = devices[p_index].name;
|
String s = devices[p_index].name;
|
||||||
device_lock->unlock();
|
device_lock.unlock();
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual String get_option_tooltip(int p_index) const {
|
virtual String get_option_tooltip(int p_index) const {
|
||||||
|
|
||||||
ERR_FAIL_INDEX_V(p_index, devices.size(), "");
|
ERR_FAIL_INDEX_V(p_index, devices.size(), "");
|
||||||
device_lock->lock();
|
device_lock.lock();
|
||||||
String s = devices[p_index].description;
|
String s = devices[p_index].description;
|
||||||
if (devices.size() == 1) {
|
if (devices.size() == 1) {
|
||||||
// Tooltip will be:
|
// Tooltip will be:
|
||||||
@ -1802,7 +1802,7 @@ public:
|
|||||||
// Description
|
// Description
|
||||||
s = devices[p_index].name + "\n\n" + s;
|
s = devices[p_index].name + "\n\n" + s;
|
||||||
}
|
}
|
||||||
device_lock->unlock();
|
device_lock.unlock();
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1817,7 +1817,7 @@ public:
|
|||||||
return ERR_UNCONFIGURED;
|
return ERR_UNCONFIGURED;
|
||||||
}
|
}
|
||||||
|
|
||||||
device_lock->lock();
|
device_lock.lock();
|
||||||
|
|
||||||
EditorProgress ep("run", "Running on " + devices[p_device].name, 3);
|
EditorProgress ep("run", "Running on " + devices[p_device].name, 3);
|
||||||
|
|
||||||
@ -1825,7 +1825,7 @@ public:
|
|||||||
|
|
||||||
// Export_temp APK.
|
// Export_temp APK.
|
||||||
if (ep.step("Exporting APK...", 0)) {
|
if (ep.step("Exporting APK...", 0)) {
|
||||||
device_lock->unlock();
|
device_lock.unlock();
|
||||||
return ERR_SKIP;
|
return ERR_SKIP;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1840,7 +1840,7 @@ public:
|
|||||||
#define CLEANUP_AND_RETURN(m_err) \
|
#define CLEANUP_AND_RETURN(m_err) \
|
||||||
{ \
|
{ \
|
||||||
DirAccess::remove_file_or_error(tmp_export_path); \
|
DirAccess::remove_file_or_error(tmp_export_path); \
|
||||||
device_lock->unlock(); \
|
device_lock.unlock(); \
|
||||||
return m_err; \
|
return m_err; \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3280,10 +3280,8 @@ public:
|
|||||||
run_icon.instance();
|
run_icon.instance();
|
||||||
run_icon->create_from_image(img);
|
run_icon->create_from_image(img);
|
||||||
|
|
||||||
device_lock = Mutex::create();
|
|
||||||
devices_changed = true;
|
devices_changed = true;
|
||||||
|
|
||||||
plugins_lock = Mutex::create();
|
|
||||||
plugins_changed = true;
|
plugins_changed = true;
|
||||||
quit_request = false;
|
quit_request = false;
|
||||||
check_for_changes_thread = Thread::create(_check_for_changes_poll_thread, this);
|
check_for_changes_thread = Thread::create(_check_for_changes_poll_thread, this);
|
||||||
@ -3292,8 +3290,6 @@ public:
|
|||||||
~EditorExportPlatformAndroid() {
|
~EditorExportPlatformAndroid() {
|
||||||
quit_request = true;
|
quit_request = true;
|
||||||
Thread::wait_to_finish(check_for_changes_thread);
|
Thread::wait_to_finish(check_for_changes_thread);
|
||||||
memdelete(plugins_lock);
|
|
||||||
memdelete(device_lock);
|
|
||||||
memdelete(check_for_changes_thread);
|
memdelete(check_for_changes_thread);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -58,7 +58,7 @@ class EditorExportPlatformIOS : public EditorExportPlatform {
|
|||||||
volatile bool plugins_changed;
|
volatile bool plugins_changed;
|
||||||
Thread *check_for_changes_thread;
|
Thread *check_for_changes_thread;
|
||||||
volatile bool quit_request;
|
volatile bool quit_request;
|
||||||
Mutex *plugins_lock;
|
Mutex plugins_lock;
|
||||||
Vector<PluginConfigIOS> plugins;
|
Vector<PluginConfigIOS> plugins;
|
||||||
|
|
||||||
typedef Error (*FileHandler)(String p_file, void *p_userdata);
|
typedef Error (*FileHandler)(String p_file, void *p_userdata);
|
||||||
@ -148,7 +148,7 @@ class EditorExportPlatformIOS : public EditorExportPlatform {
|
|||||||
// Nothing to do if we already know the plugins have changed.
|
// Nothing to do if we already know the plugins have changed.
|
||||||
if (!ea->plugins_changed) {
|
if (!ea->plugins_changed) {
|
||||||
|
|
||||||
ea->plugins_lock->lock();
|
ea->plugins_lock.lock();
|
||||||
|
|
||||||
Vector<PluginConfigIOS> loaded_plugins = get_plugins();
|
Vector<PluginConfigIOS> loaded_plugins = get_plugins();
|
||||||
|
|
||||||
@ -163,7 +163,7 @@ class EditorExportPlatformIOS : public EditorExportPlatform {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ea->plugins_lock->unlock();
|
ea->plugins_lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t wait = 3000000;
|
uint64_t wait = 3000000;
|
||||||
@ -1838,7 +1838,6 @@ EditorExportPlatformIOS::EditorExportPlatformIOS() {
|
|||||||
|
|
||||||
plugins_changed = true;
|
plugins_changed = true;
|
||||||
quit_request = false;
|
quit_request = false;
|
||||||
plugins_lock = Mutex::create();
|
|
||||||
|
|
||||||
check_for_changes_thread = Thread::create(_check_for_changes_poll_thread, this);
|
check_for_changes_thread = Thread::create(_check_for_changes_poll_thread, this);
|
||||||
}
|
}
|
||||||
@ -1846,7 +1845,6 @@ EditorExportPlatformIOS::EditorExportPlatformIOS() {
|
|||||||
EditorExportPlatformIOS::~EditorExportPlatformIOS() {
|
EditorExportPlatformIOS::~EditorExportPlatformIOS() {
|
||||||
quit_request = true;
|
quit_request = true;
|
||||||
Thread::wait_to_finish(check_for_changes_thread);
|
Thread::wait_to_finish(check_for_changes_thread);
|
||||||
memdelete(plugins_lock);
|
|
||||||
memdelete(check_for_changes_thread);
|
memdelete(check_for_changes_thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,20 +267,15 @@ int AudioDriverJavaScript::WorkletNode::create(int p_buffer_size, int p_channels
|
|||||||
|
|
||||||
void AudioDriverJavaScript::WorkletNode::start(float *p_out_buf, int p_out_buf_size, float *p_in_buf, int p_in_buf_size) {
|
void AudioDriverJavaScript::WorkletNode::start(float *p_out_buf, int p_out_buf_size, float *p_in_buf, int p_in_buf_size) {
|
||||||
godot_audio_worklet_start(p_in_buf, p_in_buf_size, p_out_buf, p_out_buf_size, state);
|
godot_audio_worklet_start(p_in_buf, p_in_buf_size, p_out_buf, p_out_buf_size, state);
|
||||||
mutex = Mutex::create();
|
|
||||||
thread = Thread::create(_audio_thread_func, this);
|
thread = Thread::create(_audio_thread_func, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverJavaScript::WorkletNode::lock() {
|
void AudioDriverJavaScript::WorkletNode::lock() {
|
||||||
if (mutex) {
|
mutex.lock();
|
||||||
mutex->lock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverJavaScript::WorkletNode::unlock() {
|
void AudioDriverJavaScript::WorkletNode::unlock() {
|
||||||
if (mutex) {
|
mutex.unlock();
|
||||||
mutex->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioDriverJavaScript::WorkletNode::finish() {
|
void AudioDriverJavaScript::WorkletNode::finish() {
|
||||||
@ -288,7 +283,5 @@ void AudioDriverJavaScript::WorkletNode::finish() {
|
|||||||
Thread::wait_to_finish(thread);
|
Thread::wait_to_finish(thread);
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
thread = nullptr;
|
thread = nullptr;
|
||||||
memdelete(mutex);
|
|
||||||
mutex = nullptr;
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -58,7 +58,7 @@ public:
|
|||||||
STATE_SAMPLES_OUT,
|
STATE_SAMPLES_OUT,
|
||||||
STATE_MAX,
|
STATE_MAX,
|
||||||
};
|
};
|
||||||
Mutex *mutex = nullptr;
|
Mutex mutex;
|
||||||
Thread *thread = nullptr;
|
Thread *thread = nullptr;
|
||||||
bool quit = false;
|
bool quit = false;
|
||||||
int32_t state[STATE_MAX] = { 0 };
|
int32_t state[STATE_MAX] = { 0 };
|
||||||
|
@ -212,7 +212,7 @@ class EditorExportPlatformJavaScript : public EditorExportPlatform {
|
|||||||
|
|
||||||
Ref<EditorHTTPServer> server;
|
Ref<EditorHTTPServer> server;
|
||||||
bool server_quit = false;
|
bool server_quit = false;
|
||||||
Mutex *server_lock = NULL;
|
Mutex server_lock;
|
||||||
Thread *server_thread = NULL;
|
Thread *server_thread = NULL;
|
||||||
|
|
||||||
enum ExportMode {
|
enum ExportMode {
|
||||||
@ -610,9 +610,9 @@ bool EditorExportPlatformJavaScript::poll_export() {
|
|||||||
menu_options = preset.is_valid();
|
menu_options = preset.is_valid();
|
||||||
if (server->is_listening()) {
|
if (server->is_listening()) {
|
||||||
if (menu_options == 0) {
|
if (menu_options == 0) {
|
||||||
server_lock->lock();
|
server_lock.lock();
|
||||||
server->stop();
|
server->stop();
|
||||||
server_lock->unlock();
|
server_lock.unlock();
|
||||||
} else {
|
} else {
|
||||||
menu_options += 1;
|
menu_options += 1;
|
||||||
}
|
}
|
||||||
@ -632,9 +632,9 @@ int EditorExportPlatformJavaScript::get_options_count() const {
|
|||||||
Error EditorExportPlatformJavaScript::run(const Ref<EditorExportPreset> &p_preset, int p_option, int p_debug_flags) {
|
Error EditorExportPlatformJavaScript::run(const Ref<EditorExportPreset> &p_preset, int p_option, int p_debug_flags) {
|
||||||
|
|
||||||
if (p_option == 1) {
|
if (p_option == 1) {
|
||||||
server_lock->lock();
|
server_lock.lock();
|
||||||
server->stop();
|
server->stop();
|
||||||
server_lock->unlock();
|
server_lock.unlock();
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -666,10 +666,10 @@ Error EditorExportPlatformJavaScript::run(const Ref<EditorExportPreset> &p_prese
|
|||||||
ERR_FAIL_COND_V_MSG(!bind_ip.is_valid(), ERR_INVALID_PARAMETER, "Invalid editor setting 'export/web/http_host': '" + bind_host + "'. Try using '127.0.0.1'.");
|
ERR_FAIL_COND_V_MSG(!bind_ip.is_valid(), ERR_INVALID_PARAMETER, "Invalid editor setting 'export/web/http_host': '" + bind_host + "'. Try using '127.0.0.1'.");
|
||||||
|
|
||||||
// Restart server.
|
// Restart server.
|
||||||
server_lock->lock();
|
server_lock.lock();
|
||||||
server->stop();
|
server->stop();
|
||||||
err = server->listen(bind_port, bind_ip);
|
err = server->listen(bind_port, bind_ip);
|
||||||
server_lock->unlock();
|
server_lock.unlock();
|
||||||
ERR_FAIL_COND_V_MSG(err != OK, err, "Unable to start HTTP server.");
|
ERR_FAIL_COND_V_MSG(err != OK, err, "Unable to start HTTP server.");
|
||||||
|
|
||||||
OS::get_singleton()->shell_open(String("http://" + bind_host + ":" + itos(bind_port) + "/tmp_js_export.html"));
|
OS::get_singleton()->shell_open(String("http://" + bind_host + ":" + itos(bind_port) + "/tmp_js_export.html"));
|
||||||
@ -687,16 +687,15 @@ void EditorExportPlatformJavaScript::_server_thread_poll(void *data) {
|
|||||||
EditorExportPlatformJavaScript *ej = (EditorExportPlatformJavaScript *)data;
|
EditorExportPlatformJavaScript *ej = (EditorExportPlatformJavaScript *)data;
|
||||||
while (!ej->server_quit) {
|
while (!ej->server_quit) {
|
||||||
OS::get_singleton()->delay_usec(1000);
|
OS::get_singleton()->delay_usec(1000);
|
||||||
ej->server_lock->lock();
|
ej->server_lock.lock();
|
||||||
ej->server->poll();
|
ej->server->poll();
|
||||||
ej->server_lock->unlock();
|
ej->server_lock.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EditorExportPlatformJavaScript::EditorExportPlatformJavaScript() {
|
EditorExportPlatformJavaScript::EditorExportPlatformJavaScript() {
|
||||||
|
|
||||||
server.instance();
|
server.instance();
|
||||||
server_lock = Mutex::create();
|
|
||||||
server_thread = Thread::create(_server_thread_poll, this);
|
server_thread = Thread::create(_server_thread_poll, this);
|
||||||
|
|
||||||
Ref<Image> img = memnew(Image(_javascript_logo));
|
Ref<Image> img = memnew(Image(_javascript_logo));
|
||||||
@ -718,7 +717,6 @@ EditorExportPlatformJavaScript::~EditorExportPlatformJavaScript() {
|
|||||||
server->stop();
|
server->stop();
|
||||||
server_quit = true;
|
server_quit = true;
|
||||||
Thread::wait_to_finish(server_thread);
|
Thread::wait_to_finish(server_thread);
|
||||||
memdelete(server_lock);
|
|
||||||
memdelete(server_thread);
|
memdelete(server_thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,7 +40,6 @@
|
|||||||
#include "drivers/unix/ip_unix.h"
|
#include "drivers/unix/ip_unix.h"
|
||||||
#include "drivers/windows/dir_access_windows.h"
|
#include "drivers/windows/dir_access_windows.h"
|
||||||
#include "drivers/windows/file_access_windows.h"
|
#include "drivers/windows/file_access_windows.h"
|
||||||
#include "drivers/windows/mutex_windows.h"
|
|
||||||
#include "drivers/windows/semaphore_windows.h"
|
#include "drivers/windows/semaphore_windows.h"
|
||||||
#include "main/main.h"
|
#include "main/main.h"
|
||||||
#include "platform/windows/windows_terminal_logger.h"
|
#include "platform/windows/windows_terminal_logger.h"
|
||||||
@ -141,7 +140,6 @@ void OS_UWP::initialize_core() {
|
|||||||
|
|
||||||
ThreadUWP::make_default();
|
ThreadUWP::make_default();
|
||||||
SemaphoreWindows::make_default();
|
SemaphoreWindows::make_default();
|
||||||
MutexWindows::make_default();
|
|
||||||
|
|
||||||
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_RESOURCES);
|
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_RESOURCES);
|
||||||
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_USERDATA);
|
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_USERDATA);
|
||||||
|
@ -40,7 +40,6 @@
|
|||||||
#include "drivers/gles3/rasterizer_gles3.h"
|
#include "drivers/gles3/rasterizer_gles3.h"
|
||||||
#include "drivers/windows/dir_access_windows.h"
|
#include "drivers/windows/dir_access_windows.h"
|
||||||
#include "drivers/windows/file_access_windows.h"
|
#include "drivers/windows/file_access_windows.h"
|
||||||
#include "drivers/windows/mutex_windows.h"
|
|
||||||
#include "drivers/windows/semaphore_windows.h"
|
#include "drivers/windows/semaphore_windows.h"
|
||||||
#include "drivers/windows/thread_windows.h"
|
#include "drivers/windows/thread_windows.h"
|
||||||
#include "joypad_windows.h"
|
#include "joypad_windows.h"
|
||||||
@ -228,7 +227,6 @@ void OS_Windows::initialize_core() {
|
|||||||
|
|
||||||
ThreadWindows::make_default();
|
ThreadWindows::make_default();
|
||||||
SemaphoreWindows::make_default();
|
SemaphoreWindows::make_default();
|
||||||
MutexWindows::make_default();
|
|
||||||
|
|
||||||
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_RESOURCES);
|
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_RESOURCES);
|
||||||
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_USERDATA);
|
FileAccess::make_default<FileAccessWindows>(FileAccess::ACCESS_USERDATA);
|
||||||
|
@ -94,7 +94,6 @@ JoypadLinux::JoypadLinux(InputDefault *in) {
|
|||||||
#endif
|
#endif
|
||||||
exit_monitor = false;
|
exit_monitor = false;
|
||||||
input = in;
|
input = in;
|
||||||
joy_mutex = Mutex::create();
|
|
||||||
joy_thread = Thread::create(joy_thread_func, this);
|
joy_thread = Thread::create(joy_thread_func, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,7 +101,6 @@ JoypadLinux::~JoypadLinux() {
|
|||||||
exit_monitor = true;
|
exit_monitor = true;
|
||||||
Thread::wait_to_finish(joy_thread);
|
Thread::wait_to_finish(joy_thread);
|
||||||
memdelete(joy_thread);
|
memdelete(joy_thread);
|
||||||
memdelete(joy_mutex);
|
|
||||||
close_joypad();
|
close_joypad();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,9 +155,9 @@ void JoypadLinux::enumerate_joypads(udev *p_udev) {
|
|||||||
|
|
||||||
String devnode_str = devnode;
|
String devnode_str = devnode;
|
||||||
if (devnode_str.find(ignore_str) == -1) {
|
if (devnode_str.find(ignore_str) == -1) {
|
||||||
joy_mutex->lock();
|
joy_mutex.lock();
|
||||||
open_joypad(devnode);
|
open_joypad(devnode);
|
||||||
joy_mutex->unlock();
|
joy_mutex.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
udev_device_unref(dev);
|
udev_device_unref(dev);
|
||||||
@ -196,7 +194,7 @@ void JoypadLinux::monitor_joypads(udev *p_udev) {
|
|||||||
|
|
||||||
if (dev && udev_device_get_devnode(dev) != 0) {
|
if (dev && udev_device_get_devnode(dev) != 0) {
|
||||||
|
|
||||||
joy_mutex->lock();
|
joy_mutex.lock();
|
||||||
String action = udev_device_get_action(dev);
|
String action = udev_device_get_action(dev);
|
||||||
const char *devnode = udev_device_get_devnode(dev);
|
const char *devnode = udev_device_get_devnode(dev);
|
||||||
if (devnode) {
|
if (devnode) {
|
||||||
@ -212,7 +210,7 @@ void JoypadLinux::monitor_joypads(udev *p_udev) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
udev_device_unref(dev);
|
udev_device_unref(dev);
|
||||||
joy_mutex->unlock();
|
joy_mutex.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
usleep(50000);
|
usleep(50000);
|
||||||
@ -224,7 +222,7 @@ void JoypadLinux::monitor_joypads(udev *p_udev) {
|
|||||||
void JoypadLinux::monitor_joypads() {
|
void JoypadLinux::monitor_joypads() {
|
||||||
|
|
||||||
while (!exit_monitor) {
|
while (!exit_monitor) {
|
||||||
joy_mutex->lock();
|
joy_mutex.lock();
|
||||||
|
|
||||||
DIR *input_directory;
|
DIR *input_directory;
|
||||||
input_directory = opendir("/dev/input");
|
input_directory = opendir("/dev/input");
|
||||||
@ -243,7 +241,7 @@ void JoypadLinux::monitor_joypads() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
closedir(input_directory);
|
closedir(input_directory);
|
||||||
joy_mutex->unlock();
|
joy_mutex.unlock();
|
||||||
usleep(1000000); // 1s
|
usleep(1000000); // 1s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -491,7 +489,7 @@ InputDefault::JoyAxis JoypadLinux::axis_correct(const input_absinfo *p_abs, int
|
|||||||
|
|
||||||
void JoypadLinux::process_joypads() {
|
void JoypadLinux::process_joypads() {
|
||||||
|
|
||||||
if (joy_mutex->try_lock() != OK) {
|
if (joy_mutex.try_lock() != OK) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
for (int i = 0; i < JOYPADS_MAX; i++) {
|
for (int i = 0; i < JOYPADS_MAX; i++) {
|
||||||
@ -586,6 +584,6 @@ void JoypadLinux::process_joypads() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
joy_mutex->unlock();
|
joy_mutex.unlock();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -75,7 +75,7 @@ private:
|
|||||||
bool use_udev;
|
bool use_udev;
|
||||||
#endif
|
#endif
|
||||||
bool exit_monitor;
|
bool exit_monitor;
|
||||||
Mutex *joy_mutex;
|
Mutex joy_mutex;
|
||||||
Thread *joy_thread;
|
Thread *joy_thread;
|
||||||
InputDefault *input;
|
InputDefault *input;
|
||||||
Joypad joypads[JOYPADS_MAX];
|
Joypad joypads[JOYPADS_MAX];
|
||||||
|
@ -122,8 +122,6 @@ Error OS_X11::initialize(const VideoMode &p_desired, int p_video_driver, int p_a
|
|||||||
|
|
||||||
XInitThreads();
|
XInitThreads();
|
||||||
|
|
||||||
events_mutex = Mutex::create();
|
|
||||||
|
|
||||||
/** XLIB INITIALIZATION **/
|
/** XLIB INITIALIZATION **/
|
||||||
x11_display = XOpenDisplay(NULL);
|
x11_display = XOpenDisplay(NULL);
|
||||||
|
|
||||||
@ -879,8 +877,6 @@ void OS_X11::finalize() {
|
|||||||
if (xmbstring)
|
if (xmbstring)
|
||||||
memfree(xmbstring);
|
memfree(xmbstring);
|
||||||
|
|
||||||
memdelete(events_mutex);
|
|
||||||
|
|
||||||
args.clear();
|
args.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ class OS_X11 : public OS_Unix {
|
|||||||
String _get_clipboard(Atom p_source, Window x11_window) const;
|
String _get_clipboard(Atom p_source, Window x11_window) const;
|
||||||
void _clipboard_transfer_ownership(Atom p_source, Window x11_window) const;
|
void _clipboard_transfer_ownership(Atom p_source, Window x11_window) const;
|
||||||
|
|
||||||
mutable Mutex *events_mutex;
|
mutable Mutex events_mutex;
|
||||||
Thread *events_thread = nullptr;
|
Thread *events_thread = nullptr;
|
||||||
bool events_thread_done = false;
|
bool events_thread_done = false;
|
||||||
LocalVector<XEvent> polled_events;
|
LocalVector<XEvent> polled_events;
|
||||||
|
@ -41,17 +41,13 @@
|
|||||||
#include "servers/visual/visual_server_raster.h"
|
#include "servers/visual/visual_server_raster.h"
|
||||||
#include "servers/visual_server.h"
|
#include "servers/visual_server.h"
|
||||||
|
|
||||||
Mutex *CanvasItemMaterial::material_mutex = NULL;
|
Mutex CanvasItemMaterial::material_mutex;
|
||||||
SelfList<CanvasItemMaterial>::List *CanvasItemMaterial::dirty_materials = NULL;
|
SelfList<CanvasItemMaterial>::List *CanvasItemMaterial::dirty_materials = NULL;
|
||||||
Map<CanvasItemMaterial::MaterialKey, CanvasItemMaterial::ShaderData> CanvasItemMaterial::shader_map;
|
Map<CanvasItemMaterial::MaterialKey, CanvasItemMaterial::ShaderData> CanvasItemMaterial::shader_map;
|
||||||
CanvasItemMaterial::ShaderNames *CanvasItemMaterial::shader_names = NULL;
|
CanvasItemMaterial::ShaderNames *CanvasItemMaterial::shader_names = NULL;
|
||||||
|
|
||||||
void CanvasItemMaterial::init_shaders() {
|
void CanvasItemMaterial::init_shaders() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
material_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
dirty_materials = memnew(SelfList<CanvasItemMaterial>::List);
|
dirty_materials = memnew(SelfList<CanvasItemMaterial>::List);
|
||||||
|
|
||||||
shader_names = memnew(ShaderNames);
|
shader_names = memnew(ShaderNames);
|
||||||
@ -66,10 +62,6 @@ void CanvasItemMaterial::finish_shaders() {
|
|||||||
memdelete(dirty_materials);
|
memdelete(dirty_materials);
|
||||||
memdelete(shader_names);
|
memdelete(shader_names);
|
||||||
dirty_materials = NULL;
|
dirty_materials = NULL;
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(material_mutex);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CanvasItemMaterial::_update_shader() {
|
void CanvasItemMaterial::_update_shader() {
|
||||||
@ -156,42 +148,36 @@ void CanvasItemMaterial::_update_shader() {
|
|||||||
|
|
||||||
void CanvasItemMaterial::flush_changes() {
|
void CanvasItemMaterial::flush_changes() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
while (dirty_materials->first()) {
|
while (dirty_materials->first()) {
|
||||||
|
|
||||||
dirty_materials->first()->self()->_update_shader();
|
dirty_materials->first()->self()->_update_shader();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CanvasItemMaterial::_queue_shader_change() {
|
void CanvasItemMaterial::_queue_shader_change() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (!element.in_list()) {
|
if (!element.in_list()) {
|
||||||
dirty_materials->add(&element);
|
dirty_materials->add(&element);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CanvasItemMaterial::_is_shader_dirty() const {
|
bool CanvasItemMaterial::_is_shader_dirty() const {
|
||||||
|
|
||||||
bool dirty = false;
|
bool dirty = false;
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
dirty = element.in_list();
|
dirty = element.in_list();
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
|
|
||||||
return dirty;
|
return dirty;
|
||||||
}
|
}
|
||||||
@ -332,8 +318,7 @@ CanvasItemMaterial::CanvasItemMaterial() :
|
|||||||
|
|
||||||
CanvasItemMaterial::~CanvasItemMaterial() {
|
CanvasItemMaterial::~CanvasItemMaterial() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (shader_map.has(current_key)) {
|
if (shader_map.has(current_key)) {
|
||||||
shader_map[current_key].users--;
|
shader_map[current_key].users--;
|
||||||
@ -346,8 +331,7 @@ CanvasItemMaterial::~CanvasItemMaterial() {
|
|||||||
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////
|
||||||
|
@ -108,7 +108,7 @@ private:
|
|||||||
return mk;
|
return mk;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Mutex *material_mutex;
|
static Mutex material_mutex;
|
||||||
static SelfList<CanvasItemMaterial>::List *dirty_materials;
|
static SelfList<CanvasItemMaterial>::List *dirty_materials;
|
||||||
SelfList<CanvasItemMaterial> element;
|
SelfList<CanvasItemMaterial> element;
|
||||||
|
|
||||||
|
@ -980,9 +980,7 @@ void CPUParticles2D::_particles_process(float p_delta) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles2D::_update_particle_data_buffer() {
|
void CPUParticles2D::_update_particle_data_buffer() {
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -1050,18 +1048,14 @@ void CPUParticles2D::_update_particle_data_buffer() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
update_mutex.unlock();
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles2D::_set_redraw(bool p_redraw) {
|
void CPUParticles2D::_set_redraw(bool p_redraw) {
|
||||||
if (redraw == p_redraw)
|
if (redraw == p_redraw)
|
||||||
return;
|
return;
|
||||||
redraw = p_redraw;
|
redraw = p_redraw;
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
if (redraw) {
|
if (redraw) {
|
||||||
VS::get_singleton()->connect("frame_pre_draw", this, "_update_render_thread");
|
VS::get_singleton()->connect("frame_pre_draw", this, "_update_render_thread");
|
||||||
VS::get_singleton()->canvas_item_set_update_when_visible(get_canvas_item(), true);
|
VS::get_singleton()->canvas_item_set_update_when_visible(get_canvas_item(), true);
|
||||||
@ -1075,23 +1069,15 @@ void CPUParticles2D::_set_redraw(bool p_redraw) {
|
|||||||
|
|
||||||
VS::get_singleton()->multimesh_set_visible_instances(multimesh, 0);
|
VS::get_singleton()->multimesh_set_visible_instances(multimesh, 0);
|
||||||
}
|
}
|
||||||
#ifndef NO_THREADS
|
update_mutex.unlock();
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
update(); // redraw to update render list
|
update(); // redraw to update render list
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles2D::_update_render_thread() {
|
void CPUParticles2D::_update_render_thread() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
VS::get_singleton()->multimesh_set_as_bulk_array(multimesh, particle_data);
|
VS::get_singleton()->multimesh_set_as_bulk_array(multimesh, particle_data);
|
||||||
|
update_mutex.unlock();
|
||||||
#ifndef NO_THREADS
|
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles2D::_notification(int p_what) {
|
void CPUParticles2D::_notification(int p_what) {
|
||||||
@ -1504,18 +1490,10 @@ CPUParticles2D::CPUParticles2D() {
|
|||||||
|
|
||||||
set_color(Color(1, 1, 1, 1));
|
set_color(Color(1, 1, 1, 1));
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
update_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
_update_mesh_texture();
|
_update_mesh_texture();
|
||||||
}
|
}
|
||||||
|
|
||||||
CPUParticles2D::~CPUParticles2D() {
|
CPUParticles2D::~CPUParticles2D() {
|
||||||
VS::get_singleton()->free(multimesh);
|
VS::get_singleton()->free(multimesh);
|
||||||
VS::get_singleton()->free(mesh);
|
VS::get_singleton()->free(mesh);
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(update_mutex);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
@ -180,7 +180,7 @@ private:
|
|||||||
void _particles_process(float p_delta);
|
void _particles_process(float p_delta);
|
||||||
void _update_particle_data_buffer();
|
void _update_particle_data_buffer();
|
||||||
|
|
||||||
Mutex *update_mutex;
|
Mutex update_mutex;
|
||||||
|
|
||||||
void _update_render_thread();
|
void _update_render_thread();
|
||||||
|
|
||||||
|
@ -1024,9 +1024,7 @@ void CPUParticles::_particles_process(float p_delta) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles::_update_particle_data_buffer() {
|
void CPUParticles::_update_particle_data_buffer() {
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -1118,18 +1116,14 @@ void CPUParticles::_update_particle_data_buffer() {
|
|||||||
can_update = true;
|
can_update = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
update_mutex.unlock();
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles::_set_redraw(bool p_redraw) {
|
void CPUParticles::_set_redraw(bool p_redraw) {
|
||||||
if (redraw == p_redraw)
|
if (redraw == p_redraw)
|
||||||
return;
|
return;
|
||||||
redraw = p_redraw;
|
redraw = p_redraw;
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
if (redraw) {
|
if (redraw) {
|
||||||
VS::get_singleton()->connect("frame_pre_draw", this, "_update_render_thread");
|
VS::get_singleton()->connect("frame_pre_draw", this, "_update_render_thread");
|
||||||
VS::get_singleton()->instance_geometry_set_flag(get_instance(), VS::INSTANCE_FLAG_DRAW_NEXT_FRAME_IF_VISIBLE, true);
|
VS::get_singleton()->instance_geometry_set_flag(get_instance(), VS::INSTANCE_FLAG_DRAW_NEXT_FRAME_IF_VISIBLE, true);
|
||||||
@ -1141,24 +1135,19 @@ void CPUParticles::_set_redraw(bool p_redraw) {
|
|||||||
VS::get_singleton()->instance_geometry_set_flag(get_instance(), VS::INSTANCE_FLAG_DRAW_NEXT_FRAME_IF_VISIBLE, false);
|
VS::get_singleton()->instance_geometry_set_flag(get_instance(), VS::INSTANCE_FLAG_DRAW_NEXT_FRAME_IF_VISIBLE, false);
|
||||||
VS::get_singleton()->multimesh_set_visible_instances(multimesh, 0);
|
VS::get_singleton()->multimesh_set_visible_instances(multimesh, 0);
|
||||||
}
|
}
|
||||||
#ifndef NO_THREADS
|
update_mutex.unlock();
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles::_update_render_thread() {
|
void CPUParticles::_update_render_thread() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
update_mutex.lock();
|
||||||
update_mutex->lock();
|
|
||||||
#endif
|
|
||||||
if (can_update) {
|
if (can_update) {
|
||||||
VS::get_singleton()->multimesh_set_as_bulk_array(multimesh, particle_data);
|
VS::get_singleton()->multimesh_set_as_bulk_array(multimesh, particle_data);
|
||||||
can_update = false; //wait for next time
|
can_update = false; //wait for next time
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
update_mutex.unlock();
|
||||||
update_mutex->unlock();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPUParticles::_notification(int p_what) {
|
void CPUParticles::_notification(int p_what) {
|
||||||
@ -1564,16 +1553,8 @@ CPUParticles::CPUParticles() {
|
|||||||
can_update = false;
|
can_update = false;
|
||||||
|
|
||||||
set_color(Color(1, 1, 1, 1));
|
set_color(Color(1, 1, 1, 1));
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
update_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CPUParticles::~CPUParticles() {
|
CPUParticles::~CPUParticles() {
|
||||||
VS::get_singleton()->free(multimesh);
|
VS::get_singleton()->free(multimesh);
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(update_mutex);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
@ -179,7 +179,7 @@ private:
|
|||||||
void _particles_process(float p_delta);
|
void _particles_process(float p_delta);
|
||||||
void _update_particle_data_buffer();
|
void _update_particle_data_buffer();
|
||||||
|
|
||||||
Mutex *update_mutex;
|
Mutex update_mutex;
|
||||||
|
|
||||||
void _update_render_thread();
|
void _update_render_thread();
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ void ScriptDebuggerRemote::debug(ScriptLanguage *p_script, bool p_can_continue,
|
|||||||
|
|
||||||
void ScriptDebuggerRemote::_get_output() {
|
void ScriptDebuggerRemote::_get_output() {
|
||||||
|
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
if (output_strings.size()) {
|
if (output_strings.size()) {
|
||||||
|
|
||||||
locking = true;
|
locking = true;
|
||||||
@ -473,7 +473,7 @@ void ScriptDebuggerRemote::_get_output() {
|
|||||||
errors.pop_front();
|
errors.pop_front();
|
||||||
locking = false;
|
locking = false;
|
||||||
}
|
}
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScriptDebuggerRemote::line_poll() {
|
void ScriptDebuggerRemote::line_poll() {
|
||||||
@ -1055,7 +1055,7 @@ void ScriptDebuggerRemote::_send_network_bandwidth_usage() {
|
|||||||
|
|
||||||
void ScriptDebuggerRemote::send_message(const String &p_message, const Array &p_args) {
|
void ScriptDebuggerRemote::send_message(const String &p_message, const Array &p_args) {
|
||||||
|
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
if (!locking && tcp_client->is_connected_to_host()) {
|
if (!locking && tcp_client->is_connected_to_host()) {
|
||||||
|
|
||||||
if (messages.size() >= max_messages_per_frame) {
|
if (messages.size() >= max_messages_per_frame) {
|
||||||
@ -1067,7 +1067,7 @@ void ScriptDebuggerRemote::send_message(const String &p_message, const Array &p_
|
|||||||
messages.push_back(msg);
|
messages.push_back(msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScriptDebuggerRemote::send_error(const String &p_func, const String &p_file, int p_line, const String &p_err, const String &p_descr, ErrorHandlerType p_type, const Vector<ScriptLanguage::StackInfo> &p_stack_info) {
|
void ScriptDebuggerRemote::send_error(const String &p_func, const String &p_file, int p_line, const String &p_err, const String &p_descr, ErrorHandlerType p_type, const Vector<ScriptLanguage::StackInfo> &p_stack_info) {
|
||||||
@ -1113,7 +1113,7 @@ void ScriptDebuggerRemote::send_error(const String &p_func, const String &p_file
|
|||||||
err_count++;
|
err_count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
|
|
||||||
if (!locking && tcp_client->is_connected_to_host()) {
|
if (!locking && tcp_client->is_connected_to_host()) {
|
||||||
|
|
||||||
@ -1132,7 +1132,7 @@ void ScriptDebuggerRemote::send_error(const String &p_func, const String &p_file
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScriptDebuggerRemote::_print_handler(void *p_this, const String &p_string, bool p_error) {
|
void ScriptDebuggerRemote::_print_handler(void *p_this, const String &p_string, bool p_error) {
|
||||||
@ -1161,7 +1161,7 @@ void ScriptDebuggerRemote::_print_handler(void *p_this, const String &p_string,
|
|||||||
sdr->char_count += allowed_chars;
|
sdr->char_count += allowed_chars;
|
||||||
bool overflowed = sdr->char_count >= sdr->max_cps;
|
bool overflowed = sdr->char_count >= sdr->max_cps;
|
||||||
|
|
||||||
sdr->mutex->lock();
|
sdr->mutex.lock();
|
||||||
if (!sdr->locking && sdr->tcp_client->is_connected_to_host()) {
|
if (!sdr->locking && sdr->tcp_client->is_connected_to_host()) {
|
||||||
|
|
||||||
if (overflowed)
|
if (overflowed)
|
||||||
@ -1178,7 +1178,7 @@ void ScriptDebuggerRemote::_print_handler(void *p_this, const String &p_string,
|
|||||||
sdr->output_strings.push_back(output_string);
|
sdr->output_strings.push_back(output_string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sdr->mutex->unlock();
|
sdr->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScriptDebuggerRemote::request_quit() {
|
void ScriptDebuggerRemote::request_quit() {
|
||||||
@ -1254,7 +1254,6 @@ ScriptDebuggerRemote::ScriptDebuggerRemote() :
|
|||||||
last_net_bandwidth_time(0),
|
last_net_bandwidth_time(0),
|
||||||
performance(Engine::get_singleton()->get_singleton_object("Performance")),
|
performance(Engine::get_singleton()->get_singleton_object("Performance")),
|
||||||
requested_quit(false),
|
requested_quit(false),
|
||||||
mutex(Mutex::create()),
|
|
||||||
max_messages_per_frame(GLOBAL_GET("network/limits/debugger_stdout/max_messages_per_frame")),
|
max_messages_per_frame(GLOBAL_GET("network/limits/debugger_stdout/max_messages_per_frame")),
|
||||||
n_messages_dropped(0),
|
n_messages_dropped(0),
|
||||||
max_errors_per_second(GLOBAL_GET("network/limits/debugger_stdout/max_errors_per_second")),
|
max_errors_per_second(GLOBAL_GET("network/limits/debugger_stdout/max_errors_per_second")),
|
||||||
@ -1291,5 +1290,4 @@ ScriptDebuggerRemote::~ScriptDebuggerRemote() {
|
|||||||
|
|
||||||
remove_print_handler(&phl);
|
remove_print_handler(&phl);
|
||||||
remove_error_handler(&eh);
|
remove_error_handler(&eh);
|
||||||
memdelete(mutex);
|
|
||||||
}
|
}
|
||||||
|
@ -75,7 +75,7 @@ class ScriptDebuggerRemote : public ScriptDebugger {
|
|||||||
uint64_t last_net_bandwidth_time;
|
uint64_t last_net_bandwidth_time;
|
||||||
Object *performance;
|
Object *performance;
|
||||||
bool requested_quit;
|
bool requested_quit;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
struct OutputError {
|
struct OutputError {
|
||||||
|
|
||||||
|
@ -1040,7 +1040,7 @@ void DynamicFont::_bind_methods() {
|
|||||||
BIND_ENUM_CONSTANT(SPACING_SPACE);
|
BIND_ENUM_CONSTANT(SPACING_SPACE);
|
||||||
}
|
}
|
||||||
|
|
||||||
Mutex *DynamicFont::dynamic_font_mutex = NULL;
|
Mutex DynamicFont::dynamic_font_mutex;
|
||||||
|
|
||||||
SelfList<DynamicFont>::List *DynamicFont::dynamic_fonts = NULL;
|
SelfList<DynamicFont>::List *DynamicFont::dynamic_fonts = NULL;
|
||||||
|
|
||||||
@ -1054,29 +1054,22 @@ DynamicFont::DynamicFont() :
|
|||||||
spacing_char = 0;
|
spacing_char = 0;
|
||||||
spacing_space = 0;
|
spacing_space = 0;
|
||||||
outline_color = Color(1, 1, 1);
|
outline_color = Color(1, 1, 1);
|
||||||
if (dynamic_font_mutex) {
|
dynamic_font_mutex.lock();
|
||||||
dynamic_font_mutex->lock();
|
|
||||||
dynamic_fonts->add(&font_list);
|
dynamic_fonts->add(&font_list);
|
||||||
dynamic_font_mutex->unlock();
|
dynamic_font_mutex.unlock();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DynamicFont::~DynamicFont() {
|
DynamicFont::~DynamicFont() {
|
||||||
if (dynamic_font_mutex) {
|
dynamic_font_mutex.lock();
|
||||||
dynamic_font_mutex->lock();
|
|
||||||
dynamic_fonts->remove(&font_list);
|
dynamic_fonts->remove(&font_list);
|
||||||
dynamic_font_mutex->unlock();
|
dynamic_font_mutex.unlock();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DynamicFont::initialize_dynamic_fonts() {
|
void DynamicFont::initialize_dynamic_fonts() {
|
||||||
dynamic_fonts = memnew(SelfList<DynamicFont>::List());
|
dynamic_fonts = memnew(SelfList<DynamicFont>::List());
|
||||||
dynamic_font_mutex = Mutex::create();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DynamicFont::finish_dynamic_fonts() {
|
void DynamicFont::finish_dynamic_fonts() {
|
||||||
memdelete(dynamic_font_mutex);
|
|
||||||
dynamic_font_mutex = NULL;
|
|
||||||
memdelete(dynamic_fonts);
|
memdelete(dynamic_fonts);
|
||||||
dynamic_fonts = NULL;
|
dynamic_fonts = NULL;
|
||||||
}
|
}
|
||||||
@ -1085,8 +1078,7 @@ void DynamicFont::update_oversampling() {
|
|||||||
|
|
||||||
Vector<Ref<DynamicFont> > changed;
|
Vector<Ref<DynamicFont> > changed;
|
||||||
|
|
||||||
if (dynamic_font_mutex)
|
dynamic_font_mutex.lock();
|
||||||
dynamic_font_mutex->lock();
|
|
||||||
|
|
||||||
SelfList<DynamicFont> *E = dynamic_fonts->first();
|
SelfList<DynamicFont> *E = dynamic_fonts->first();
|
||||||
while (E) {
|
while (E) {
|
||||||
@ -1114,8 +1106,7 @@ void DynamicFont::update_oversampling() {
|
|||||||
E = E->next();
|
E = E->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dynamic_font_mutex)
|
dynamic_font_mutex.unlock();
|
||||||
dynamic_font_mutex->unlock();
|
|
||||||
|
|
||||||
for (int i = 0; i < changed.size(); i++) {
|
for (int i = 0; i < changed.size(); i++) {
|
||||||
changed.write[i]->emit_changed();
|
changed.write[i]->emit_changed();
|
||||||
|
@ -286,7 +286,7 @@ public:
|
|||||||
|
|
||||||
SelfList<DynamicFont> font_list;
|
SelfList<DynamicFont> font_list;
|
||||||
|
|
||||||
static Mutex *dynamic_font_mutex;
|
static Mutex dynamic_font_mutex;
|
||||||
static SelfList<DynamicFont>::List *dynamic_fonts;
|
static SelfList<DynamicFont>::List *dynamic_fonts;
|
||||||
|
|
||||||
static void initialize_dynamic_fonts();
|
static void initialize_dynamic_fonts();
|
||||||
|
@ -290,17 +290,13 @@ ShaderMaterial::~ShaderMaterial() {
|
|||||||
|
|
||||||
/////////////////////////////////
|
/////////////////////////////////
|
||||||
|
|
||||||
Mutex *SpatialMaterial::material_mutex = NULL;
|
Mutex SpatialMaterial::material_mutex;
|
||||||
SelfList<SpatialMaterial>::List *SpatialMaterial::dirty_materials = NULL;
|
SelfList<SpatialMaterial>::List *SpatialMaterial::dirty_materials = NULL;
|
||||||
Map<SpatialMaterial::MaterialKey, SpatialMaterial::ShaderData> SpatialMaterial::shader_map;
|
Map<SpatialMaterial::MaterialKey, SpatialMaterial::ShaderData> SpatialMaterial::shader_map;
|
||||||
SpatialMaterial::ShaderNames *SpatialMaterial::shader_names = NULL;
|
SpatialMaterial::ShaderNames *SpatialMaterial::shader_names = NULL;
|
||||||
|
|
||||||
void SpatialMaterial::init_shaders() {
|
void SpatialMaterial::init_shaders() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
material_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
dirty_materials = memnew(SelfList<SpatialMaterial>::List);
|
dirty_materials = memnew(SelfList<SpatialMaterial>::List);
|
||||||
|
|
||||||
shader_names = memnew(ShaderNames);
|
shader_names = memnew(ShaderNames);
|
||||||
@ -379,10 +375,6 @@ void SpatialMaterial::finish_shaders() {
|
|||||||
materials_for_2d[i].unref();
|
materials_for_2d[i].unref();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(material_mutex);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memdelete(dirty_materials);
|
memdelete(dirty_materials);
|
||||||
dirty_materials = NULL;
|
dirty_materials = NULL;
|
||||||
|
|
||||||
@ -1062,42 +1054,36 @@ void SpatialMaterial::_update_shader() {
|
|||||||
|
|
||||||
void SpatialMaterial::flush_changes() {
|
void SpatialMaterial::flush_changes() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
while (dirty_materials->first()) {
|
while (dirty_materials->first()) {
|
||||||
|
|
||||||
dirty_materials->first()->self()->_update_shader();
|
dirty_materials->first()->self()->_update_shader();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpatialMaterial::_queue_shader_change() {
|
void SpatialMaterial::_queue_shader_change() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (!element.in_list()) {
|
if (!element.in_list()) {
|
||||||
dirty_materials->add(&element);
|
dirty_materials->add(&element);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SpatialMaterial::_is_shader_dirty() const {
|
bool SpatialMaterial::_is_shader_dirty() const {
|
||||||
|
|
||||||
bool dirty = false;
|
bool dirty = false;
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
dirty = element.in_list();
|
dirty = element.in_list();
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
|
|
||||||
return dirty;
|
return dirty;
|
||||||
}
|
}
|
||||||
@ -2425,8 +2411,7 @@ SpatialMaterial::SpatialMaterial() :
|
|||||||
|
|
||||||
SpatialMaterial::~SpatialMaterial() {
|
SpatialMaterial::~SpatialMaterial() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (shader_map.has(current_key)) {
|
if (shader_map.has(current_key)) {
|
||||||
shader_map[current_key].users--;
|
shader_map[current_key].users--;
|
||||||
@ -2439,6 +2424,5 @@ SpatialMaterial::~SpatialMaterial() {
|
|||||||
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
@ -361,7 +361,7 @@ private:
|
|||||||
StringName texture_names[TEXTURE_MAX];
|
StringName texture_names[TEXTURE_MAX];
|
||||||
};
|
};
|
||||||
|
|
||||||
static Mutex *material_mutex;
|
static Mutex material_mutex;
|
||||||
static SelfList<SpatialMaterial>::List *dirty_materials;
|
static SelfList<SpatialMaterial>::List *dirty_materials;
|
||||||
static ShaderNames *shader_names;
|
static ShaderNames *shader_names;
|
||||||
|
|
||||||
|
@ -30,17 +30,13 @@
|
|||||||
|
|
||||||
#include "particles_material.h"
|
#include "particles_material.h"
|
||||||
|
|
||||||
Mutex *ParticlesMaterial::material_mutex = NULL;
|
Mutex ParticlesMaterial::material_mutex;
|
||||||
SelfList<ParticlesMaterial>::List *ParticlesMaterial::dirty_materials = NULL;
|
SelfList<ParticlesMaterial>::List *ParticlesMaterial::dirty_materials = NULL;
|
||||||
Map<ParticlesMaterial::MaterialKey, ParticlesMaterial::ShaderData> ParticlesMaterial::shader_map;
|
Map<ParticlesMaterial::MaterialKey, ParticlesMaterial::ShaderData> ParticlesMaterial::shader_map;
|
||||||
ParticlesMaterial::ShaderNames *ParticlesMaterial::shader_names = NULL;
|
ParticlesMaterial::ShaderNames *ParticlesMaterial::shader_names = NULL;
|
||||||
|
|
||||||
void ParticlesMaterial::init_shaders() {
|
void ParticlesMaterial::init_shaders() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
material_mutex = Mutex::create();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
dirty_materials = memnew(SelfList<ParticlesMaterial>::List);
|
dirty_materials = memnew(SelfList<ParticlesMaterial>::List);
|
||||||
|
|
||||||
shader_names = memnew(ShaderNames);
|
shader_names = memnew(ShaderNames);
|
||||||
@ -107,10 +103,6 @@ void ParticlesMaterial::init_shaders() {
|
|||||||
|
|
||||||
void ParticlesMaterial::finish_shaders() {
|
void ParticlesMaterial::finish_shaders() {
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
|
||||||
memdelete(material_mutex);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memdelete(dirty_materials);
|
memdelete(dirty_materials);
|
||||||
dirty_materials = NULL;
|
dirty_materials = NULL;
|
||||||
|
|
||||||
@ -615,42 +607,36 @@ void ParticlesMaterial::_update_shader() {
|
|||||||
|
|
||||||
void ParticlesMaterial::flush_changes() {
|
void ParticlesMaterial::flush_changes() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
while (dirty_materials->first()) {
|
while (dirty_materials->first()) {
|
||||||
|
|
||||||
dirty_materials->first()->self()->_update_shader();
|
dirty_materials->first()->self()->_update_shader();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticlesMaterial::_queue_shader_change() {
|
void ParticlesMaterial::_queue_shader_change() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (!element.in_list()) {
|
if (!element.in_list()) {
|
||||||
dirty_materials->add(&element);
|
dirty_materials->add(&element);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ParticlesMaterial::_is_shader_dirty() const {
|
bool ParticlesMaterial::_is_shader_dirty() const {
|
||||||
|
|
||||||
bool dirty = false;
|
bool dirty = false;
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
dirty = element.in_list();
|
dirty = element.in_list();
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
|
|
||||||
return dirty;
|
return dirty;
|
||||||
}
|
}
|
||||||
@ -1301,8 +1287,7 @@ ParticlesMaterial::ParticlesMaterial() :
|
|||||||
|
|
||||||
ParticlesMaterial::~ParticlesMaterial() {
|
ParticlesMaterial::~ParticlesMaterial() {
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.lock();
|
||||||
material_mutex->lock();
|
|
||||||
|
|
||||||
if (shader_map.has(current_key)) {
|
if (shader_map.has(current_key)) {
|
||||||
shader_map[current_key].users--;
|
shader_map[current_key].users--;
|
||||||
@ -1315,6 +1300,5 @@ ParticlesMaterial::~ParticlesMaterial() {
|
|||||||
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
VS::get_singleton()->material_set_shader(_get_material(), RID());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (material_mutex)
|
material_mutex.unlock();
|
||||||
material_mutex->unlock();
|
|
||||||
}
|
}
|
||||||
|
@ -126,7 +126,7 @@ private:
|
|||||||
return mk;
|
return mk;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Mutex *material_mutex;
|
static Mutex material_mutex;
|
||||||
static SelfList<ParticlesMaterial>::List *dirty_materials;
|
static SelfList<ParticlesMaterial>::List *dirty_materials;
|
||||||
|
|
||||||
struct ShaderNames {
|
struct ShaderNames {
|
||||||
|
@ -49,7 +49,6 @@ Error AudioDriverDummy::init() {
|
|||||||
|
|
||||||
samples_in = memnew_arr(int32_t, buffer_frames * channels);
|
samples_in = memnew_arr(int32_t, buffer_frames * channels);
|
||||||
|
|
||||||
mutex = Mutex::create();
|
|
||||||
thread = Thread::create(AudioDriverDummy::thread_func, this);
|
thread = Thread::create(AudioDriverDummy::thread_func, this);
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
@ -95,16 +94,16 @@ AudioDriver::SpeakerMode AudioDriverDummy::get_speaker_mode() const {
|
|||||||
|
|
||||||
void AudioDriverDummy::lock() {
|
void AudioDriverDummy::lock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->lock();
|
mutex.lock();
|
||||||
};
|
};
|
||||||
|
|
||||||
void AudioDriverDummy::unlock() {
|
void AudioDriverDummy::unlock() {
|
||||||
|
|
||||||
if (!thread || !mutex)
|
if (!thread)
|
||||||
return;
|
return;
|
||||||
mutex->unlock();
|
mutex.unlock();
|
||||||
};
|
};
|
||||||
|
|
||||||
void AudioDriverDummy::finish() {
|
void AudioDriverDummy::finish() {
|
||||||
@ -120,14 +119,11 @@ void AudioDriverDummy::finish() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
memdelete(thread);
|
memdelete(thread);
|
||||||
if (mutex)
|
|
||||||
memdelete(mutex);
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
};
|
};
|
||||||
|
|
||||||
AudioDriverDummy::AudioDriverDummy() {
|
AudioDriverDummy::AudioDriverDummy() {
|
||||||
|
|
||||||
mutex = NULL;
|
|
||||||
thread = NULL;
|
thread = NULL;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
class AudioDriverDummy : public AudioDriver {
|
class AudioDriverDummy : public AudioDriver {
|
||||||
|
|
||||||
Thread *thread;
|
Thread *thread;
|
||||||
Mutex *mutex;
|
Mutex mutex;
|
||||||
|
|
||||||
int32_t *samples_in;
|
int32_t *samples_in;
|
||||||
|
|
||||||
|
@ -1148,27 +1148,27 @@ void *AudioServer::audio_data_alloc(uint32_t p_data_len, const uint8_t *p_from_d
|
|||||||
copymem(ad, p_from_data, p_data_len);
|
copymem(ad, p_from_data, p_data_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
audio_data_lock->lock();
|
audio_data_lock.lock();
|
||||||
audio_data[ad] = p_data_len;
|
audio_data[ad] = p_data_len;
|
||||||
audio_data_total_mem += p_data_len;
|
audio_data_total_mem += p_data_len;
|
||||||
audio_data_max_mem = MAX(audio_data_total_mem, audio_data_max_mem);
|
audio_data_max_mem = MAX(audio_data_total_mem, audio_data_max_mem);
|
||||||
audio_data_lock->unlock();
|
audio_data_lock.unlock();
|
||||||
|
|
||||||
return ad;
|
return ad;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AudioServer::audio_data_free(void *p_data) {
|
void AudioServer::audio_data_free(void *p_data) {
|
||||||
|
|
||||||
audio_data_lock->lock();
|
audio_data_lock.lock();
|
||||||
if (!audio_data.has(p_data)) {
|
if (!audio_data.has(p_data)) {
|
||||||
audio_data_lock->unlock();
|
audio_data_lock.unlock();
|
||||||
ERR_FAIL();
|
ERR_FAIL();
|
||||||
}
|
}
|
||||||
|
|
||||||
audio_data_total_mem -= audio_data[p_data];
|
audio_data_total_mem -= audio_data[p_data];
|
||||||
audio_data.erase(p_data);
|
audio_data.erase(p_data);
|
||||||
memfree(p_data);
|
memfree(p_data);
|
||||||
audio_data_lock->unlock();
|
audio_data_lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t AudioServer::audio_data_get_total_memory_usage() const {
|
size_t AudioServer::audio_data_get_total_memory_usage() const {
|
||||||
@ -1410,7 +1410,6 @@ AudioServer::AudioServer() {
|
|||||||
singleton = this;
|
singleton = this;
|
||||||
audio_data_total_mem = 0;
|
audio_data_total_mem = 0;
|
||||||
audio_data_max_mem = 0;
|
audio_data_max_mem = 0;
|
||||||
audio_data_lock = Mutex::create();
|
|
||||||
mix_frames = 0;
|
mix_frames = 0;
|
||||||
channel_count = 0;
|
channel_count = 0;
|
||||||
to_mix = 0;
|
to_mix = 0;
|
||||||
@ -1424,7 +1423,6 @@ AudioServer::AudioServer() {
|
|||||||
|
|
||||||
AudioServer::~AudioServer() {
|
AudioServer::~AudioServer() {
|
||||||
|
|
||||||
memdelete(audio_data_lock);
|
|
||||||
singleton = NULL;
|
singleton = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,7 +238,7 @@ private:
|
|||||||
size_t audio_data_total_mem;
|
size_t audio_data_total_mem;
|
||||||
size_t audio_data_max_mem;
|
size_t audio_data_max_mem;
|
||||||
|
|
||||||
Mutex *audio_data_lock;
|
Mutex audio_data_lock;
|
||||||
|
|
||||||
void init_channels_and_buffers();
|
void init_channels_and_buffers();
|
||||||
|
|
||||||
|
@ -160,7 +160,6 @@ Physics2DServerWrapMT::Physics2DServerWrapMT(Physics2DServer *p_contained, bool
|
|||||||
step_sem = NULL;
|
step_sem = NULL;
|
||||||
step_pending = 0;
|
step_pending = 0;
|
||||||
step_thread_up = false;
|
step_thread_up = false;
|
||||||
alloc_mutex = Mutex::create();
|
|
||||||
|
|
||||||
pool_max_size = GLOBAL_GET("memory/limits/multithreaded_server/rid_pool_prealloc");
|
pool_max_size = GLOBAL_GET("memory/limits/multithreaded_server/rid_pool_prealloc");
|
||||||
|
|
||||||
@ -177,6 +176,5 @@ Physics2DServerWrapMT::Physics2DServerWrapMT(Physics2DServer *p_contained, bool
|
|||||||
Physics2DServerWrapMT::~Physics2DServerWrapMT() {
|
Physics2DServerWrapMT::~Physics2DServerWrapMT() {
|
||||||
|
|
||||||
memdelete(physics_2d_server);
|
memdelete(physics_2d_server);
|
||||||
memdelete(alloc_mutex);
|
|
||||||
//finish();
|
//finish();
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,7 @@ class Physics2DServerWrapMT : public Physics2DServer {
|
|||||||
|
|
||||||
bool first_frame;
|
bool first_frame;
|
||||||
|
|
||||||
Mutex *alloc_mutex;
|
Mutex alloc_mutex;
|
||||||
int pool_max_size;
|
int pool_max_size;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -57,7 +57,7 @@
|
|||||||
virtual RID m_type##_create() { \
|
virtual RID m_type##_create() { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, &ret); \
|
||||||
@ -65,7 +65,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(); \
|
return server_name->m_type##_create(); \
|
||||||
@ -88,7 +88,7 @@
|
|||||||
virtual RID m_type##_create(m_arg1 p1) { \
|
virtual RID m_type##_create(m_arg1 p1) { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, &ret); \
|
||||||
@ -96,7 +96,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(p1); \
|
return server_name->m_type##_create(p1); \
|
||||||
@ -119,7 +119,7 @@
|
|||||||
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2) { \
|
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2) { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, &ret); \
|
||||||
@ -127,7 +127,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(p1, p2); \
|
return server_name->m_type##_create(p1, p2); \
|
||||||
@ -150,7 +150,7 @@
|
|||||||
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3) { \
|
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3) { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, &ret); \
|
||||||
@ -158,7 +158,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(p1, p2, p3); \
|
return server_name->m_type##_create(p1, p2, p3); \
|
||||||
@ -181,7 +181,7 @@
|
|||||||
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3, m_arg4 p4) { \
|
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3, m_arg4 p4) { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, p4, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, p4, &ret); \
|
||||||
@ -189,7 +189,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(p1, p2, p3, p4); \
|
return server_name->m_type##_create(p1, p2, p3, p4); \
|
||||||
@ -213,7 +213,7 @@
|
|||||||
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3, m_arg4 p4, m_arg5 p5) { \
|
virtual RID m_type##_create(m_arg1 p1, m_arg2 p2, m_arg3 p3, m_arg4 p4, m_arg5 p5) { \
|
||||||
if (Thread::get_caller_id() != server_thread) { \
|
if (Thread::get_caller_id() != server_thread) { \
|
||||||
RID rid; \
|
RID rid; \
|
||||||
alloc_mutex->lock(); \
|
alloc_mutex.lock(); \
|
||||||
if (m_type##_id_pool.size() == 0) { \
|
if (m_type##_id_pool.size() == 0) { \
|
||||||
int ret; \
|
int ret; \
|
||||||
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, p4, p5, &ret); \
|
command_queue.push_and_ret(this, &ServerNameWrapMT::m_type##allocn, p1, p2, p3, p4, p5, &ret); \
|
||||||
@ -221,7 +221,7 @@
|
|||||||
} \
|
} \
|
||||||
rid = m_type##_id_pool.front()->get(); \
|
rid = m_type##_id_pool.front()->get(); \
|
||||||
m_type##_id_pool.pop_front(); \
|
m_type##_id_pool.pop_front(); \
|
||||||
alloc_mutex->unlock(); \
|
alloc_mutex.unlock(); \
|
||||||
return rid; \
|
return rid; \
|
||||||
} else { \
|
} else { \
|
||||||
return server_name->m_type##_create(p1, p2, p3, p4, p5); \
|
return server_name->m_type##_create(p1, p2, p3, p4, p5); \
|
||||||
|
@ -2718,13 +2718,13 @@ void VisualServerScene::_gi_probe_bake_thread() {
|
|||||||
|
|
||||||
Instance *to_bake = NULL;
|
Instance *to_bake = NULL;
|
||||||
|
|
||||||
probe_bake_mutex->lock();
|
probe_bake_mutex.lock();
|
||||||
|
|
||||||
if (!probe_bake_list.empty()) {
|
if (!probe_bake_list.empty()) {
|
||||||
to_bake = probe_bake_list.front()->get();
|
to_bake = probe_bake_list.front()->get();
|
||||||
probe_bake_list.pop_front();
|
probe_bake_list.pop_front();
|
||||||
}
|
}
|
||||||
probe_bake_mutex->unlock();
|
probe_bake_mutex.unlock();
|
||||||
|
|
||||||
if (!to_bake)
|
if (!to_bake)
|
||||||
continue;
|
continue;
|
||||||
@ -3263,15 +3263,9 @@ void VisualServerScene::_bake_gi_probe(Instance *p_gi_probe) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//send back to main thread to update un little chunks
|
//send back to main thread to update un little chunks
|
||||||
if (probe_bake_mutex) {
|
probe_bake_mutex.lock();
|
||||||
probe_bake_mutex->lock();
|
|
||||||
}
|
|
||||||
|
|
||||||
probe_data->dynamic.updating_stage = GI_UPDATE_STAGE_UPLOADING;
|
probe_data->dynamic.updating_stage = GI_UPDATE_STAGE_UPLOADING;
|
||||||
|
probe_bake_mutex.unlock();
|
||||||
if (probe_bake_mutex) {
|
|
||||||
probe_bake_mutex->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool VisualServerScene::_check_gi_probe(Instance *p_gi_probe) {
|
bool VisualServerScene::_check_gi_probe(Instance *p_gi_probe) {
|
||||||
@ -3412,10 +3406,10 @@ void VisualServerScene::render_probes() {
|
|||||||
if (_check_gi_probe(instance_probe) || force_lighting) { //send to lighting thread
|
if (_check_gi_probe(instance_probe) || force_lighting) { //send to lighting thread
|
||||||
|
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
probe_bake_mutex->lock();
|
probe_bake_mutex.lock();
|
||||||
probe->dynamic.updating_stage = GI_UPDATE_STAGE_LIGHTING;
|
probe->dynamic.updating_stage = GI_UPDATE_STAGE_LIGHTING;
|
||||||
probe_bake_list.push_back(instance_probe);
|
probe_bake_list.push_back(instance_probe);
|
||||||
probe_bake_mutex->unlock();
|
probe_bake_mutex.unlock();
|
||||||
probe_bake_sem->post();
|
probe_bake_sem->post();
|
||||||
|
|
||||||
#else
|
#else
|
||||||
@ -3690,7 +3684,6 @@ VisualServerScene::VisualServerScene() {
|
|||||||
|
|
||||||
#ifndef NO_THREADS
|
#ifndef NO_THREADS
|
||||||
probe_bake_sem = Semaphore::create();
|
probe_bake_sem = Semaphore::create();
|
||||||
probe_bake_mutex = Mutex::create();
|
|
||||||
probe_bake_thread = Thread::create(_gi_probe_bake_threads, this);
|
probe_bake_thread = Thread::create(_gi_probe_bake_threads, this);
|
||||||
probe_bake_thread_exit = false;
|
probe_bake_thread_exit = false;
|
||||||
#endif
|
#endif
|
||||||
@ -3708,7 +3701,5 @@ VisualServerScene::~VisualServerScene() {
|
|||||||
Thread::wait_to_finish(probe_bake_thread);
|
Thread::wait_to_finish(probe_bake_thread);
|
||||||
memdelete(probe_bake_thread);
|
memdelete(probe_bake_thread);
|
||||||
memdelete(probe_bake_sem);
|
memdelete(probe_bake_sem);
|
||||||
memdelete(probe_bake_mutex);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -594,7 +594,7 @@ public:
|
|||||||
volatile bool probe_bake_thread_exit;
|
volatile bool probe_bake_thread_exit;
|
||||||
Thread *probe_bake_thread;
|
Thread *probe_bake_thread;
|
||||||
Semaphore *probe_bake_sem;
|
Semaphore *probe_bake_sem;
|
||||||
Mutex *probe_bake_mutex;
|
Mutex probe_bake_mutex;
|
||||||
List<Instance *> probe_bake_list;
|
List<Instance *> probe_bake_list;
|
||||||
|
|
||||||
bool _render_reflection_probe_step(Instance *p_instance, int p_step);
|
bool _render_reflection_probe_step(Instance *p_instance, int p_step);
|
||||||
|
@ -180,7 +180,6 @@ VisualServerWrapMT::VisualServerWrapMT(VisualServer *p_contained, bool p_create_
|
|||||||
thread = NULL;
|
thread = NULL;
|
||||||
draw_pending = 0;
|
draw_pending = 0;
|
||||||
draw_thread_up = false;
|
draw_thread_up = false;
|
||||||
alloc_mutex = Mutex::create();
|
|
||||||
pool_max_size = GLOBAL_GET("memory/limits/multithreaded_server/rid_pool_prealloc");
|
pool_max_size = GLOBAL_GET("memory/limits/multithreaded_server/rid_pool_prealloc");
|
||||||
|
|
||||||
if (!p_create_thread) {
|
if (!p_create_thread) {
|
||||||
@ -193,6 +192,5 @@ VisualServerWrapMT::VisualServerWrapMT(VisualServer *p_contained, bool p_create_
|
|||||||
VisualServerWrapMT::~VisualServerWrapMT() {
|
VisualServerWrapMT::~VisualServerWrapMT() {
|
||||||
|
|
||||||
memdelete(visual_server);
|
memdelete(visual_server);
|
||||||
memdelete(alloc_mutex);
|
|
||||||
//finish();
|
//finish();
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ class VisualServerWrapMT : public VisualServer {
|
|||||||
|
|
||||||
void thread_exit();
|
void thread_exit();
|
||||||
|
|
||||||
Mutex *alloc_mutex;
|
Mutex alloc_mutex;
|
||||||
|
|
||||||
int pool_max_size;
|
int pool_max_size;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user