* Brought libkernelland_emu.so up-to-date again.
* Added Slab stubs (from tcp_shell). * Added (yet untested) support for anonymous condition variables. * Added low resource manager functions. * Allows including thread.h now. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@28502 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
7f1f15f775
commit
167460c123
@ -7,8 +7,10 @@
|
||||
* Axel Dörfler, axeld@pinc-software.de.
|
||||
*/
|
||||
|
||||
#include <lock.h>
|
||||
#include <fs/devfs.h>
|
||||
#include <set>
|
||||
#include <signal.h>
|
||||
#include <stdio.h>
|
||||
#include <string>
|
||||
|
||||
#include <Autolock.h>
|
||||
#include <Directory.h>
|
||||
@ -21,9 +23,16 @@
|
||||
#include <Path.h>
|
||||
#include <String.h>
|
||||
|
||||
#include <set>
|
||||
#include <stdio.h>
|
||||
#include <string>
|
||||
#ifdef ASSERT
|
||||
# undef ASSERT
|
||||
#endif
|
||||
|
||||
#include <condition_variable.h>
|
||||
#include <lock.h>
|
||||
#include <low_resource_manager.h>
|
||||
#include <fs/devfs.h>
|
||||
#include <kscheduler.h>
|
||||
#include <slab/Slab.h>
|
||||
|
||||
#ifdef TRACE
|
||||
# undef TRACE
|
||||
@ -31,6 +40,8 @@
|
||||
#define TRACE(x)
|
||||
//#define TRACE(x) printf x
|
||||
|
||||
#define RW_MAX_READERS 10000
|
||||
|
||||
static const char *gModuleDirs[] = {
|
||||
"distro/x86.R1/beos/system/add-ons/userland",
|
||||
NULL
|
||||
@ -848,22 +859,37 @@ atomic_test_and_set(vint32 *value, int32 newValue, int32 testAgainst)
|
||||
}
|
||||
|
||||
|
||||
extern "C" uint64
|
||||
parse_expression(const char* arg)
|
||||
extern "C" int
|
||||
send_signal_etc(pid_t thread, uint signal, uint32 flags)
|
||||
{
|
||||
return strtoull(arg, NULL, 0);
|
||||
return send_signal(thread, signal);
|
||||
}
|
||||
|
||||
|
||||
extern "C" int
|
||||
add_debugger_command(char *name, int (*func)(int, char **), char *desc)
|
||||
extern "C" int32
|
||||
low_resource_state(uint32 resources)
|
||||
{
|
||||
return B_NO_LOW_RESOURCE;
|
||||
}
|
||||
|
||||
|
||||
extern "C" void
|
||||
low_resource(uint32 resource, uint64 requirements, uint32 flags,
|
||||
uint32 timeout)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
extern "C" status_t
|
||||
register_low_resource_handler(low_resource_func function, void *data,
|
||||
uint32 resources, int32 priority)
|
||||
{
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
extern "C" int
|
||||
remove_debugger_command(char * name, int (*func)(int, char **))
|
||||
extern "C" status_t
|
||||
unregister_low_resource_handler(low_resource_func function, void *data)
|
||||
{
|
||||
return B_OK;
|
||||
}
|
||||
@ -1002,38 +1028,159 @@ user_strlcpy(char *to, const char *from, size_t size)
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - Debugger
|
||||
|
||||
|
||||
extern "C" uint64
|
||||
parse_expression(const char* arg)
|
||||
{
|
||||
return strtoull(arg, NULL, 0);
|
||||
}
|
||||
|
||||
|
||||
extern "C" bool
|
||||
set_debug_variable(const char* variableName, uint64 value)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
extern "C" bool
|
||||
print_debugger_command_usage(const char* command)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
extern "C" status_t
|
||||
add_debugger_command_etc(const char* name, debugger_command_hook func,
|
||||
const char* description, const char* usage, uint32 flags)
|
||||
{
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
extern "C" int
|
||||
add_debugger_command(char *name, int (*func)(int, char **), char *desc)
|
||||
{
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
extern "C" int
|
||||
remove_debugger_command(char * name, int (*func)(int, char **))
|
||||
{
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - Slab allocator
|
||||
|
||||
|
||||
extern "C" void *
|
||||
object_cache_alloc(object_cache *cache, uint32 flags)
|
||||
{
|
||||
return malloc((size_t)cache);
|
||||
}
|
||||
|
||||
|
||||
extern "C" void
|
||||
object_cache_free(object_cache *cache, void *object)
|
||||
{
|
||||
free(object);
|
||||
}
|
||||
|
||||
|
||||
extern "C" object_cache *
|
||||
create_object_cache_etc(const char *name, size_t objectSize,
|
||||
size_t alignment, size_t maxByteUsage, uint32 flags, void *cookie,
|
||||
object_cache_constructor constructor, object_cache_destructor destructor,
|
||||
object_cache_reclaimer reclaimer)
|
||||
{
|
||||
return (object_cache*)objectSize;
|
||||
}
|
||||
|
||||
|
||||
extern "C" object_cache *
|
||||
create_object_cache(const char *name, size_t objectSize,
|
||||
size_t alignment, void *cookie, object_cache_constructor constructor,
|
||||
object_cache_destructor)
|
||||
{
|
||||
return (object_cache*)objectSize;
|
||||
}
|
||||
|
||||
|
||||
extern "C" void
|
||||
delete_object_cache(object_cache *cache)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
extern "C" void
|
||||
object_cache_get_usage(object_cache *cache, size_t *_allocatedMemory)
|
||||
{
|
||||
*_allocatedMemory = 100;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - Thread/scheduler functions
|
||||
|
||||
|
||||
struct scheduler_ops kScheduler = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
};
|
||||
struct scheduler_ops* gScheduler = &kScheduler;
|
||||
|
||||
|
||||
// #pragma mark - Private locking functions
|
||||
|
||||
|
||||
int32
|
||||
recursive_lock_get_recursion(recursive_lock *lock)
|
||||
{
|
||||
thread_id thid = find_thread(NULL);
|
||||
thread_id thread = find_thread(NULL);
|
||||
|
||||
if (lock->holder == thid)
|
||||
#if !KDEBUG
|
||||
if (lock->holder == thread)
|
||||
return lock->recursion;
|
||||
#else
|
||||
if (lock->lock.holder == thread)
|
||||
return lock->recursion;
|
||||
#endif
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
recursive_lock_init(recursive_lock *lock, const char *name)
|
||||
void
|
||||
recursive_lock_init_etc(recursive_lock *lock, const char *name, uint32 flags)
|
||||
{
|
||||
if (lock == NULL)
|
||||
return B_BAD_VALUE;
|
||||
return;
|
||||
|
||||
if (name == NULL)
|
||||
name = "recursive lock";
|
||||
|
||||
#if !KDEBUG
|
||||
lock->holder = -1;
|
||||
#else
|
||||
lock->lock.holder = -1;
|
||||
#endif
|
||||
lock->recursion = 0;
|
||||
lock->sem = create_sem(1, name);
|
||||
lock->lock.waiters = (mutex_waiter*)create_sem(1, name);
|
||||
|
||||
if (lock->sem >= B_OK)
|
||||
return B_OK;
|
||||
if ((sem_id)lock->lock.waiters < B_OK)
|
||||
panic("recursive lock creation failed: %s\n", name);
|
||||
}
|
||||
|
||||
return lock->sem;
|
||||
|
||||
void
|
||||
recursive_lock_init(recursive_lock *lock, const char *name)
|
||||
{
|
||||
recursive_lock_init_etc(lock, name, 0);
|
||||
}
|
||||
|
||||
|
||||
@ -1043,8 +1190,8 @@ recursive_lock_destroy(recursive_lock *lock)
|
||||
if (lock == NULL)
|
||||
return;
|
||||
|
||||
delete_sem(lock->sem);
|
||||
lock->sem = -1;
|
||||
delete_sem((sem_id)lock->lock.waiters);
|
||||
lock->lock.waiters = (mutex_waiter*)-1;
|
||||
}
|
||||
|
||||
|
||||
@ -1053,13 +1200,29 @@ recursive_lock_lock(recursive_lock *lock)
|
||||
{
|
||||
thread_id thread = find_thread(NULL);
|
||||
|
||||
#if !KDEBUG
|
||||
if (thread != lock->holder) {
|
||||
status_t status = acquire_sem(lock->sem);
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem((sem_id)lock->lock.waiters);
|
||||
} while (status == B_INTERRUPTED);
|
||||
if (status < B_OK)
|
||||
return status;
|
||||
|
||||
lock->holder = thread;
|
||||
}
|
||||
#else
|
||||
if (thread != lock->lock.holder) {
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem((sem_id)lock->lock.waiters);
|
||||
} while (status == B_INTERRUPTED);
|
||||
if (status < B_OK)
|
||||
return status;
|
||||
|
||||
lock->lock.holder = thread;
|
||||
}
|
||||
#endif
|
||||
lock->recursion++;
|
||||
return B_OK;
|
||||
}
|
||||
@ -1068,12 +1231,21 @@ recursive_lock_lock(recursive_lock *lock)
|
||||
void
|
||||
recursive_lock_unlock(recursive_lock *lock)
|
||||
{
|
||||
#if !KDEBUG
|
||||
if (find_thread(NULL) != lock->holder)
|
||||
panic("recursive_lock %p unlocked by non-holder thread!\n", lock);
|
||||
#else
|
||||
if (find_thread(NULL) != lock->lock.holder)
|
||||
panic("recursive_lock %p unlocked by non-holder thread!\n", lock);
|
||||
#endif
|
||||
|
||||
if (--lock->recursion == 0) {
|
||||
#if !KDEBUG
|
||||
lock->holder = -1;
|
||||
release_sem_etc(lock->sem, 1, 0/*B_DO_NOT_RESCHEDULE*/);
|
||||
#else
|
||||
lock->lock.holder = -1;
|
||||
#endif
|
||||
release_sem_etc((sem_id)lock->lock.waiters, 1, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1129,19 +1301,28 @@ mutex_destroy(mutex *mutex)
|
||||
status_t
|
||||
_mutex_trylock(mutex *mutex)
|
||||
{
|
||||
return acquire_sem_etc((sem_id)mutex->waiters, 1, B_RELATIVE_TIMEOUT, 0);
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem_etc((sem_id)mutex->waiters, 1, B_RELATIVE_TIMEOUT,
|
||||
0);
|
||||
} while (status == B_INTERRUPTED);
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
_mutex_lock(mutex *mutex, bool threadsLocked)
|
||||
{
|
||||
return acquire_sem((sem_id)mutex->waiters);
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem((sem_id)mutex->waiters);
|
||||
} while (status == B_INTERRUPTED);
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
_mutex_unlock(mutex *mutex)
|
||||
_mutex_unlock(mutex *mutex, bool threadsLocked)
|
||||
{
|
||||
release_sem((sem_id)mutex->waiters);
|
||||
}
|
||||
@ -1150,46 +1331,25 @@ _mutex_unlock(mutex *mutex)
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
status_t
|
||||
benaphore_init(benaphore *ben, const char *name)
|
||||
{
|
||||
if (ben == NULL || name == NULL)
|
||||
return B_BAD_VALUE;
|
||||
|
||||
ben->count = 1;
|
||||
ben->sem = create_sem(0, name);
|
||||
if (ben->sem >= B_OK)
|
||||
return B_OK;
|
||||
|
||||
return ben->sem;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
benaphore_destroy(benaphore *ben)
|
||||
{
|
||||
delete_sem(ben->sem);
|
||||
ben->sem = -1;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
status_t
|
||||
rw_lock_init(rw_lock *lock, const char *name)
|
||||
rw_lock_init_etc(rw_lock *lock, const char *name, uint32 flags)
|
||||
{
|
||||
if (lock == NULL)
|
||||
return B_BAD_VALUE;
|
||||
return;
|
||||
|
||||
if (name == NULL)
|
||||
name = "r/w lock";
|
||||
|
||||
lock->sem = create_sem(RW_MAX_READERS, name);
|
||||
if (lock->sem >= B_OK)
|
||||
return B_OK;
|
||||
lock->waiters = (rw_lock_waiter*)create_sem(RW_MAX_READERS, name);
|
||||
if ((sem_id)lock->waiters < B_OK)
|
||||
panic("r/w lock \"%s\" creation failed.", name);
|
||||
}
|
||||
|
||||
return lock->sem;
|
||||
|
||||
void
|
||||
rw_lock_init(rw_lock *lock, const char *name)
|
||||
{
|
||||
rw_lock_init_etc(lock, name, 0);
|
||||
}
|
||||
|
||||
|
||||
@ -1199,34 +1359,146 @@ rw_lock_destroy(rw_lock *lock)
|
||||
if (lock == NULL)
|
||||
return;
|
||||
|
||||
delete_sem(lock->sem);
|
||||
delete_sem((sem_id)lock->waiters);
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
rw_lock_read_lock(rw_lock *lock)
|
||||
{
|
||||
return acquire_sem(lock->sem);
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem((sem_id)lock->waiters);
|
||||
} while (status == B_INTERRUPTED);
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
rw_lock_read_unlock(rw_lock *lock)
|
||||
{
|
||||
return release_sem(lock->sem);
|
||||
return release_sem((sem_id)lock->waiters);
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
rw_lock_write_lock(rw_lock *lock)
|
||||
{
|
||||
return acquire_sem_etc(lock->sem, RW_MAX_READERS, 0, 0);
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem_etc((sem_id)lock->waiters, RW_MAX_READERS, 0, 0);
|
||||
} while (status == B_INTERRUPTED);
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
rw_lock_write_unlock(rw_lock *lock)
|
||||
{
|
||||
return release_sem_etc(lock->sem, RW_MAX_READERS, 0);
|
||||
return release_sem_etc((sem_id)lock->waiters, RW_MAX_READERS, 0);
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - Condition variables (anonymous only)
|
||||
|
||||
|
||||
#define STATUS_ADDED 1
|
||||
#define STATUS_WAITING 2
|
||||
|
||||
|
||||
struct condition_private {
|
||||
mutex lock;
|
||||
sem_id wait_sem;
|
||||
const void* object;
|
||||
};
|
||||
|
||||
|
||||
status_t
|
||||
ConditionVariableEntry::Wait(uint32 flags, bigtime_t timeout)
|
||||
{
|
||||
if (fVariable == NULL)
|
||||
return fWaitStatus;
|
||||
|
||||
condition_private* condition = (condition_private*)fVariable->fObject;
|
||||
fWaitStatus = STATUS_WAITING;
|
||||
|
||||
status_t status;
|
||||
do {
|
||||
status = acquire_sem_etc(condition->wait_sem, 1, flags, timeout);
|
||||
} while (status == B_INTERRUPTED);
|
||||
|
||||
mutex_lock(&condition->lock);
|
||||
|
||||
// remove entry from variable, if not done yet
|
||||
if (fVariable != NULL) {
|
||||
fVariable->fEntries.Remove(this);
|
||||
fVariable = NULL;
|
||||
}
|
||||
|
||||
mutex_unlock(&condition->lock);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
inline void
|
||||
ConditionVariableEntry::AddToVariable(ConditionVariable* variable)
|
||||
{
|
||||
fVariable = variable;
|
||||
fWaitStatus = STATUS_ADDED;
|
||||
fVariable->fEntries.Add(this);
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark -
|
||||
|
||||
|
||||
void
|
||||
ConditionVariable::Init(const void* object, const char* objectType)
|
||||
{
|
||||
fObjectType = objectType;
|
||||
new(&fEntries) EntryList;
|
||||
|
||||
condition_private* condition = new condition_private;
|
||||
mutex_init(&condition->lock, objectType);
|
||||
condition->wait_sem = create_sem(0, "condition variable wait");
|
||||
if (condition->wait_sem < B_OK)
|
||||
panic("cannot create condition variable.");
|
||||
|
||||
condition->object = object;
|
||||
|
||||
fObject = condition;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
ConditionVariable::Add(ConditionVariableEntry* entry)
|
||||
{
|
||||
entry->AddToVariable(this);
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
ConditionVariable::_Notify(bool all, bool threadsLocked)
|
||||
{
|
||||
condition_private* condition = (condition_private*)fObject;
|
||||
mutex_lock(&condition->lock);
|
||||
|
||||
uint32 count = 0;
|
||||
|
||||
while (ConditionVariableEntry* entry = fEntries.RemoveHead()) {
|
||||
entry->fVariable = NULL;
|
||||
if (entry->fWaitStatus <= 0)
|
||||
continue;
|
||||
|
||||
entry->fWaitStatus = B_OK;
|
||||
count++;
|
||||
|
||||
if (!all)
|
||||
break;
|
||||
}
|
||||
|
||||
release_sem_etc(condition->wait_sem, count, 0);
|
||||
mutex_unlock(&condition->lock);
|
||||
}
|
||||
|
||||
|
@ -12,6 +12,7 @@ SimpleTest tcp_shell :
|
||||
tcp_shell.cpp
|
||||
|
||||
# stack
|
||||
ancillary_data.cpp
|
||||
net_buffer.cpp
|
||||
utility.cpp
|
||||
|
||||
@ -37,7 +38,7 @@ SEARCH on [ FGristFiles
|
||||
] = [ FDirName $(HAIKU_TOP) src add-ons kernel network protocols ipv4 ] ;
|
||||
|
||||
SEARCH on [ FGristFiles
|
||||
net_buffer.cpp utility.cpp
|
||||
ancillary_data.cpp net_buffer.cpp utility.cpp
|
||||
] = [ FDirName $(HAIKU_TOP) src add-ons kernel network stack ] ;
|
||||
|
||||
SEARCH on [ FGristFiles
|
||||
|
@ -61,7 +61,7 @@ struct net_socket_private : net_socket {
|
||||
struct list connected_children;
|
||||
|
||||
struct select_sync_pool *select_pool;
|
||||
benaphore lock;
|
||||
mutex lock;
|
||||
};
|
||||
|
||||
|
||||
@ -141,44 +141,6 @@ is_fin(net_buffer* buffer)
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - misc kernel
|
||||
|
||||
|
||||
void *
|
||||
object_cache_alloc(object_cache *cache, uint32 flags)
|
||||
{
|
||||
return malloc((size_t)cache);
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
object_cache_free(object_cache *cache, void *object)
|
||||
{
|
||||
free(object);
|
||||
}
|
||||
|
||||
|
||||
object_cache *
|
||||
create_object_cache(const char *name, size_t objectSize,
|
||||
size_t alignment, void *cookie, object_cache_constructor constructor,
|
||||
object_cache_destructor)
|
||||
{
|
||||
return (object_cache*)objectSize;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
delete_object_cache(object_cache *cache)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
extern "C" void
|
||||
scheduler_enqueue_in_run_queue(struct thread *thread)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - stack
|
||||
|
||||
|
||||
@ -279,12 +241,16 @@ static net_stack_module_info gNetStackModule = {
|
||||
init_timer,
|
||||
set_timer,
|
||||
cancel_timer,
|
||||
wait_for_timer,
|
||||
is_timer_active,
|
||||
is_timer_running,
|
||||
|
||||
dummy_is_syscall,
|
||||
dummy_is_restarted_syscall,
|
||||
dummy_store_syscall_restart_timeout,
|
||||
NULL, // restore_syscall_restart_timeout
|
||||
|
||||
// ancillary data is not used by TCP
|
||||
};
|
||||
|
||||
|
||||
@ -305,9 +271,7 @@ socket_create(int family, int type, int protocol, net_socket **_socket)
|
||||
socket->type = type;
|
||||
socket->protocol = protocol;
|
||||
|
||||
status_t status = benaphore_init(&socket->lock, "socket");
|
||||
if (status < B_OK)
|
||||
goto err1;
|
||||
mutex_init(&socket->lock, "socket");
|
||||
|
||||
// set defaults (may be overridden by the protocols)
|
||||
socket->send.buffer_size = 65535;
|
||||
@ -323,7 +287,9 @@ socket_create(int family, int type, int protocol, net_socket **_socket)
|
||||
socket->first_protocol = gTCPModule->init_protocol(socket);
|
||||
if (socket->first_protocol == NULL) {
|
||||
fprintf(stderr, "tcp_tester: cannot create protocol\n");
|
||||
goto err2;
|
||||
mutex_destroy(&socket->lock);
|
||||
delete socket;
|
||||
return B_ERROR;
|
||||
}
|
||||
|
||||
socket->first_info = gTCPModule;
|
||||
@ -338,12 +304,6 @@ socket_create(int family, int type, int protocol, net_socket **_socket)
|
||||
|
||||
*_socket = socket;
|
||||
return B_OK;
|
||||
|
||||
err2:
|
||||
benaphore_destroy(&socket->lock);
|
||||
err1:
|
||||
delete socket;
|
||||
return status;
|
||||
}
|
||||
|
||||
|
||||
@ -356,7 +316,7 @@ socket_delete(net_socket *_socket)
|
||||
panic("socket still has a parent!");
|
||||
|
||||
socket->first_info->uninit_protocol(socket->first_protocol);
|
||||
benaphore_destroy(&socket->lock);
|
||||
mutex_destroy(&socket->lock);
|
||||
delete socket;
|
||||
}
|
||||
|
||||
@ -508,7 +468,7 @@ socket_spawn_pending(net_socket *_parent, net_socket **_socket)
|
||||
{
|
||||
net_socket_private *parent = (net_socket_private *)_parent;
|
||||
|
||||
BenaphoreLocker locker(parent->lock);
|
||||
MutexLocker locker(parent->lock);
|
||||
|
||||
// We actually accept more pending connections to compensate for those
|
||||
// that never complete, and also make sure at least a single connection
|
||||
@ -545,7 +505,7 @@ socket_dequeue_connected(net_socket *_parent, net_socket **_socket)
|
||||
{
|
||||
net_socket_private *parent = (net_socket_private *)_parent;
|
||||
|
||||
benaphore_lock(&parent->lock);
|
||||
mutex_lock(&parent->lock);
|
||||
|
||||
net_socket *socket = (net_socket *)list_remove_head_item(&parent->connected_children);
|
||||
if (socket != NULL) {
|
||||
@ -554,7 +514,7 @@ socket_dequeue_connected(net_socket *_parent, net_socket **_socket)
|
||||
*_socket = socket;
|
||||
}
|
||||
|
||||
benaphore_unlock(&parent->lock);
|
||||
mutex_unlock(&parent->lock);
|
||||
return socket != NULL ? B_OK : B_ENTRY_NOT_FOUND;
|
||||
}
|
||||
|
||||
@ -564,7 +524,7 @@ socket_count_connected(net_socket *_parent)
|
||||
{
|
||||
net_socket_private *parent = (net_socket_private *)_parent;
|
||||
|
||||
BenaphoreLocker _(parent->lock);
|
||||
MutexLocker _(parent->lock);
|
||||
|
||||
ssize_t count = 0;
|
||||
void *item = NULL;
|
||||
@ -586,7 +546,7 @@ socket_set_max_backlog(net_socket *_socket, uint32 backlog)
|
||||
if (backlog > 256)
|
||||
backlog = 256;
|
||||
|
||||
benaphore_lock(&socket->lock);
|
||||
mutex_lock(&socket->lock);
|
||||
|
||||
// first remove the pending connections, then the already connected ones as needed
|
||||
net_socket *child;
|
||||
@ -603,7 +563,7 @@ socket_set_max_backlog(net_socket *_socket, uint32 backlog)
|
||||
}
|
||||
|
||||
socket->max_backlog = backlog;
|
||||
benaphore_unlock(&socket->lock);
|
||||
mutex_unlock(&socket->lock);
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
@ -619,12 +579,12 @@ socket_connected(net_socket *socket)
|
||||
if (parent == NULL)
|
||||
return B_BAD_VALUE;
|
||||
|
||||
benaphore_lock(&parent->lock);
|
||||
mutex_lock(&parent->lock);
|
||||
|
||||
list_remove_item(&parent->pending_children, socket);
|
||||
list_add_item(&parent->connected_children, socket);
|
||||
|
||||
benaphore_unlock(&parent->lock);
|
||||
mutex_unlock(&parent->lock);
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
@ -634,7 +594,7 @@ socket_notify(net_socket *_socket, uint8 event, int32 value)
|
||||
{
|
||||
net_socket_private *socket = (net_socket_private *)_socket;
|
||||
|
||||
benaphore_lock(&socket->lock);
|
||||
mutex_lock(&socket->lock);
|
||||
|
||||
bool notify = true;
|
||||
|
||||
@ -659,7 +619,7 @@ socket_notify(net_socket *_socket, uint8 event, int32 value)
|
||||
if (notify)
|
||||
;
|
||||
|
||||
benaphore_unlock(&socket->lock);
|
||||
mutex_unlock(&socket->lock);
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user