Edit

kc3-lang/angle/src/compiler/InitializeDll.cpp

Branch :

  • Show log

    Commit

  • Author : alokp@chromium.org
    Date : 2010-03-22 19:33:14
    Hash : ea0e1af4
    Message : Minor reshuffling of directory structure in preparation of ESSL to GLSL compiler work. 1. Added include/GLSLANG which includes compiler API 2. Deleted src/include and moved the header files to the same directory as the corresponding source files 3. Modied include path to be relative to src/. I have only fixed paths for files I moved. We should fix it for all new files at least. It is much easier to see where an included file is coming from. I noticed that a few libGLESv2 source files include headers from libEGL project, which seems wrong. I think we should address this issue. Next step: move compiler source files to compiler/frontend and create two new projects compiler/glsl_backend and compiler/hlsl_backend. Review URL: http://codereview.appspot.com/662042 git-svn-id: https://angleproject.googlecode.com/svn/trunk@62 736b8ea6-26fd-11df-bfd4-992fa37f6226

  • src/compiler/InitializeDll.cpp
  • //
    // Copyright (c) 2002-2010 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    #include "InitializeDll.h"
    #include "InitializeGlobals.h"
    #include "InitializeParseContext.h"
    
    #include "GLSLANG/ShaderLang.h"
    
    OS_TLSIndex ThreadInitializeIndex = OS_INVALID_TLS_INDEX;
    
    bool InitProcess()
    {
        if (ThreadInitializeIndex != OS_INVALID_TLS_INDEX) {
    		//
    		// Function is re-entrant.
    		//
            return true;
    	}
    
        ThreadInitializeIndex = OS_AllocTLSIndex();
    
        if (ThreadInitializeIndex == OS_INVALID_TLS_INDEX) {
            assert(0 && "InitProcess(): Failed to allocate TLS area for init flag");
            return false;
    	}
    
    
        if (!InitializePoolIndex()) {
            assert(0 && "InitProcess(): Failed to initalize global pool");
            return false;
    	}
    
        if (!InitializeParseContextIndex()) {
            assert(0 && "InitProcess(): Failed to initalize parse context");
            return false;
    	}
    
    	InitThread();
        return true;
    }
    
    
    bool InitThread()
    {
    	//
        // This function is re-entrant
    	//
        if (ThreadInitializeIndex == OS_INVALID_TLS_INDEX) {
    		assert(0 && "InitThread(): Process hasn't been initalised.");
            return false;
    	}
    
        if (OS_GetTLSValue(ThreadInitializeIndex) != 0)
            return true;
    
    	InitializeGlobalPools();
    
    	if (!InitializeGlobalParseContext())
            return false;
    
        if (!OS_SetTLSValue(ThreadInitializeIndex, (void *)1)) {
    		assert(0 && "InitThread(): Unable to set init flag.");
            return false;
    	}
    
        return true;
    }
    
    
    bool DetachThread()
    {
        bool success = true;
    
        if (ThreadInitializeIndex == OS_INVALID_TLS_INDEX)
            return true;
    
    	//
    	// Function is re-entrant and this thread may not have been initalised.
    	//
        if (OS_GetTLSValue(ThreadInitializeIndex) != 0) {
            if (!OS_SetTLSValue(ThreadInitializeIndex, (void *)0)) {
    			assert(0 && "DetachThread(): Unable to clear init flag.");
                success = false;
    		}
    
    		FreeGlobalPools();
    
    		if (!FreeParseContext())
                success = false;
    	}
    
        return success;
    }
    
    bool DetachProcess()
    {
        bool success = true;
    
        if (ThreadInitializeIndex == OS_INVALID_TLS_INDEX)
            return true;
    
        ShFinalize();
    
        success = DetachThread();
    
    	FreePoolIndex();
    
    	if (!FreeParseContextIndex())
            success = false;
    
        OS_FreeTLSIndex(ThreadInitializeIndex);
        ThreadInitializeIndex = OS_INVALID_TLS_INDEX;
    
        return success;
    }