mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			191 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
/*
 | 
						|
    Copyright (c) 2014-2016 Intel Corporation.  All Rights Reserved.
 | 
						|
 | 
						|
    Redistribution and use in source and binary forms, with or without
 | 
						|
    modification, are permitted provided that the following conditions
 | 
						|
    are met:
 | 
						|
 | 
						|
      * Redistributions of source code must retain the above copyright
 | 
						|
        notice, this list of conditions and the following disclaimer.
 | 
						|
      * Redistributions in binary form must reproduce the above copyright
 | 
						|
        notice, this list of conditions and the following disclaimer in the
 | 
						|
        documentation and/or other materials provided with the distribution.
 | 
						|
      * Neither the name of Intel Corporation nor the names of its
 | 
						|
        contributors may be used to endorse or promote products derived
 | 
						|
        from this software without specific prior written permission.
 | 
						|
 | 
						|
    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 | 
						|
    "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | 
						|
    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 | 
						|
    A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 | 
						|
    HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 | 
						|
    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 | 
						|
    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 | 
						|
    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 | 
						|
    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | 
						|
    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | 
						|
    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
						|
*/
 | 
						|
 | 
						|
 | 
						|
#if defined(LINUX) || defined(FREEBSD)
 | 
						|
#include <mm_malloc.h>
 | 
						|
#endif
 | 
						|
 | 
						|
#include "offload_common.h"
 | 
						|
 | 
						|
// The debug routines
 | 
						|
 | 
						|
#if OFFLOAD_DEBUG > 0
 | 
						|
 | 
						|
void __dump_bytes(
 | 
						|
    int trace_level,
 | 
						|
    const void *data,
 | 
						|
    int len
 | 
						|
)
 | 
						|
{
 | 
						|
    if (console_enabled > trace_level) {
 | 
						|
        const uint8_t *arr = (const uint8_t*) data;
 | 
						|
        char buffer[4096];
 | 
						|
        char *bufferp;
 | 
						|
        int count = 0;
 | 
						|
 | 
						|
        bufferp = buffer;
 | 
						|
        while (len--) {
 | 
						|
            sprintf(bufferp, "%02x", *arr++);
 | 
						|
            bufferp += 2;
 | 
						|
            count++;
 | 
						|
            if ((count&3) == 0) {
 | 
						|
                sprintf(bufferp, " ");
 | 
						|
                bufferp++;
 | 
						|
            }
 | 
						|
            if ((count&63) == 0) {
 | 
						|
                OFFLOAD_DEBUG_TRACE(trace_level, "%s\n", buffer);
 | 
						|
                bufferp = buffer;
 | 
						|
                count = 0;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        if (count) {
 | 
						|
            OFFLOAD_DEBUG_TRACE(trace_level, "%s\n", buffer);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
#endif // OFFLOAD_DEBUG
 | 
						|
 | 
						|
// The Marshaller and associated routines
 | 
						|
 | 
						|
void Marshaller::send_data(
 | 
						|
    const void *data,
 | 
						|
    int64_t length
 | 
						|
)
 | 
						|
{
 | 
						|
    OFFLOAD_DEBUG_TRACE(2, "send_data(%p, %lld)\n",
 | 
						|
                        data, length);
 | 
						|
    memcpy(buffer_ptr, data, (size_t)length);
 | 
						|
    buffer_ptr += length;
 | 
						|
    tfr_size += length;
 | 
						|
}
 | 
						|
 | 
						|
void Marshaller::receive_data(
 | 
						|
    void *data,
 | 
						|
    int64_t length
 | 
						|
)
 | 
						|
{
 | 
						|
    OFFLOAD_DEBUG_TRACE(2, "receive_data(%p, %lld)\n",
 | 
						|
                        data, length);
 | 
						|
    memcpy(data, buffer_ptr, (size_t)length);
 | 
						|
    buffer_ptr += length;
 | 
						|
    tfr_size += length;
 | 
						|
}
 | 
						|
 | 
						|
// Send function pointer
 | 
						|
void Marshaller::send_func_ptr(
 | 
						|
    const void* data
 | 
						|
)
 | 
						|
{
 | 
						|
    const char* name;
 | 
						|
    size_t      length;
 | 
						|
 | 
						|
    if (data != 0) {
 | 
						|
        name = __offload_funcs.find_name(data);
 | 
						|
        if (name == 0) {
 | 
						|
#if OFFLOAD_DEBUG > 0
 | 
						|
            if (console_enabled > 2) {
 | 
						|
                __offload_funcs.dump();
 | 
						|
            }
 | 
						|
#endif // OFFLOAD_DEBUG > 0
 | 
						|
 | 
						|
            LIBOFFLOAD_ERROR(c_send_func_ptr, data);
 | 
						|
            exit(1);
 | 
						|
        }
 | 
						|
        length = strlen(name) + 1;
 | 
						|
    }
 | 
						|
    else {
 | 
						|
        name = "";
 | 
						|
        length = 1;
 | 
						|
    }
 | 
						|
 | 
						|
    memcpy(buffer_ptr, name, length);
 | 
						|
    buffer_ptr += length;
 | 
						|
    tfr_size += length;
 | 
						|
}
 | 
						|
 | 
						|
// Receive function pointer
 | 
						|
void Marshaller::receive_func_ptr(
 | 
						|
    const void** data
 | 
						|
)
 | 
						|
{
 | 
						|
    const char* name;
 | 
						|
    size_t      length;
 | 
						|
 | 
						|
    name = (const char*) buffer_ptr;
 | 
						|
    if (name[0] != '\0') {
 | 
						|
        *data = __offload_funcs.find_addr(name);
 | 
						|
        if (*data == 0) {
 | 
						|
#if OFFLOAD_DEBUG > 0
 | 
						|
            if (console_enabled > 2) {
 | 
						|
                __offload_funcs.dump();
 | 
						|
            }
 | 
						|
#endif // OFFLOAD_DEBUG > 0
 | 
						|
 | 
						|
            LIBOFFLOAD_ERROR(c_receive_func_ptr, name);
 | 
						|
            exit(1);
 | 
						|
        }
 | 
						|
        length = strlen(name) + 1;
 | 
						|
    }
 | 
						|
    else {
 | 
						|
        *data = 0;
 | 
						|
        length = 1;
 | 
						|
    }
 | 
						|
 | 
						|
    buffer_ptr += length;
 | 
						|
    tfr_size += length;
 | 
						|
}
 | 
						|
 | 
						|
// End of the Marshaller and associated routines
 | 
						|
 | 
						|
extern void *OFFLOAD_MALLOC(
 | 
						|
    size_t size,
 | 
						|
    size_t align
 | 
						|
)
 | 
						|
{
 | 
						|
    void *ptr;
 | 
						|
    int   err;
 | 
						|
 | 
						|
    OFFLOAD_DEBUG_TRACE(2, "%s(%lld, %lld)\n", __func__, size, align);
 | 
						|
 | 
						|
    if (align < sizeof(void*)) {
 | 
						|
        align = sizeof(void*);
 | 
						|
    }
 | 
						|
 | 
						|
    ptr = _mm_malloc(size, align);
 | 
						|
    if (ptr == NULL) {
 | 
						|
        LIBOFFLOAD_ERROR(c_offload_malloc, size, align);
 | 
						|
        exit(1);
 | 
						|
    }
 | 
						|
 | 
						|
    OFFLOAD_DEBUG_TRACE(2, "%s returned %p\n", __func__, ptr);
 | 
						|
 | 
						|
    return ptr;
 | 
						|
}
 |