2796N/A/*
2796N/A * Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved.
2796N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2796N/A *
2796N/A * This code is free software; you can redistribute it and/or modify it
2796N/A * under the terms of the GNU General Public License version 2 only, as
2796N/A * published by the Free Software Foundation.
2796N/A *
2796N/A * This code is distributed in the hope that it will be useful, but WITHOUT
2796N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2796N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
2796N/A * version 2 for more details (a copy is included in the LICENSE file that
2796N/A * accompanied this code).
2796N/A *
2796N/A * You should have received a copy of the GNU General Public License version
2796N/A * 2 along with this work; if not, write to the Free Software Foundation,
2796N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2796N/A *
2796N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2796N/A * or visit www.oracle.com if you need additional information or have any
2796N/A * questions.
2796N/A *
2796N/A */
2796N/A
2796N/A#include "precompiled.hpp"
2796N/A#include "runtime/threadCritical.hpp"
2796N/A#include "thread_bsd.inline.hpp"
2796N/A
2796N/A// put OS-includes here
2796N/A# include <pthread.h>
2796N/A
2796N/A//
2796N/A// See threadCritical.hpp for details of this class.
2796N/A//
2796N/A
2796N/Astatic pthread_t tc_owner = 0;
2796N/Astatic pthread_mutex_t tc_mutex = PTHREAD_MUTEX_INITIALIZER;
2796N/Astatic int tc_count = 0;
2796N/A
2796N/Avoid ThreadCritical::initialize() {
2796N/A}
2796N/A
2796N/Avoid ThreadCritical::release() {
2796N/A}
2796N/A
2796N/AThreadCritical::ThreadCritical() {
2796N/A pthread_t self = pthread_self();
2796N/A if (self != tc_owner) {
2796N/A int ret = pthread_mutex_lock(&tc_mutex);
2796N/A guarantee(ret == 0, "fatal error with pthread_mutex_lock()");
2796N/A assert(tc_count == 0, "Lock acquired with illegal reentry count.");
2796N/A tc_owner = self;
2796N/A }
2796N/A tc_count++;
2796N/A}
2796N/A
2796N/AThreadCritical::~ThreadCritical() {
2796N/A assert(tc_owner == pthread_self(), "must have correct owner");
2796N/A assert(tc_count > 0, "must have correct count");
2796N/A
2796N/A tc_count--;
2796N/A if (tc_count == 0) {
2796N/A tc_owner = 0;
2796N/A int ret = pthread_mutex_unlock(&tc_mutex);
2796N/A guarantee(ret == 0, "fatal error with pthread_mutex_unlock()");
2796N/A }
2796N/A}