/*
- * Copyright 2001-2007 Internet2
+ * Copyright 2001-2010 Internet2
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
class XMLTOOL_DLLLOCAL ThreadImpl : public Thread {
pthread_t thread_id;
public:
- ThreadImpl(void* (*start_routine)(void*), void* arg);
+ ThreadImpl(void* (*start_routine)(void*), void* arg, size_t stacksize);
virtual ~ThreadImpl() {}
int detach() {
};
-ThreadImpl::ThreadImpl(void* (*start_routine)(void*), void* arg)
+ThreadImpl::ThreadImpl(void* (*start_routine)(void*), void* arg, size_t stacksize)
{
- int rc=pthread_create(&thread_id, NULL, start_routine, arg);
+ int rc;
+
+ if (stacksize > 0) {
+ pthread_attr_t attrs;
+ rc = pthread_attr_init(&attrs);
+ if (rc) {
+ Category::getInstance(XMLTOOLING_LOGCAT".Threads").error("pthread_attr_init error (%d)", rc);
+ throw ThreadingException("Thread creation failed.");
+ }
+ rc = pthread_attr_setstacksize(&attrs, stacksize);
+ if (rc) {
+ Category::getInstance(XMLTOOLING_LOGCAT".Threads").error("pthread_attr_setstacksize error (%d)", rc);
+ throw ThreadingException("Thread creation failed.");
+ }
+ rc = pthread_create(&thread_id, &attrs, start_routine, arg);
+ }
+ else {
+ rc = pthread_create(&thread_id, NULL, start_routine, arg);
+ }
if (rc) {
#ifdef HAVE_STRERROR_R
char buf[256];
}
}
-Thread* Thread::create(void* (*start_routine)(void*), void* arg)
+Thread* Thread::create(void* (*start_routine)(void*), void* arg, size_t stacksize)
{
- return new ThreadImpl(start_routine, arg);
+ return new ThreadImpl(start_routine, arg, stacksize);
}
void Thread::exit(void* return_val)
/*
- * Copyright 2001-2009 Internet2
+ * Copyright 2001-2010 Internet2
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
class XMLTOOL_API Thread
{
MAKE_NONCOPYABLE(Thread);
- public:
+ protected:
Thread() {}
+ public:
virtual ~Thread() {}
/**
*
* @param start_routine the function to execute on the thread
* @param arg a parameter for the start routine
+ * @param stacksize size of stack to use, or 0 for default
* @return the created and running thread object
*/
- static Thread* create(void* (*start_routine)(void*), void* arg);
+ static Thread* create(void* (*start_routine)(void*), void* arg, size_t stacksize=0);
/**
* Exits a thread gracefully.
class XMLTOOL_API ThreadKey
{
MAKE_NONCOPYABLE(ThreadKey);
- public:
+ protected:
ThreadKey() {}
+ public:
virtual ~ThreadKey() {}
/**
class XMLTOOL_API Mutex
{
MAKE_NONCOPYABLE(Mutex);
- public:
+ protected:
Mutex() {}
+ public:
virtual ~Mutex() {}
/**
class XMLTOOL_API RWLock
{
MAKE_NONCOPYABLE(RWLock);
- public:
+ protected:
RWLock() {}
+ public:
virtual ~RWLock() {}
/**
class XMLTOOL_API CondWait
{
MAKE_NONCOPYABLE(CondWait);
- public:
+ protected:
CondWait() {}
+ public:
virtual ~CondWait() {}
/**
/*
- * Copyright 2001-2009 Internet2
+ * Copyright 2001-2010 Internet2
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
private:
HANDLE thread_id;
public:
- ThreadImpl(void* (*start_routine)(void*), void* arg) : thread_id(0) {
+ ThreadImpl(void* (*start_routine)(void*), void* arg, size_t stacksize) : thread_id(0) {
thread_id=CreateThread(
0, // security attributes
- 0, // use default stack size, maybe this should be setable
+ stacksize, // 0 just means the default size anyway
(LPTHREAD_START_ROUTINE ) start_routine,
arg,
- 0, // flags, default is ignore stacksize and don't create suspended which is what we want
+ 0, // flags, default is don't create suspended which is what we want
0);
if (thread_id==0) {
map_windows_error_status_to_pthreads();
// public "static" creation functions
//
-Thread* Thread::create(void* (*start_routine)(void*), void* arg)
+Thread* Thread::create(void* (*start_routine)(void*), void* arg, size_t stacksize)
{
- return new ThreadImpl(start_routine, arg);
+ return new ThreadImpl(start_routine, arg, stacksize);
}
void Thread::exit(void* return_val)