-/*
- * Copyright 2001-2007 Internet2
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
+/**
+ * Licensed to the University Corporation for Advanced Internet
+ * Development, Inc. (UCAID) under one or more contributor license
+ * agreements. See the NOTICE file distributed with this work for
+ * additional information regarding copyright ownership.
*
- * http://www.apache.org/licenses/LICENSE-2.0
+ * UCAID licenses this file to you under the Apache License,
+ * Version 2.0 (the "License"); you may not use this file except
+ * in compliance with the License. You may obtain a copy of the
+ * License at
*
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
+ * either express or implied. See the License for the specific
+ * language governing permissions and limitations under the License.
*/
/**
*/
#include "internal.h"
+#include "logging.h"
#include "util/Threads.h"
#include <ctime>
#include <signal.h>
-#include <log4cpp/Category.hh>
#ifdef HAVE_PTHREAD
# include <pthread.h>
# error "This implementation is for POSIX platforms."
#endif
+using namespace xmltooling::logging;
using namespace xmltooling;
-using namespace log4cpp;
using namespace std;
namespace xmltooling {
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() {
int timedwait(MutexImpl* mutex, int delay_seconds) {
struct timespec ts;
memset(&ts, 0, sizeof(ts));
- ts.tv_sec = time(NULL) + delay_seconds;
+ ts.tv_sec = time(nullptr) + delay_seconds;
return pthread_cond_timedwait(&cond, &(mutex->mutex), &ts);
}
};
-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, nullptr, start_routine, arg);
+ }
if (rc) {
#ifdef HAVE_STRERROR_R
char buf[256];
MutexImpl::MutexImpl()
{
- int rc=pthread_mutex_init(&mutex, NULL);
+ int rc=pthread_mutex_init(&mutex, nullptr);
if (rc) {
#ifdef HAVE_STRERROR_R
char buf[256];
CondWaitImpl::CondWaitImpl()
{
- int rc=pthread_cond_init(&cond, NULL);
+ int rc=pthread_cond_init(&cond, nullptr);
if (rc) {
#ifdef HAVE_STRERROR_R
char buf[256];
RWLockImpl::RWLockImpl()
{
#ifdef HAVE_PTHREAD_RWLOCK_INIT
- int rc=pthread_rwlock_init(&lock, NULL);
+ int rc=pthread_rwlock_init(&lock, nullptr);
#else
- int rc=rwlock_init(&lock, USYNC_THREAD, NULL);
+ int rc=rwlock_init(&lock, USYNC_THREAD, nullptr);
#endif
if (rc) {
#ifdef HAVE_STRERROR_R
}
}
-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)
{
sigset_t sigmask;
sigfillset(&sigmask);
- Thread::mask_signals(SIG_BLOCK, &sigmask, NULL);
+ Thread::mask_signals(SIG_BLOCK, &sigmask, nullptr);
}
int Thread::mask_signals(int how, const sigset_t *newmask, sigset_t *oldmask)