mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-10-21 14:53:44 +03:00
applied patch from Marcin 'Shard' Konicki to provide BeOS thread support.
* nanoftp.c nanohttp.c testThreads.c threads.c: applied patch from Marcin 'Shard' Konicki to provide BeOS thread support. Daniel
This commit is contained in:
@@ -1,3 +1,8 @@
|
||||
Wed Oct 29 14:37:40 CET 2003 Daniel Veillard <daniel@veillard.com>
|
||||
|
||||
* nanoftp.c nanohttp.c testThreads.c threads.c: applied patch from
|
||||
Marcin 'Shard' Konicki to provide BeOS thread support.
|
||||
|
||||
Wed Oct 29 14:20:14 CET 2003 Daniel Veillard <daniel@veillard.com>
|
||||
|
||||
* xmlschemas.c include/libxml/xmlschemas.h: applied patch
|
||||
|
@@ -2221,10 +2221,10 @@ static
|
||||
void ftpData(void *userData, const char *data, int len) {
|
||||
if (userData == NULL) return;
|
||||
if (len <= 0) {
|
||||
fclose(userData);
|
||||
fclose((FILE*)userData);
|
||||
return;
|
||||
}
|
||||
fwrite(data, len, 1, userData);
|
||||
fwrite(data, len, 1, (FILE*)userData);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
|
12
nanohttp.c
12
nanohttp.c
@@ -1314,7 +1314,7 @@ retry:
|
||||
if (contentType && *contentType)
|
||||
blen += strlen(*contentType) + 16;
|
||||
blen += strlen(method) + strlen(ctxt->path) + 24;
|
||||
bp = xmlMallocAtomic(blen);
|
||||
bp = (char*)xmlMallocAtomic(blen);
|
||||
if ( bp == NULL ) {
|
||||
xmlNanoHTTPFreeCtxt( ctxt );
|
||||
xmlHTTPErrMemory("allocating header buffer");
|
||||
@@ -1616,7 +1616,7 @@ xmlNanoHTTPAuthHeader(void *ctx) {
|
||||
*/
|
||||
int
|
||||
xmlNanoHTTPContentLength( void * ctx ) {
|
||||
xmlNanoHTTPCtxtPtr ctxt = ctx;
|
||||
xmlNanoHTTPCtxtPtr ctxt = (xmlNanoHTTPCtxtPtr)ctx;
|
||||
|
||||
return ( ( ctxt == NULL ) ? -1 : ctxt->ContentLength );
|
||||
}
|
||||
@@ -1631,7 +1631,7 @@ xmlNanoHTTPContentLength( void * ctx ) {
|
||||
*/
|
||||
const char *
|
||||
xmlNanoHTTPRedir( void * ctx ) {
|
||||
xmlNanoHTTPCtxtPtr ctxt = ctx;
|
||||
xmlNanoHTTPCtxtPtr ctxt = (xmlNanoHTTPCtxtPtr)ctx;
|
||||
|
||||
return ( ( ctxt == NULL ) ? NULL : ctxt->location );
|
||||
}
|
||||
@@ -1646,7 +1646,7 @@ xmlNanoHTTPRedir( void * ctx ) {
|
||||
*/
|
||||
const char *
|
||||
xmlNanoHTTPEncoding( void * ctx ) {
|
||||
xmlNanoHTTPCtxtPtr ctxt = ctx;
|
||||
xmlNanoHTTPCtxtPtr ctxt = (xmlNanoHTTPCtxtPtr)ctx;
|
||||
|
||||
return ( ( ctxt == NULL ) ? NULL : ctxt->encoding );
|
||||
}
|
||||
@@ -1661,7 +1661,7 @@ xmlNanoHTTPEncoding( void * ctx ) {
|
||||
*/
|
||||
const char *
|
||||
xmlNanoHTTPMimeType( void * ctx ) {
|
||||
xmlNanoHTTPCtxtPtr ctxt = ctx;
|
||||
xmlNanoHTTPCtxtPtr ctxt = (xmlNanoHTTPCtxtPtr)ctx;
|
||||
|
||||
return ( ( ctxt == NULL ) ? NULL : ctxt->mimeType );
|
||||
}
|
||||
@@ -1680,7 +1680,7 @@ xmlNanoHTTPMimeType( void * ctx ) {
|
||||
*/
|
||||
int
|
||||
xmlNanoHTTPFetchContent( void * ctx, char ** ptr, int * len ) {
|
||||
xmlNanoHTTPCtxtPtr ctxt = ctx;
|
||||
xmlNanoHTTPCtxtPtr ctxt = (xmlNanoHTTPCtxtPtr)ctx;
|
||||
|
||||
int rc = 0;
|
||||
int cur_lgth;
|
||||
|
@@ -7,7 +7,11 @@
|
||||
#include <libxml/threads.h>
|
||||
#include <libxml/parser.h>
|
||||
#include <libxml/catalog.h>
|
||||
#ifdef HAVE_PTHREAD_H
|
||||
#include <pthread.h>
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
#include <OS.h>
|
||||
#endif
|
||||
#include <string.h>
|
||||
#if !defined(_MSC_VER)
|
||||
#include <unistd.h>
|
||||
@@ -15,7 +19,11 @@
|
||||
#include <assert.h>
|
||||
|
||||
#define MAX_ARGC 20
|
||||
#ifdef HAVE_PTHREAD_H
|
||||
static pthread_t tid[MAX_ARGC];
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
static thread_id tid[MAX_ARGC];
|
||||
#endif
|
||||
|
||||
static const char *catalog = "test/threads/complex.xml";
|
||||
static const char *testfiles[] = {
|
||||
@@ -83,6 +91,7 @@ thread_specific_data(void *private_data)
|
||||
return ((void *) Okay);
|
||||
}
|
||||
|
||||
#ifdef HAVE_PTHREAD_H
|
||||
int
|
||||
main(void)
|
||||
{
|
||||
@@ -125,6 +134,62 @@ main(void)
|
||||
xmlMemoryDump();
|
||||
return (0);
|
||||
}
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
int
|
||||
main(void)
|
||||
{
|
||||
unsigned int i, repeat;
|
||||
unsigned int num_threads = sizeof(testfiles) / sizeof(testfiles[0]);
|
||||
void *results[MAX_ARGC];
|
||||
status_t ret;
|
||||
|
||||
xmlInitParser();
|
||||
printf("Parser initialized\n");
|
||||
for (repeat = 0;repeat < 500;repeat++) {
|
||||
printf("repeat: %d\n",repeat);
|
||||
xmlLoadCatalog(catalog);
|
||||
printf("loaded catalog: %s\n", catalog);
|
||||
for (i = 0; i < num_threads; i++) {
|
||||
results[i] = NULL;
|
||||
tid[i] = (thread_id) -1;
|
||||
}
|
||||
printf("cleaned threads\n");
|
||||
for (i = 0; i < num_threads; i++) {
|
||||
tid[i] = spawn_thread(thread_specific_data, "xmlTestThread", B_NORMAL_PRIORITY, (void *) testfiles[i]);
|
||||
if (tid[i] < B_OK) {
|
||||
perror("beos_thread_create");
|
||||
exit(1);
|
||||
}
|
||||
printf("beos_thread_create %d -> %d\n", i, tid[i]);
|
||||
}
|
||||
for (i = 0; i < num_threads; i++) {
|
||||
ret = wait_for_thread(tid[i], &results[i]);
|
||||
printf("beos_thread_wait %d -> %d\n", i, ret);
|
||||
if (ret != B_OK) {
|
||||
perror("beos_thread_wait");
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
xmlCatalogCleanup();
|
||||
ret = B_OK;
|
||||
for (i = 0; i < num_threads; i++)
|
||||
if (results[i] != (void *) Okay) {
|
||||
printf("Thread %d handling %s failed\n", i, testfiles[i]);
|
||||
ret = B_ERROR;
|
||||
}
|
||||
}
|
||||
xmlCleanupParser();
|
||||
xmlMemoryDump();
|
||||
|
||||
if (ret == B_OK)
|
||||
printf("testThread : BeOS : SUCCESS!\n");
|
||||
else
|
||||
printf("testThread : BeOS : FAILED!\n");
|
||||
|
||||
return (0);
|
||||
}
|
||||
#endif /* pthreads or BeOS threads */
|
||||
|
||||
#else /* !LIBXML_THREADS_ENABLED */
|
||||
int
|
||||
|
99
threads.c
99
threads.c
@@ -35,6 +35,11 @@
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_BEOS_THREADS
|
||||
#include <OS.h>
|
||||
#include <TLS.h>
|
||||
#endif
|
||||
|
||||
#if defined(SOLARIS)
|
||||
#include <note.h>
|
||||
#endif
|
||||
@@ -55,6 +60,8 @@ struct _xmlMutex {
|
||||
pthread_mutex_t lock;
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
HANDLE mutex;
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
sem_id sem;
|
||||
#else
|
||||
int empty;
|
||||
#endif
|
||||
@@ -73,6 +80,10 @@ struct _xmlRMutex {
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
CRITICAL_SECTION cs;
|
||||
unsigned int count;
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
xmlMutexPtr lock;
|
||||
thread_id tid;
|
||||
int32 count;
|
||||
#else
|
||||
int empty;
|
||||
#endif
|
||||
@@ -96,7 +107,12 @@ static DWORD globalkey = TLS_OUT_OF_INDEXES;
|
||||
#endif /* HAVE_COMPILER_TLS */
|
||||
static DWORD mainthread;
|
||||
static int run_once_init = 1;
|
||||
#endif /* HAVE_WIN32_THREADS */
|
||||
/* endif HAVE_WIN32_THREADS */
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
int32 globalkey = 0;
|
||||
thread_id mainthread = 0;
|
||||
int32 run_once_init = 0;
|
||||
#endif
|
||||
|
||||
static xmlRMutexPtr xmlLibraryLock = NULL;
|
||||
#ifdef LIBXML_THREAD_ENABLED
|
||||
@@ -122,6 +138,11 @@ xmlNewMutex(void)
|
||||
pthread_mutex_init(&tok->lock, NULL);
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
tok->mutex = CreateMutex(NULL, FALSE, NULL);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
if ((tok->sem = create_sem(1, "xmlMutex")) < B_OK) {
|
||||
free(tok);
|
||||
return NULL;
|
||||
}
|
||||
#endif
|
||||
return (tok);
|
||||
}
|
||||
@@ -142,6 +163,8 @@ xmlFreeMutex(xmlMutexPtr tok)
|
||||
pthread_mutex_destroy(&tok->lock);
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
CloseHandle(tok->mutex);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
delete_sem(tok->sem);
|
||||
#endif
|
||||
free(tok);
|
||||
}
|
||||
@@ -161,6 +184,13 @@ xmlMutexLock(xmlMutexPtr tok)
|
||||
pthread_mutex_lock(&tok->lock);
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
WaitForSingleObject(tok->mutex, INFINITE);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
if (acquire_sem(tok->sem) != B_NO_ERROR) {
|
||||
#ifdef DEBUG_THREADS
|
||||
xmlGenericError(xmlGenericErrorContext, "xmlMutexLock():BeOS:Couldn't aquire semaphore\n");
|
||||
exit();
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
||||
}
|
||||
@@ -180,6 +210,8 @@ xmlMutexUnlock(xmlMutexPtr tok)
|
||||
pthread_mutex_unlock(&tok->lock);
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
ReleaseMutex(tok->mutex);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
release_sem(tok->sem);
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -208,6 +240,13 @@ xmlNewRMutex(void)
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
InitializeCriticalSection(&tok->cs);
|
||||
tok->count = 0;
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
if ((tok->lock = xmlNewMutex()) == NULL) {
|
||||
free(tok);
|
||||
return NULL;
|
||||
}
|
||||
tok->count = 0;
|
||||
tok->tid = 0;
|
||||
#endif
|
||||
return (tok);
|
||||
}
|
||||
@@ -226,6 +265,8 @@ xmlFreeRMutex(xmlRMutexPtr tok ATTRIBUTE_UNUSED)
|
||||
pthread_mutex_destroy(&tok->lock);
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
DeleteCriticalSection(&tok->cs);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
xmlFreeMutex(tok->lock);
|
||||
#endif
|
||||
free(tok);
|
||||
}
|
||||
@@ -261,6 +302,15 @@ xmlRMutexLock(xmlRMutexPtr tok)
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
EnterCriticalSection(&tok->cs);
|
||||
++tok->count;
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
if (tok->tid == find_thread(NULL)) {
|
||||
tok->count++;
|
||||
return;
|
||||
} else {
|
||||
xmlMutexLock(tok->lock);
|
||||
tok->tid = find_thread(NULL);
|
||||
tok->count = 1;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -287,6 +337,15 @@ xmlRMutexUnlock(xmlRMutexPtr tok ATTRIBUTE_UNUSED)
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
if (!--tok->count)
|
||||
LeaveCriticalSection(&tok->cs);
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
if (tok->tid == find_thread(NULL)) {
|
||||
tok->count--;
|
||||
if (tok->count == 0) {
|
||||
tok->tid = 0;
|
||||
xmlMutexUnlock(tok->lock);
|
||||
}
|
||||
return;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -369,6 +428,15 @@ static CRITICAL_SECTION cleanup_helpers_cs;
|
||||
#endif /* HAVE_COMPILER_TLS */
|
||||
#endif /* HAVE_WIN32_THREADS */
|
||||
|
||||
#if defined HAVE_BEOS_THREADS
|
||||
void xmlGlobalStateCleanup(void *data)
|
||||
{
|
||||
void *globalval = tls_get(globalkey);
|
||||
if (globalval != NULL)
|
||||
xmlFreeGlobalState(globalval);
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* xmlGetGlobalState:
|
||||
*
|
||||
@@ -438,6 +506,20 @@ xmlGetGlobalState(void)
|
||||
}
|
||||
return (globalval);
|
||||
#endif /* HAVE_COMPILER_TLS */
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
xmlGlobalState *globalval;
|
||||
|
||||
xmlOnceInit();
|
||||
|
||||
if ((globalval = (xmlGlobalState *)
|
||||
tls_get(globalkey)) == NULL) {
|
||||
xmlGlobalState *tsd = xmlNewGlobalState();
|
||||
|
||||
tls_set(globalkey, tsd);
|
||||
on_exit_thread(xmlGlobalStateCleanup, NULL);
|
||||
return (tsd);
|
||||
}
|
||||
return (globalval);
|
||||
#else
|
||||
return(NULL);
|
||||
#endif
|
||||
@@ -463,6 +545,8 @@ xmlGetThreadId(void)
|
||||
return((int) pthread_self());
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
return GetCurrentThreadId();
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
return find_thread(NULL);
|
||||
#else
|
||||
return((int) 0);
|
||||
#endif
|
||||
@@ -485,6 +569,8 @@ xmlIsMainThread(void)
|
||||
run_once_init = 0;
|
||||
xmlOnceInit ();
|
||||
}
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
xmlOnceInit();
|
||||
#endif
|
||||
|
||||
#ifdef DEBUG_THREADS
|
||||
@@ -494,6 +580,8 @@ xmlIsMainThread(void)
|
||||
return(mainthread == pthread_self());
|
||||
#elif defined HAVE_WIN32_THREADS
|
||||
return(mainthread == GetCurrentThreadId ());
|
||||
#elif defined HAVE_BEOS_THREADS
|
||||
return(mainthread == find_thread(NULL));
|
||||
#else
|
||||
return(1);
|
||||
#endif
|
||||
@@ -601,6 +689,15 @@ xmlOnceInit(void) {
|
||||
#endif
|
||||
mainthread = GetCurrentThreadId();
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_BEOS_THREADS
|
||||
if (atomic_add(&run_once_init, 1) == 0) {
|
||||
globalkey = tls_allocate();
|
||||
tls_set(globalkey, NULL);
|
||||
mainthread = find_thread(NULL);
|
||||
} else
|
||||
atomic_add(&run_once_init, -1);
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
||||
|
Reference in New Issue
Block a user