mirror of https://github.com/GOSTSec/sgminer
R4SAS
7 years ago
37 changed files with 24743 additions and 0 deletions
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
///
|
||||
/// Copyright (c) 2008 - 2013 Advanced Micro Devices, Inc.
|
||||
|
||||
/// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
|
||||
/// EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
|
||||
/// WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
|
||||
|
||||
/// \file adl_sdk.h
|
||||
/// \brief Contains the definition of the Memory Allocation Callback.\n <b>Included in ADL SDK</b>
|
||||
///
|
||||
/// \n\n
|
||||
/// This file contains the definition of the Memory Allocation Callback.\n
|
||||
/// It also includes definitions of the respective structures and constants.\n
|
||||
/// <b> This is the only header file to be included in a C/C++ project using ADL </b>
|
||||
|
||||
#ifndef ADL_SDK_H_ |
||||
#define ADL_SDK_H_ |
||||
|
||||
#include "adl_structures.h" |
||||
|
||||
#if defined (LINUX) |
||||
#define __stdcall |
||||
#endif /* (LINUX) */ |
||||
|
||||
/// Memory Allocation Call back
|
||||
typedef void* ( __stdcall *ADL_MAIN_MALLOC_CALLBACK )( int ); |
||||
|
||||
|
||||
#endif /* ADL_SDK_H_ */ |
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,126 @@
@@ -0,0 +1,126 @@
|
||||
/**********************************************************************************
|
||||
* Copyright (c) 2008-2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
**********************************************************************************/ |
||||
|
||||
/* $Revision: 11708 $ on $Date: 2010-06-13 23:36:24 -0700 (Sun, 13 Jun 2010) $ */ |
||||
|
||||
#ifndef __OPENCL_CL_D3D10_H |
||||
#define __OPENCL_CL_D3D10_H |
||||
|
||||
#include <d3d10.h> |
||||
#include <CL/cl.h> |
||||
#include <CL/cl_platform.h> |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
/******************************************************************************
|
||||
* cl_khr_d3d10_sharing */ |
||||
#define cl_khr_d3d10_sharing 1 |
||||
|
||||
typedef cl_uint cl_d3d10_device_source_khr; |
||||
typedef cl_uint cl_d3d10_device_set_khr; |
||||
|
||||
/******************************************************************************/ |
||||
|
||||
// Error Codes
|
||||
#define CL_INVALID_D3D10_DEVICE_KHR -1002 |
||||
#define CL_INVALID_D3D10_RESOURCE_KHR -1003 |
||||
#define CL_D3D10_RESOURCE_ALREADY_ACQUIRED_KHR -1004 |
||||
#define CL_D3D10_RESOURCE_NOT_ACQUIRED_KHR -1005 |
||||
|
||||
// cl_d3d10_device_source_nv
|
||||
#define CL_D3D10_DEVICE_KHR 0x4010 |
||||
#define CL_D3D10_DXGI_ADAPTER_KHR 0x4011 |
||||
|
||||
// cl_d3d10_device_set_nv
|
||||
#define CL_PREFERRED_DEVICES_FOR_D3D10_KHR 0x4012 |
||||
#define CL_ALL_DEVICES_FOR_D3D10_KHR 0x4013 |
||||
|
||||
// cl_context_info
|
||||
#define CL_CONTEXT_D3D10_DEVICE_KHR 0x4014 |
||||
#define CL_CONTEXT_D3D10_PREFER_SHARED_RESOURCES_KHR 0x402C |
||||
|
||||
// cl_mem_info
|
||||
#define CL_MEM_D3D10_RESOURCE_KHR 0x4015 |
||||
|
||||
// cl_image_info
|
||||
#define CL_IMAGE_D3D10_SUBRESOURCE_KHR 0x4016 |
||||
|
||||
// cl_command_type
|
||||
#define CL_COMMAND_ACQUIRE_D3D10_OBJECTS_KHR 0x4017 |
||||
#define CL_COMMAND_RELEASE_D3D10_OBJECTS_KHR 0x4018 |
||||
|
||||
/******************************************************************************/ |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clGetDeviceIDsFromD3D10KHR_fn)( |
||||
cl_platform_id platform, |
||||
cl_d3d10_device_source_khr d3d_device_source, |
||||
void * d3d_object, |
||||
cl_d3d10_device_set_khr d3d_device_set, |
||||
cl_uint num_entries, |
||||
cl_device_id * devices, |
||||
cl_uint * num_devices) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D10BufferKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D10Buffer * resource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D10Texture2DKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D10Texture2D * resource, |
||||
UINT subresource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D10Texture3DKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D10Texture3D * resource, |
||||
UINT subresource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueAcquireD3D10ObjectsKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueReleaseD3D10ObjectsKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif // __OPENCL_CL_D3D10_H
|
||||
|
@ -0,0 +1,126 @@
@@ -0,0 +1,126 @@
|
||||
/**********************************************************************************
|
||||
* Copyright (c) 2008-2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
**********************************************************************************/ |
||||
|
||||
/* $Revision: 11708 $ on $Date: 2010-06-13 23:36:24 -0700 (Sun, 13 Jun 2010) $ */ |
||||
|
||||
#ifndef __OPENCL_CL_D3D11_H |
||||
#define __OPENCL_CL_D3D11_H |
||||
|
||||
#include <d3d11.h> |
||||
#include <CL/cl.h> |
||||
#include <CL/cl_platform.h> |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
/******************************************************************************
|
||||
* cl_khr_d3d11_sharing */ |
||||
#define cl_khr_d3d11_sharing 1 |
||||
|
||||
typedef cl_uint cl_d3d11_device_source_khr; |
||||
typedef cl_uint cl_d3d11_device_set_khr; |
||||
|
||||
/******************************************************************************/ |
||||
|
||||
// Error Codes
|
||||
#define CL_INVALID_D3D11_DEVICE_KHR -1006 |
||||
#define CL_INVALID_D3D11_RESOURCE_KHR -1007 |
||||
#define CL_D3D11_RESOURCE_ALREADY_ACQUIRED_KHR -1008 |
||||
#define CL_D3D11_RESOURCE_NOT_ACQUIRED_KHR -1009 |
||||
|
||||
// cl_d3d11_device_source
|
||||
#define CL_D3D11_DEVICE_KHR 0x4019 |
||||
#define CL_D3D11_DXGI_ADAPTER_KHR 0x401A |
||||
|
||||
// cl_d3d11_device_set
|
||||
#define CL_PREFERRED_DEVICES_FOR_D3D11_KHR 0x401B |
||||
#define CL_ALL_DEVICES_FOR_D3D11_KHR 0x401C |
||||
|
||||
// cl_context_info
|
||||
#define CL_CONTEXT_D3D11_DEVICE_KHR 0x401D |
||||
#define CL_CONTEXT_D3D11_PREFER_SHARED_RESOURCES_KHR 0x402D |
||||
|
||||
// cl_mem_info
|
||||
#define CL_MEM_D3D11_RESOURCE_KHR 0x401E |
||||
|
||||
// cl_image_info
|
||||
#define CL_IMAGE_D3D11_SUBRESOURCE_KHR 0x401F |
||||
|
||||
// cl_command_type
|
||||
#define CL_COMMAND_ACQUIRE_D3D11_OBJECTS_KHR 0x4020 |
||||
#define CL_COMMAND_RELEASE_D3D11_OBJECTS_KHR 0x4021 |
||||
|
||||
/******************************************************************************/ |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clGetDeviceIDsFromD3D11KHR_fn)( |
||||
cl_platform_id platform, |
||||
cl_d3d11_device_source_khr d3d_device_source, |
||||
void * d3d_object, |
||||
cl_d3d11_device_set_khr d3d_device_set, |
||||
cl_uint num_entries, |
||||
cl_device_id * devices, |
||||
cl_uint * num_devices) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D11BufferKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D11Buffer * resource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D11Texture2DKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D11Texture2D * resource, |
||||
UINT subresource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromD3D11Texture3DKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
ID3D11Texture3D * resource, |
||||
UINT subresource, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueAcquireD3D11ObjectsKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueReleaseD3D11ObjectsKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif // __OPENCL_CL_D3D11_H
|
||||
|
@ -0,0 +1,127 @@
@@ -0,0 +1,127 @@
|
||||
/**********************************************************************************
|
||||
* Copyright (c) 2008-2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
**********************************************************************************/ |
||||
|
||||
/* $Revision: 11708 $ on $Date: 2010-06-13 23:36:24 -0700 (Sun, 13 Jun 2010) $ */ |
||||
|
||||
#ifndef __OPENCL_CL_DX9_MEDIA_SHARING_H |
||||
#define __OPENCL_CL_DX9_MEDIA_SHARING_H |
||||
|
||||
#include <CL/cl.h> |
||||
#include <CL/cl_platform.h> |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
/******************************************************************************
|
||||
/* cl_khr_dx9_media_sharing */ |
||||
#define cl_khr_dx9_media_sharing 1 |
||||
|
||||
typedef cl_uint cl_dx9_media_adapter_type_khr; |
||||
typedef cl_uint cl_dx9_media_adapter_set_khr; |
||||
|
||||
#if defined(_WIN32) |
||||
#include <d3d9.h> |
||||
typedef struct _cl_dx9_surface_info_khr |
||||
{ |
||||
IDirect3DSurface9 *resource; |
||||
HANDLE shared_handle; |
||||
} cl_dx9_surface_info_khr; |
||||
#endif |
||||
|
||||
|
||||
/******************************************************************************/ |
||||
|
||||
// Error Codes
|
||||
#define CL_INVALID_DX9_MEDIA_ADAPTER_KHR -1010 |
||||
#define CL_INVALID_DX9_MEDIA_SURFACE_KHR -1011 |
||||
#define CL_DX9_MEDIA_SURFACE_ALREADY_ACQUIRED_KHR -1012 |
||||
#define CL_DX9_MEDIA_SURFACE_NOT_ACQUIRED_KHR -1013 |
||||
|
||||
// cl_media_adapter_type_khr
|
||||
#define CL_ADAPTER_D3D9_KHR 0x2020 |
||||
#define CL_ADAPTER_D3D9EX_KHR 0x2021 |
||||
#define CL_ADAPTER_DXVA_KHR 0x2022 |
||||
|
||||
// cl_media_adapter_set_khr
|
||||
#define CL_PREFERRED_DEVICES_FOR_DX9_MEDIA_ADAPTER_KHR 0x2023 |
||||
#define CL_ALL_DEVICES_FOR_DX9_MEDIA_ADAPTER_KHR 0x2024 |
||||
|
||||
// cl_context_info
|
||||
#define CL_CONTEXT_ADAPTER_D3D9_KHR 0x2025 |
||||
#define CL_CONTEXT_ADAPTER_D3D9EX_KHR 0x2026 |
||||
#define CL_CONTEXT_ADAPTER_DXVA_KHR 0x2027 |
||||
|
||||
// cl_mem_info
|
||||
#define CL_MEM_DX9_MEDIA_ADAPTER_TYPE_KHR 0x2028 |
||||
#define CL_MEM_DX9_MEDIA_SURFACE_INFO_KHR 0x2029 |
||||
|
||||
// cl_image_info
|
||||
#define CL_IMAGE_DX9_MEDIA_PLANE_KHR 0x202A |
||||
|
||||
// cl_command_type
|
||||
#define CL_COMMAND_ACQUIRE_DX9_MEDIA_SURFACES_KHR 0x202B |
||||
#define CL_COMMAND_RELEASE_DX9_MEDIA_SURFACES_KHR 0x202C |
||||
|
||||
/******************************************************************************/ |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clGetDeviceIDsFromDX9MediaAdapterKHR_fn)( |
||||
cl_platform_id platform, |
||||
cl_uint num_media_adapters, |
||||
cl_dx9_media_adapter_type_khr * media_adapter_type, |
||||
void * media_adapters, |
||||
cl_dx9_media_adapter_set_khr media_adapter_set, |
||||
cl_uint num_entries, |
||||
cl_device_id * devices, |
||||
cl_uint * num_devices) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_mem (CL_API_CALL *clCreateFromDX9MediaSurfaceKHR_fn)( |
||||
cl_context context, |
||||
cl_mem_flags flags, |
||||
cl_dx9_media_adapter_type_khr adapter_type, |
||||
void * surface_info, |
||||
cl_uint plane, |
||||
cl_int * errcode_ret) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueAcquireDX9MediaSurfacesKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clEnqueueReleaseDX9MediaSurfacesKHR_fn)( |
||||
cl_command_queue command_queue, |
||||
cl_uint num_objects, |
||||
const cl_mem * mem_objects, |
||||
cl_uint num_events_in_wait_list, |
||||
const cl_event * event_wait_list, |
||||
cl_event * event) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif // __OPENCL_CL_DX9_MEDIA_SHARING_H
|
||||
|
@ -0,0 +1,533 @@
@@ -0,0 +1,533 @@
|
||||
/*******************************************************************************
|
||||
* Copyright (c) 2008-2013 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
******************************************************************************/ |
||||
|
||||
/* $Revision: 14835 $ on $Date: 2011-05-26 11:32:00 -0700 (Thu, 26 May 2011) $ */ |
||||
|
||||
/* cl_ext.h contains OpenCL extensions which don't have external */ |
||||
/* (OpenGL, D3D) dependencies. */ |
||||
|
||||
#ifndef __CL_EXT_H |
||||
#define __CL_EXT_H |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
#ifdef __APPLE__ |
||||
#include <OpenCL/cl.h> |
||||
#include <AvailabilityMacros.h> |
||||
#else |
||||
#include <CL/cl.h> |
||||
#endif |
||||
|
||||
/* cl_khr_fp16 extension - no extension #define since it has no functions */ |
||||
#define CL_DEVICE_HALF_FP_CONFIG 0x1033 |
||||
|
||||
/* Memory object destruction
|
||||
* |
||||
* Apple extension for use to manage externally allocated buffers used with cl_mem objects with CL_MEM_USE_HOST_PTR |
||||
* |
||||
* Registers a user callback function that will be called when the memory object is deleted and its resources |
||||
* freed. Each call to clSetMemObjectCallbackFn registers the specified user callback function on a callback |
||||
* stack associated with memobj. The registered user callback functions are called in the reverse order in |
||||
* which they were registered. The user callback functions are called and then the memory object is deleted |
||||
* and its resources freed. This provides a mechanism for the application (and libraries) using memobj to be |
||||
* notified when the memory referenced by host_ptr, specified when the memory object is created and used as |
||||
* the storage bits for the memory object, can be reused or freed. |
||||
* |
||||
* The application may not call CL api's with the cl_mem object passed to the pfn_notify. |
||||
* |
||||
* Please check for the "cl_APPLE_SetMemObjectDestructor" extension using clGetDeviceInfo(CL_DEVICE_EXTENSIONS) |
||||
* before using. |
||||
*/ |
||||
#define cl_APPLE_SetMemObjectDestructor 1 |
||||
cl_int CL_API_ENTRY clSetMemObjectDestructorAPPLE( cl_mem /* memobj */, |
||||
void (* /*pfn_notify*/)( cl_mem /* memobj */, void* /*user_data*/), |
||||
void * /*user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; |
||||
|
||||
|
||||
/* Context Logging Functions
|
||||
* |
||||
* The next three convenience functions are intended to be used as the pfn_notify parameter to clCreateContext(). |
||||
* Please check for the "cl_APPLE_ContextLoggingFunctions" extension using clGetDeviceInfo(CL_DEVICE_EXTENSIONS) |
||||
* before using. |
||||
* |
||||
* clLogMessagesToSystemLog fowards on all log messages to the Apple System Logger |
||||
*/ |
||||
#define cl_APPLE_ContextLoggingFunctions 1 |
||||
extern void CL_API_ENTRY clLogMessagesToSystemLogAPPLE( const char * /* errstr */, |
||||
const void * /* private_info */, |
||||
size_t /* cb */, |
||||
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; |
||||
|
||||
/* clLogMessagesToStdout sends all log messages to the file descriptor stdout */ |
||||
extern void CL_API_ENTRY clLogMessagesToStdoutAPPLE( const char * /* errstr */, |
||||
const void * /* private_info */, |
||||
size_t /* cb */, |
||||
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; |
||||
|
||||
/* clLogMessagesToStderr sends all log messages to the file descriptor stderr */ |
||||
extern void CL_API_ENTRY clLogMessagesToStderrAPPLE( const char * /* errstr */, |
||||
const void * /* private_info */, |
||||
size_t /* cb */, |
||||
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; |
||||
|
||||
|
||||
/************************
|
||||
* cl_khr_icd extension * |
||||
************************/ |
||||
#define cl_khr_icd 1 |
||||
|
||||
/* cl_platform_info */ |
||||
#define CL_PLATFORM_ICD_SUFFIX_KHR 0x0920 |
||||
|
||||
/* Additional Error Codes */ |
||||
#define CL_PLATFORM_NOT_FOUND_KHR -1001 |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clIcdGetPlatformIDsKHR(cl_uint /* num_entries */, |
||||
cl_platform_id * /* platforms */, |
||||
cl_uint * /* num_platforms */); |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clIcdGetPlatformIDsKHR_fn)( |
||||
cl_uint /* num_entries */, |
||||
cl_platform_id * /* platforms */, |
||||
cl_uint * /* num_platforms */); |
||||
|
||||
|
||||
/* Extension: cl_khr_image2D_buffer
|
||||
* |
||||
* This extension allows a 2D image to be created from a cl_mem buffer without a copy. |
||||
* The type associated with a 2D image created from a buffer in an OpenCL program is image2d_t. |
||||
* Both the sampler and sampler-less read_image built-in functions are supported for 2D images |
||||
* and 2D images created from a buffer. Similarly, the write_image built-ins are also supported |
||||
* for 2D images created from a buffer. |
||||
* |
||||
* When the 2D image from buffer is created, the client must specify the width, |
||||
* height, image format (i.e. channel order and channel data type) and optionally the row pitch |
||||
* |
||||
* The pitch specified must be a multiple of CL_DEVICE_IMAGE_PITCH_ALIGNMENT pixels. |
||||
* The base address of the buffer must be aligned to CL_DEVICE_IMAGE_BASE_ADDRESS_ALIGNMENT pixels. |
||||
*/ |
||||
|
||||
/*************************************
|
||||
* cl_khr_initalize_memory extension * |
||||
*************************************/ |
||||
|
||||
#define CL_CONTEXT_MEMORY_INITIALIZE_KHR 0x200E |
||||
|
||||
|
||||
/**************************************
|
||||
* cl_khr_terminate_context extension * |
||||
**************************************/ |
||||
|
||||
#define CL_DEVICE_TERMINATE_CAPABILITY_KHR 0x200F |
||||
#define CL_CONTEXT_TERMINATE_KHR 0x2010 |
||||
|
||||
#define cl_khr_terminate_context 1 |
||||
extern CL_API_ENTRY cl_int CL_API_CALL clTerminateContextKHR(cl_context /* context */) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clTerminateContextKHR_fn)(cl_context /* context */) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
|
||||
/*
|
||||
* Extension: cl_khr_spir |
||||
* |
||||
* This extension adds support to create an OpenCL program object from a |
||||
* Standard Portable Intermediate Representation (SPIR) instance |
||||
*/ |
||||
|
||||
// KHR SPIR extension (Section 9.15.2 in the extension SPEC)
|
||||
// TODO: The values have been approved by khronos and waiting to be updated in official header file.
|
||||
#define CL_DEVICE_SPIR_VERSIONS 0x40E0 |
||||
#define CL_PROGRAM_BINARY_TYPE_INTERMEDIATE 0x40E1 |
||||
|
||||
/******************************************
|
||||
* cl_nv_device_attribute_query extension * |
||||
******************************************/ |
||||
/* cl_nv_device_attribute_query extension - no extension #define since it has no functions */ |
||||
#define CL_DEVICE_COMPUTE_CAPABILITY_MAJOR_NV 0x4000 |
||||
#define CL_DEVICE_COMPUTE_CAPABILITY_MINOR_NV 0x4001 |
||||
#define CL_DEVICE_REGISTERS_PER_BLOCK_NV 0x4002 |
||||
#define CL_DEVICE_WARP_SIZE_NV 0x4003 |
||||
#define CL_DEVICE_GPU_OVERLAP_NV 0x4004 |
||||
#define CL_DEVICE_KERNEL_EXEC_TIMEOUT_NV 0x4005 |
||||
#define CL_DEVICE_INTEGRATED_MEMORY_NV 0x4006 |
||||
|
||||
/*********************************
|
||||
* cl_amd_device_memory_flags * |
||||
*********************************/ |
||||
#define cl_amd_device_memory_flags 1 |
||||
#define CL_MEM_USE_PERSISTENT_MEM_AMD (1 << 6) // Alloc from GPU's CPU visible heap
|
||||
|
||||
/* cl_device_info */ |
||||
#define CL_DEVICE_MAX_ATOMIC_COUNTERS_EXT 0x4032 |
||||
|
||||
/*********************************
|
||||
* cl_amd_device_attribute_query * |
||||
*********************************/ |
||||
#define CL_DEVICE_PROFILING_TIMER_OFFSET_AMD 0x4036 |
||||
#define CL_DEVICE_TOPOLOGY_AMD 0x4037 |
||||
#define CL_DEVICE_BOARD_NAME_AMD 0x4038 |
||||
#define CL_DEVICE_GLOBAL_FREE_MEMORY_AMD 0x4039 |
||||
#define CL_DEVICE_SIMD_PER_COMPUTE_UNIT_AMD 0x4040 |
||||
#define CL_DEVICE_SIMD_WIDTH_AMD 0x4041 |
||||
#define CL_DEVICE_SIMD_INSTRUCTION_WIDTH_AMD 0x4042 |
||||
#define CL_DEVICE_WAVEFRONT_WIDTH_AMD 0x4043 |
||||
#define CL_DEVICE_GLOBAL_MEM_CHANNELS_AMD 0x4044 |
||||
#define CL_DEVICE_GLOBAL_MEM_CHANNEL_BANKS_AMD 0x4045 |
||||
#define CL_DEVICE_GLOBAL_MEM_CHANNEL_BANK_WIDTH_AMD 0x4046 |
||||
#define CL_DEVICE_LOCAL_MEM_SIZE_PER_COMPUTE_UNIT_AMD 0x4047 |
||||
#define CL_DEVICE_LOCAL_MEM_BANKS_AMD 0x4048 |
||||
#define CL_DEVICE_THREAD_TRACE_SUPPORTED_AMD 0x4049 |
||||
#define CL_DEVICE_GFXIP_MAJOR_AMD 0x404A |
||||
#define CL_DEVICE_GFXIP_MINOR_AMD 0x404B |
||||
|
||||
typedef union |
||||
{ |
||||
struct { cl_uint type; cl_uint data[5]; } raw; |
||||
struct { cl_uint type; cl_char unused[17]; cl_char bus; cl_char device; cl_char function; } pcie; |
||||
} cl_device_topology_amd; |
||||
|
||||
#define CL_DEVICE_TOPOLOGY_TYPE_PCIE_AMD 1 |
||||
|
||||
/*************
|
||||
* cl_amd_hsa * |
||||
**************/ |
||||
#define CL_HSA_ENABLED_AMD (1ull << 62) |
||||
#define CL_HSA_DISABLED_AMD (1ull << 63) |
||||
|
||||
|
||||
/**************************
|
||||
* cl_amd_offline_devices * |
||||
**************************/ |
||||
#define CL_CONTEXT_OFFLINE_DEVICES_AMD 0x403F |
||||
|
||||
#ifdef CL_VERSION_1_1 |
||||
/***********************************
|
||||
* cl_ext_device_fission extension * |
||||
***********************************/ |
||||
#define cl_ext_device_fission 1 |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clReleaseDeviceEXT( cl_device_id /*device*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL *clReleaseDeviceEXT_fn)( cl_device_id /*device*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clRetainDeviceEXT( cl_device_id /*device*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL *clRetainDeviceEXT_fn)( cl_device_id /*device*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
typedef cl_ulong cl_device_partition_property_ext; |
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clCreateSubDevicesEXT( cl_device_id /*in_device*/, |
||||
const cl_device_partition_property_ext * /* properties */, |
||||
cl_uint /*num_entries*/, |
||||
cl_device_id * /*out_devices*/, |
||||
cl_uint * /*num_devices*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
( CL_API_CALL * clCreateSubDevicesEXT_fn)( cl_device_id /*in_device*/, |
||||
const cl_device_partition_property_ext * /* properties */, |
||||
cl_uint /*num_entries*/, |
||||
cl_device_id * /*out_devices*/, |
||||
cl_uint * /*num_devices*/ ) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
/* cl_device_partition_property_ext */ |
||||
#define CL_DEVICE_PARTITION_EQUALLY_EXT 0x4050 |
||||
#define CL_DEVICE_PARTITION_BY_COUNTS_EXT 0x4051 |
||||
#define CL_DEVICE_PARTITION_BY_NAMES_EXT 0x4052 |
||||
#define CL_DEVICE_PARTITION_BY_AFFINITY_DOMAIN_EXT 0x4053 |
||||
|
||||
/* clDeviceGetInfo selectors */ |
||||
#define CL_DEVICE_PARENT_DEVICE_EXT 0x4054 |
||||
#define CL_DEVICE_PARTITION_TYPES_EXT 0x4055 |
||||
#define CL_DEVICE_AFFINITY_DOMAINS_EXT 0x4056 |
||||
#define CL_DEVICE_REFERENCE_COUNT_EXT 0x4057 |
||||
#define CL_DEVICE_PARTITION_STYLE_EXT 0x4058 |
||||
|
||||
/* clGetImageInfo enum */ |
||||
#define CL_IMAGE_BYTE_PITCH_AMD 0x4059 |
||||
|
||||
/* error codes */ |
||||
#define CL_DEVICE_PARTITION_FAILED_EXT -1057 |
||||
#define CL_INVALID_PARTITION_COUNT_EXT -1058 |
||||
#define CL_INVALID_PARTITION_NAME_EXT -1059 |
||||
|
||||
/* CL_AFFINITY_DOMAINs */ |
||||
#define CL_AFFINITY_DOMAIN_L1_CACHE_EXT 0x1 |
||||
#define CL_AFFINITY_DOMAIN_L2_CACHE_EXT 0x2 |
||||
#define CL_AFFINITY_DOMAIN_L3_CACHE_EXT 0x3 |
||||
#define CL_AFFINITY_DOMAIN_L4_CACHE_EXT 0x4 |
||||
#define CL_AFFINITY_DOMAIN_NUMA_EXT 0x10 |
||||
#define CL_AFFINITY_DOMAIN_NEXT_FISSIONABLE_EXT 0x100 |
||||
/* cl_device_partition_property_ext list terminators */ |
||||
#define CL_PROPERTIES_LIST_END_EXT ((cl_device_partition_property_ext) 0) |
||||
#define CL_PARTITION_BY_COUNTS_LIST_END_EXT ((cl_device_partition_property_ext) 0) |
||||
#define CL_PARTITION_BY_NAMES_LIST_END_EXT ((cl_device_partition_property_ext) 0 - 1) |
||||
|
||||
/*********************************
|
||||
* cl_qcom_ext_host_ptr extension |
||||
*********************************/ |
||||
|
||||
#define CL_MEM_EXT_HOST_PTR_QCOM (1 << 29) |
||||
|
||||
#define CL_DEVICE_EXT_MEM_PADDING_IN_BYTES_QCOM 0x40A0 |
||||
#define CL_DEVICE_PAGE_SIZE_QCOM 0x40A1 |
||||
#define CL_IMAGE_ROW_ALIGNMENT_QCOM 0x40A2 |
||||
#define CL_IMAGE_SLICE_ALIGNMENT_QCOM 0x40A3 |
||||
#define CL_MEM_HOST_UNCACHED_QCOM 0x40A4 |
||||
#define CL_MEM_HOST_WRITEBACK_QCOM 0x40A5 |
||||
#define CL_MEM_HOST_WRITETHROUGH_QCOM 0x40A6 |
||||
#define CL_MEM_HOST_WRITE_COMBINING_QCOM 0x40A7 |
||||
|
||||
typedef cl_uint cl_image_pitch_info_qcom; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clGetDeviceImageInfoQCOM(cl_device_id device, |
||||
size_t image_width, |
||||
size_t image_height, |
||||
const cl_image_format *image_format, |
||||
cl_image_pitch_info_qcom param_name, |
||||
size_t param_value_size, |
||||
void *param_value, |
||||
size_t *param_value_size_ret); |
||||
|
||||
typedef struct _cl_mem_ext_host_ptr |
||||
{ |
||||
// Type of external memory allocation.
|
||||
// Legal values will be defined in layered extensions.
|
||||
cl_uint allocation_type; |
||||
|
||||
// Host cache policy for this external memory allocation.
|
||||
cl_uint host_cache_policy; |
||||
|
||||
} cl_mem_ext_host_ptr; |
||||
|
||||
/*********************************
|
||||
* cl_qcom_ion_host_ptr extension |
||||
*********************************/ |
||||
|
||||
#define CL_MEM_ION_HOST_PTR_QCOM 0x40A8 |
||||
|
||||
typedef struct _cl_mem_ion_host_ptr |
||||
{ |
||||
// Type of external memory allocation.
|
||||
// Must be CL_MEM_ION_HOST_PTR_QCOM for ION allocations.
|
||||
cl_mem_ext_host_ptr ext_host_ptr; |
||||
|
||||
// ION file descriptor
|
||||
int ion_filedesc; |
||||
|
||||
// Host pointer to the ION allocated memory
|
||||
void* ion_hostptr; |
||||
|
||||
} cl_mem_ion_host_ptr; |
||||
|
||||
#endif /* CL_VERSION_1_1 */ |
||||
|
||||
#ifdef CL_VERSION_1_2 |
||||
/********************************
|
||||
* cl_amd_bus_addressable_memory * |
||||
********************************/ |
||||
|
||||
/* cl_mem flag - bitfield */ |
||||
#define CL_MEM_BUS_ADDRESSABLE_AMD (1<<30) |
||||
#define CL_MEM_EXTERNAL_PHYSICAL_AMD (1<<31) |
||||
|
||||
#define CL_COMMAND_WAIT_SIGNAL_AMD 0x4080 |
||||
#define CL_COMMAND_WRITE_SIGNAL_AMD 0x4081 |
||||
#define CL_COMMAND_MAKE_BUFFERS_RESIDENT_AMD 0x4082 |
||||
|
||||
typedef struct _cl_bus_address_amd |
||||
{ |
||||
cl_ulong surface_bus_address; |
||||
cl_ulong marker_bus_address; |
||||
} cl_bus_address_amd; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueWaitSignalAMD_fn)( cl_command_queue /*command_queue*/, |
||||
cl_mem /*mem_object*/, |
||||
cl_uint /*value*/, |
||||
cl_uint /*num_events*/, |
||||
const cl_event * /*event_wait_list*/, |
||||
cl_event * /*event*/) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueWriteSignalAMD_fn)( cl_command_queue /*command_queue*/, |
||||
cl_mem /*mem_object*/, |
||||
cl_uint /*value*/, |
||||
cl_ulong /*offset*/, |
||||
cl_uint /*num_events*/, |
||||
const cl_event * /*event_list*/, |
||||
cl_event * /*event*/) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueMakeBuffersResidentAMD_fn)( cl_command_queue /*command_queue*/, |
||||
cl_uint /*num_mem_objs*/, |
||||
cl_mem * /*mem_objects*/, |
||||
cl_bool /*blocking_make_resident*/, |
||||
cl_bus_address_amd * /*bus_addresses*/, |
||||
cl_uint /*num_events*/, |
||||
const cl_event * /*event_list*/, |
||||
cl_event * /*event*/) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
/*******************************************
|
||||
* Shared Virtual Memory (SVM) extension |
||||
* The declarations match the order, naming and values of the original 2.0 |
||||
* standard, except for the fact that we added the _AMD suffix to each |
||||
* symbol |
||||
*******************************************/ |
||||
typedef cl_bitfield cl_device_svm_capabilities_amd; |
||||
typedef cl_bitfield cl_svm_mem_flags_amd; |
||||
typedef cl_uint cl_kernel_exec_info_amd; |
||||
|
||||
/* cl_device_info */ |
||||
#define CL_DEVICE_SVM_CAPABILITIES_AMD 0x1053 |
||||
#define CL_DEVICE_PREFERRED_PLATFORM_ATOMIC_ALIGNMENT_AMD 0x1054 |
||||
|
||||
/* cl_device_svm_capabilities_amd */ |
||||
#define CL_DEVICE_SVM_COARSE_GRAIN_BUFFER_AMD (1 << 0) |
||||
#define CL_DEVICE_SVM_FINE_GRAIN_BUFFER_AMD (1 << 1) |
||||
#define CL_DEVICE_SVM_FINE_GRAIN_SYSTEM_AMD (1 << 2) |
||||
#define CL_DEVICE_SVM_ATOMICS_AMD (1 << 3) |
||||
|
||||
/* cl_svm_mem_flags_amd */ |
||||
#define CL_MEM_SVM_FINE_GRAIN_BUFFER_AMD (1 << 10) |
||||
#define CL_MEM_SVM_ATOMICS_AMD (1 << 11) |
||||
|
||||
/* cl_mem_info */ |
||||
#define CL_MEM_USES_SVM_POINTER_AMD 0x1109 |
||||
|
||||
/* cl_kernel_exec_info_amd */ |
||||
#define CL_KERNEL_EXEC_INFO_SVM_PTRS_AMD 0x11B6 |
||||
#define CL_KERNEL_EXEC_INFO_SVM_FINE_GRAIN_SYSTEM_AMD 0x11B7 |
||||
|
||||
/* cl_command_type */ |
||||
#define CL_COMMAND_SVM_FREE_AMD 0x1209 |
||||
#define CL_COMMAND_SVM_MEMCPY_AMD 0x120A |
||||
#define CL_COMMAND_SVM_MEMFILL_AMD 0x120B |
||||
#define CL_COMMAND_SVM_MAP_AMD 0x120C |
||||
#define CL_COMMAND_SVM_UNMAP_AMD 0x120D |
||||
|
||||
typedef CL_API_ENTRY void* |
||||
(CL_API_CALL * clSVMAllocAMD_fn)( |
||||
cl_context /* context */, |
||||
cl_svm_mem_flags_amd /* flags */, |
||||
size_t /* size */, |
||||
unsigned int /* alignment */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY void |
||||
(CL_API_CALL * clSVMFreeAMD_fn)( |
||||
cl_context /* context */, |
||||
void* /* svm_pointer */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueSVMFreeAMD_fn)( |
||||
cl_command_queue /* command_queue */, |
||||
cl_uint /* num_svm_pointers */, |
||||
void** /* svm_pointers */, |
||||
void (CL_CALLBACK *)( /*pfn_free_func*/ |
||||
cl_command_queue /* queue */, |
||||
cl_uint /* num_svm_pointers */, |
||||
void** /* svm_pointers */, |
||||
void* /* user_data */), |
||||
void* /* user_data */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event* /* event_wait_list */, |
||||
cl_event* /* event */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueSVMMemcpyAMD_fn)( |
||||
cl_command_queue /* command_queue */, |
||||
cl_bool /* blocking_copy */, |
||||
void* /* dst_ptr */, |
||||
const void* /* src_ptr */, |
||||
size_t /* size */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event* /* event_wait_list */, |
||||
cl_event* /* event */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueSVMMemFillAMD_fn)( |
||||
cl_command_queue /* command_queue */, |
||||
void* /* svm_ptr */, |
||||
const void* /* pattern */, |
||||
size_t /* pattern_size */, |
||||
size_t /* size */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event* /* event_wait_list */, |
||||
cl_event* /* event */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueSVMMapAMD_fn)( |
||||
cl_command_queue /* command_queue */, |
||||
cl_bool /* blocking_map */, |
||||
cl_map_flags /* map_flags */, |
||||
void* /* svm_ptr */, |
||||
size_t /* size */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event* /* event_wait_list */, |
||||
cl_event* /* event */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clEnqueueSVMUnmapAMD_fn)( |
||||
cl_command_queue /* command_queue */, |
||||
void* /* svm_ptr */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event* /* event_wait_list */, |
||||
cl_event* /* event */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clSetKernelArgSVMPointerAMD_fn)( |
||||
cl_kernel /* kernel */, |
||||
cl_uint /* arg_index */, |
||||
const void * /* arg_value */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
typedef CL_API_ENTRY cl_int |
||||
(CL_API_CALL * clSetKernelExecInfoAMD_fn)( |
||||
cl_kernel /* kernel */, |
||||
cl_kernel_exec_info_amd /* param_name */, |
||||
size_t /* param_value_size */, |
||||
const void * /* param_value */ |
||||
) CL_EXT_SUFFIX__VERSION_1_2; |
||||
|
||||
#endif /* CL_VERSION_1_2 */ |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
|
||||
#endif /* __CL_EXT_H */ |
@ -0,0 +1,162 @@
@@ -0,0 +1,162 @@
|
||||
/**********************************************************************************
|
||||
* Copyright (c) 2008 - 2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
**********************************************************************************/ |
||||
|
||||
#ifndef __OPENCL_CL_GL_H |
||||
#define __OPENCL_CL_GL_H |
||||
|
||||
#ifdef __APPLE__ |
||||
#include <OpenCL/cl.h> |
||||
#else |
||||
#include <CL/cl.h> |
||||
#endif |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
typedef cl_uint cl_gl_object_type; |
||||
typedef cl_uint cl_gl_texture_info; |
||||
typedef cl_uint cl_gl_platform_info; |
||||
typedef struct __GLsync *cl_GLsync; |
||||
|
||||
/* cl_gl_object_type = 0x2000 - 0x200F enum values are currently taken */ |
||||
#define CL_GL_OBJECT_BUFFER 0x2000 |
||||
#define CL_GL_OBJECT_TEXTURE2D 0x2001 |
||||
#define CL_GL_OBJECT_TEXTURE3D 0x2002 |
||||
#define CL_GL_OBJECT_RENDERBUFFER 0x2003 |
||||
#define CL_GL_OBJECT_TEXTURE2D_ARRAY 0x200E |
||||
#define CL_GL_OBJECT_TEXTURE1D 0x200F |
||||
#define CL_GL_OBJECT_TEXTURE1D_ARRAY 0x2010 |
||||
#define CL_GL_OBJECT_TEXTURE_BUFFER 0x2011 |
||||
|
||||
/* cl_gl_texture_info */ |
||||
#define CL_GL_TEXTURE_TARGET 0x2004 |
||||
#define CL_GL_MIPMAP_LEVEL 0x2005 |
||||
#define CL_GL_NUM_SAMPLES 0x2012 |
||||
|
||||
|
||||
extern CL_API_ENTRY cl_mem CL_API_CALL |
||||
clCreateFromGLBuffer(cl_context /* context */, |
||||
cl_mem_flags /* flags */, |
||||
cl_GLuint /* bufobj */, |
||||
int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
extern CL_API_ENTRY cl_mem CL_API_CALL |
||||
clCreateFromGLTexture(cl_context /* context */, |
||||
cl_mem_flags /* flags */, |
||||
cl_GLenum /* target */, |
||||
cl_GLint /* miplevel */, |
||||
cl_GLuint /* texture */, |
||||
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_2; |
||||
|
||||
extern CL_API_ENTRY cl_mem CL_API_CALL |
||||
clCreateFromGLRenderbuffer(cl_context /* context */, |
||||
cl_mem_flags /* flags */, |
||||
cl_GLuint /* renderbuffer */, |
||||
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clGetGLObjectInfo(cl_mem /* memobj */, |
||||
cl_gl_object_type * /* gl_object_type */, |
||||
cl_GLuint * /* gl_object_name */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clGetGLTextureInfo(cl_mem /* memobj */, |
||||
cl_gl_texture_info /* param_name */, |
||||
size_t /* param_value_size */, |
||||
void * /* param_value */, |
||||
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clEnqueueAcquireGLObjects(cl_command_queue /* command_queue */, |
||||
cl_uint /* num_objects */, |
||||
const cl_mem * /* mem_objects */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event * /* event_wait_list */, |
||||
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clEnqueueReleaseGLObjects(cl_command_queue /* command_queue */, |
||||
cl_uint /* num_objects */, |
||||
const cl_mem * /* mem_objects */, |
||||
cl_uint /* num_events_in_wait_list */, |
||||
const cl_event * /* event_wait_list */, |
||||
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
|
||||
// Deprecated OpenCL 1.1 APIs
|
||||
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_mem CL_API_CALL |
||||
clCreateFromGLTexture2D(cl_context /* context */, |
||||
cl_mem_flags /* flags */, |
||||
cl_GLenum /* target */, |
||||
cl_GLint /* miplevel */, |
||||
cl_GLuint /* texture */, |
||||
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; |
||||
|
||||
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_mem CL_API_CALL |
||||
clCreateFromGLTexture3D(cl_context /* context */, |
||||
cl_mem_flags /* flags */, |
||||
cl_GLenum /* target */, |
||||
cl_GLint /* miplevel */, |
||||
cl_GLuint /* texture */, |
||||
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; |
||||
|
||||
/* cl_khr_gl_sharing extension */ |
||||
|
||||
#define cl_khr_gl_sharing 1 |
||||
|
||||
typedef cl_uint cl_gl_context_info; |
||||
|
||||
/* Additional Error Codes */ |
||||
#define CL_INVALID_GL_SHAREGROUP_REFERENCE_KHR -1000 |
||||
|
||||
/* cl_gl_context_info */ |
||||
#define CL_CURRENT_DEVICE_FOR_GL_CONTEXT_KHR 0x2006 |
||||
#define CL_DEVICES_FOR_GL_CONTEXT_KHR 0x2007 |
||||
|
||||
/* Additional cl_context_properties */ |
||||
#define CL_GL_CONTEXT_KHR 0x2008 |
||||
#define CL_EGL_DISPLAY_KHR 0x2009 |
||||
#define CL_GLX_DISPLAY_KHR 0x200A |
||||
#define CL_WGL_HDC_KHR 0x200B |
||||
#define CL_CGL_SHAREGROUP_KHR 0x200C |
||||
|
||||
extern CL_API_ENTRY cl_int CL_API_CALL |
||||
clGetGLContextInfoKHR(const cl_context_properties * /* properties */, |
||||
cl_gl_context_info /* param_name */, |
||||
size_t /* param_value_size */, |
||||
void * /* param_value */, |
||||
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; |
||||
|
||||
typedef CL_API_ENTRY cl_int (CL_API_CALL *clGetGLContextInfoKHR_fn)( |
||||
const cl_context_properties * properties, |
||||
cl_gl_context_info param_name, |
||||
size_t param_value_size, |
||||
void * param_value, |
||||
size_t * param_value_size_ret); |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* __OPENCL_CL_GL_H */ |
@ -0,0 +1,69 @@
@@ -0,0 +1,69 @@
|
||||
/**********************************************************************************
|
||||
* Copyright (c) 2008-2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
**********************************************************************************/ |
||||
|
||||
/* $Revision: 14826 $ on $Date: 2011-05-26 07:40:43 -0700 (Thu, 26 May 2011) $ */ |
||||
|
||||
/* cl_gl_ext.h contains vendor (non-KHR) OpenCL extensions which have */ |
||||
/* OpenGL dependencies. */ |
||||
|
||||
#ifndef __OPENCL_CL_GL_EXT_H |
||||
#define __OPENCL_CL_GL_EXT_H |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
#ifdef __APPLE__ |
||||
#include <OpenCL/cl_gl.h> |
||||
#else |
||||
#include <CL/cl_gl.h> |
||||
#endif |
||||
|
||||
/*
|
||||
* For each extension, follow this template |
||||
* cl_VEN_extname extension */ |
||||
/* #define cl_VEN_extname 1
|
||||
* ... define new types, if any |
||||
* ... define new tokens, if any |
||||
* ... define new APIs, if any |
||||
* |
||||
* If you need GLtypes here, mirror them with a cl_GLtype, rather than including a GL header |
||||
* This allows us to avoid having to decide whether to include GL headers or GLES here. |
||||
*/ |
||||
|
||||
/*
|
||||
* cl_khr_gl_event extension |
||||
* See section 9.9 in the OpenCL 1.1 spec for more information |
||||
*/ |
||||
#define CL_COMMAND_GL_FENCE_SYNC_OBJECT_KHR 0x200D |
||||
|
||||
extern CL_API_ENTRY cl_event CL_API_CALL |
||||
clCreateEventFromGLsyncKHR(cl_context /* context */, |
||||
cl_GLsync /* cl_GLsync */, |
||||
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1; |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* __OPENCL_CL_GL_EXT_H */ |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,54 @@
@@ -0,0 +1,54 @@
|
||||
/*******************************************************************************
|
||||
* Copyright (c) 2008-2012 The Khronos Group Inc. |
||||
* |
||||
* Permission is hereby granted, free of charge, to any person obtaining a |
||||
* copy of this software and/or associated documentation files (the |
||||
* "Materials"), to deal in the Materials without restriction, including |
||||
* without limitation the rights to use, copy, modify, merge, publish, |
||||
* distribute, sublicense, and/or sell copies of the Materials, and to |
||||
* permit persons to whom the Materials are furnished to do so, subject to |
||||
* the following conditions: |
||||
* |
||||
* The above copyright notice and this permission notice shall be included |
||||
* in all copies or substantial portions of the Materials. |
||||
* |
||||
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
||||
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
||||
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||||
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||||
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. |
||||
******************************************************************************/ |
||||
|
||||
/* $Revision: 11708 $ on $Date: 2010-06-13 23:36:24 -0700 (Sun, 13 Jun 2010) $ */ |
||||
|
||||
#ifndef __OPENCL_H |
||||
#define __OPENCL_H |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
#ifdef __APPLE__ |
||||
|
||||
#include <OpenCL/cl.h> |
||||
#include <OpenCL/cl_gl.h> |
||||
#include <OpenCL/cl_gl_ext.h> |
||||
#include <OpenCL/cl_ext.h> |
||||
|
||||
#else |
||||
|
||||
#include <CL/cl.h> |
||||
#include <CL/cl_gl.h> |
||||
#include <CL/cl_gl_ext.h> |
||||
#include <CL/cl_ext.h> |
||||
|
||||
#endif |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* __OPENCL_H */ |
||||
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,180 @@
@@ -0,0 +1,180 @@
|
||||
#ifndef __CURL_CURLBUILD_H |
||||
#define __CURL_CURLBUILD_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
/* ================================================================ */ |
||||
/* NOTES FOR CONFIGURE CAPABLE SYSTEMS */ |
||||
/* ================================================================ */ |
||||
|
||||
/*
|
||||
* NOTE 1: |
||||
* ------- |
||||
* |
||||
* Nothing in this file is intended to be modified or adjusted by the |
||||
* curl library user nor by the curl library builder. |
||||
* |
||||
* If you think that something actually needs to be changed, adjusted |
||||
* or fixed in this file, then, report it on the libcurl development |
||||
* mailing list: http://cool.haxx.se/mailman/listinfo/curl-library/
|
||||
* |
||||
* This header file shall only export symbols which are 'curl' or 'CURL' |
||||
* prefixed, otherwise public name space would be polluted. |
||||
* |
||||
* NOTE 2: |
||||
* ------- |
||||
* |
||||
* Right now you might be staring at file include/curl/curlbuild.h.in or |
||||
* at file include/curl/curlbuild.h, this is due to the following reason: |
||||
* |
||||
* On systems capable of running the configure script, the configure process |
||||
* will overwrite the distributed include/curl/curlbuild.h file with one that |
||||
* is suitable and specific to the library being configured and built, which |
||||
* is generated from the include/curl/curlbuild.h.in template file. |
||||
* |
||||
*/ |
||||
|
||||
/* ================================================================ */ |
||||
/* DEFINITION OF THESE SYMBOLS SHALL NOT TAKE PLACE ANYWHERE ELSE */ |
||||
/* ================================================================ */ |
||||
|
||||
#ifdef CURL_SIZEOF_LONG |
||||
# error "CURL_SIZEOF_LONG shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_SIZEOF_LONG_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_TYPEOF_CURL_SOCKLEN_T |
||||
# error "CURL_TYPEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_TYPEOF_CURL_SOCKLEN_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_SIZEOF_CURL_SOCKLEN_T |
||||
# error "CURL_SIZEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_SIZEOF_CURL_SOCKLEN_T_already_defined |
||||
#endif |
||||
#ifdef CURL_TYPEOF_CURL_OFF_T |
||||
# error "CURL_TYPEOF_CURL_OFF_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_TYPEOF_CURL_OFF_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_FORMAT_CURL_OFF_T |
||||
# error "CURL_FORMAT_CURL_OFF_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_FORMAT_CURL_OFF_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_FORMAT_CURL_OFF_TU |
||||
# error "CURL_FORMAT_CURL_OFF_TU shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_FORMAT_CURL_OFF_TU_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_FORMAT_OFF_T |
||||
# error "CURL_FORMAT_OFF_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_FORMAT_OFF_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_SIZEOF_CURL_OFF_T |
||||
# error "CURL_SIZEOF_CURL_OFF_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_SIZEOF_CURL_OFF_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_SUFFIX_CURL_OFF_T |
||||
# error "CURL_SUFFIX_CURL_OFF_T shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_T_already_defined |
||||
#endif |
||||
|
||||
#ifdef CURL_SUFFIX_CURL_OFF_TU |
||||
# error "CURL_SUFFIX_CURL_OFF_TU shall not be defined except in curlbuild.h" |
||||
Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_TU_already_defined |
||||
#endif |
||||
|
||||
/* ================================================================ */ |
||||
/* EXTERNAL INTERFACE SETTINGS FOR CONFIGURE CAPABLE SYSTEMS ONLY */ |
||||
/* ================================================================ */ |
||||
|
||||
/* Configure process defines this to 1 when it finds out that system */ |
||||
/* header file sys/types.h must be included by the external interface. */ |
||||
/* #undef CURL_PULL_SYS_TYPES_H */ |
||||
#ifdef CURL_PULL_SYS_TYPES_H |
||||
# include <sys/types.h> |
||||
#endif |
||||
|
||||
/* Configure process defines this to 1 when it finds out that system */ |
||||
/* header file stdint.h must be included by the external interface. */ |
||||
/* #undef CURL_PULL_STDINT_H */ |
||||
#ifdef CURL_PULL_STDINT_H |
||||
# include <stdint.h> |
||||
#endif |
||||
|
||||
/* Configure process defines this to 1 when it finds out that system */ |
||||
/* header file inttypes.h must be included by the external interface. */ |
||||
/* #undef CURL_PULL_INTTYPES_H */ |
||||
#ifdef CURL_PULL_INTTYPES_H |
||||
# include <inttypes.h> |
||||
#endif |
||||
|
||||
/* The size of `long', as computed by sizeof. */ |
||||
#define CURL_SIZEOF_LONG 4 |
||||
|
||||
/* Integral data type used for curl_socklen_t. */ |
||||
#define CURL_TYPEOF_CURL_SOCKLEN_T socklen_t |
||||
|
||||
/* on windows socklen_t is in here */ |
||||
#ifdef _WIN32 |
||||
# include <winsock2.h> |
||||
# include <ws2tcpip.h> |
||||
#endif |
||||
|
||||
#ifdef HAVE_SYS_SOCKET_H |
||||
# include <sys/socket.h> |
||||
#endif |
||||
|
||||
/* Data type definition of curl_socklen_t. */ |
||||
typedef CURL_TYPEOF_CURL_SOCKLEN_T curl_socklen_t; |
||||
|
||||
/* The size of `curl_socklen_t', as computed by sizeof. */ |
||||
#define CURL_SIZEOF_CURL_SOCKLEN_T 4 |
||||
|
||||
/* Signed integral data type used for curl_off_t. */ |
||||
#define CURL_TYPEOF_CURL_OFF_T long long |
||||
|
||||
/* Data type definition of curl_off_t. */ |
||||
typedef CURL_TYPEOF_CURL_OFF_T curl_off_t; |
||||
|
||||
/* curl_off_t formatting string directive without "%" conversion specifier. */ |
||||
#define CURL_FORMAT_CURL_OFF_T "lld" |
||||
|
||||
/* unsigned curl_off_t formatting string without "%" conversion specifier. */ |
||||
#define CURL_FORMAT_CURL_OFF_TU "llu" |
||||
|
||||
/* curl_off_t formatting string directive with "%" conversion specifier. */ |
||||
#define CURL_FORMAT_OFF_T "%lld" |
||||
|
||||
/* The size of `curl_off_t', as computed by sizeof. */ |
||||
#define CURL_SIZEOF_CURL_OFF_T 8 |
||||
|
||||
/* curl_off_t constant suffix. */ |
||||
#define CURL_SUFFIX_CURL_OFF_T LL |
||||
|
||||
/* unsigned curl_off_t constant suffix. */ |
||||
#define CURL_SUFFIX_CURL_OFF_TU ULL |
||||
|
||||
#endif /* __CURL_CURLBUILD_H */ |
@ -0,0 +1,262 @@
@@ -0,0 +1,262 @@
|
||||
#ifndef __CURL_CURLRULES_H |
||||
#define __CURL_CURLRULES_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
/* ================================================================ */ |
||||
/* COMPILE TIME SANITY CHECKS */ |
||||
/* ================================================================ */ |
||||
|
||||
/*
|
||||
* NOTE 1: |
||||
* ------- |
||||
* |
||||
* All checks done in this file are intentionally placed in a public |
||||
* header file which is pulled by curl/curl.h when an application is |
||||
* being built using an already built libcurl library. Additionally |
||||
* this file is also included and used when building the library. |
||||
* |
||||
* If compilation fails on this file it is certainly sure that the |
||||
* problem is elsewhere. It could be a problem in the curlbuild.h |
||||
* header file, or simply that you are using different compilation |
||||
* settings than those used to build the library. |
||||
* |
||||
* Nothing in this file is intended to be modified or adjusted by the |
||||
* curl library user nor by the curl library builder. |
||||
* |
||||
* Do not deactivate any check, these are done to make sure that the |
||||
* library is properly built and used. |
||||
* |
||||
* You can find further help on the libcurl development mailing list: |
||||
* http://cool.haxx.se/mailman/listinfo/curl-library/
|
||||
* |
||||
* NOTE 2 |
||||
* ------ |
||||
* |
||||
* Some of the following compile time checks are based on the fact |
||||
* that the dimension of a constant array can not be a negative one. |
||||
* In this way if the compile time verification fails, the compilation |
||||
* will fail issuing an error. The error description wording is compiler |
||||
* dependent but it will be quite similar to one of the following: |
||||
* |
||||
* "negative subscript or subscript is too large" |
||||
* "array must have at least one element" |
||||
* "-1 is an illegal array size" |
||||
* "size of array is negative" |
||||
* |
||||
* If you are building an application which tries to use an already |
||||
* built libcurl library and you are getting this kind of errors on |
||||
* this file, it is a clear indication that there is a mismatch between |
||||
* how the library was built and how you are trying to use it for your |
||||
* application. Your already compiled or binary library provider is the |
||||
* only one who can give you the details you need to properly use it. |
||||
*/ |
||||
|
||||
/*
|
||||
* Verify that some macros are actually defined. |
||||
*/ |
||||
|
||||
#ifndef CURL_SIZEOF_LONG |
||||
# error "CURL_SIZEOF_LONG definition is missing!" |
||||
Error Compilation_aborted_CURL_SIZEOF_LONG_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_TYPEOF_CURL_SOCKLEN_T |
||||
# error "CURL_TYPEOF_CURL_SOCKLEN_T definition is missing!" |
||||
Error Compilation_aborted_CURL_TYPEOF_CURL_SOCKLEN_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_SIZEOF_CURL_SOCKLEN_T |
||||
# error "CURL_SIZEOF_CURL_SOCKLEN_T definition is missing!" |
||||
Error Compilation_aborted_CURL_SIZEOF_CURL_SOCKLEN_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_TYPEOF_CURL_OFF_T |
||||
# error "CURL_TYPEOF_CURL_OFF_T definition is missing!" |
||||
Error Compilation_aborted_CURL_TYPEOF_CURL_OFF_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_FORMAT_CURL_OFF_T |
||||
# error "CURL_FORMAT_CURL_OFF_T definition is missing!" |
||||
Error Compilation_aborted_CURL_FORMAT_CURL_OFF_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_FORMAT_CURL_OFF_TU |
||||
# error "CURL_FORMAT_CURL_OFF_TU definition is missing!" |
||||
Error Compilation_aborted_CURL_FORMAT_CURL_OFF_TU_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_FORMAT_OFF_T |
||||
# error "CURL_FORMAT_OFF_T definition is missing!" |
||||
Error Compilation_aborted_CURL_FORMAT_OFF_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_SIZEOF_CURL_OFF_T |
||||
# error "CURL_SIZEOF_CURL_OFF_T definition is missing!" |
||||
Error Compilation_aborted_CURL_SIZEOF_CURL_OFF_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_SUFFIX_CURL_OFF_T |
||||
# error "CURL_SUFFIX_CURL_OFF_T definition is missing!" |
||||
Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_T_is_missing |
||||
#endif |
||||
|
||||
#ifndef CURL_SUFFIX_CURL_OFF_TU |
||||
# error "CURL_SUFFIX_CURL_OFF_TU definition is missing!" |
||||
Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_TU_is_missing |
||||
#endif |
||||
|
||||
/*
|
||||
* Macros private to this header file. |
||||
*/ |
||||
|
||||
#define CurlchkszEQ(t, s) sizeof(t) == s ? 1 : -1 |
||||
|
||||
#define CurlchkszGE(t1, t2) sizeof(t1) >= sizeof(t2) ? 1 : -1 |
||||
|
||||
/*
|
||||
* Verify that the size previously defined and expected for long |
||||
* is the same as the one reported by sizeof() at compile time. |
||||
*/ |
||||
|
||||
typedef char |
||||
__curl_rule_01__ |
||||
[CurlchkszEQ(long, CURL_SIZEOF_LONG)]; |
||||
|
||||
/*
|
||||
* Verify that the size previously defined and expected for |
||||
* curl_off_t is actually the the same as the one reported |
||||
* by sizeof() at compile time. |
||||
*/ |
||||
|
||||
typedef char |
||||
__curl_rule_02__ |
||||
[CurlchkszEQ(curl_off_t, CURL_SIZEOF_CURL_OFF_T)]; |
||||
|
||||
/*
|
||||
* Verify at compile time that the size of curl_off_t as reported |
||||
* by sizeof() is greater or equal than the one reported for long |
||||
* for the current compilation. |
||||
*/ |
||||
|
||||
typedef char |
||||
__curl_rule_03__ |
||||
[CurlchkszGE(curl_off_t, long)]; |
||||
|
||||
/*
|
||||
* Verify that the size previously defined and expected for |
||||
* curl_socklen_t is actually the the same as the one reported |
||||
* by sizeof() at compile time. |
||||
*/ |
||||
|
||||
typedef char |
||||
__curl_rule_04__ |
||||
[CurlchkszEQ(curl_socklen_t, CURL_SIZEOF_CURL_SOCKLEN_T)]; |
||||
|
||||
/*
|
||||
* Verify at compile time that the size of curl_socklen_t as reported |
||||
* by sizeof() is greater or equal than the one reported for int for |
||||
* the current compilation. |
||||
*/ |
||||
|
||||
typedef char |
||||
__curl_rule_05__ |
||||
[CurlchkszGE(curl_socklen_t, int)]; |
||||
|
||||
/* ================================================================ */ |
||||
/* EXTERNALLY AND INTERNALLY VISIBLE DEFINITIONS */ |
||||
/* ================================================================ */ |
||||
|
||||
/*
|
||||
* CURL_ISOCPP and CURL_OFF_T_C definitions are done here in order to allow |
||||
* these to be visible and exported by the external libcurl interface API, |
||||
* while also making them visible to the library internals, simply including |
||||
* curl_setup.h, without actually needing to include curl.h internally. |
||||
* If some day this section would grow big enough, all this should be moved |
||||
* to its own header file. |
||||
*/ |
||||
|
||||
/*
|
||||
* Figure out if we can use the ## preprocessor operator, which is supported |
||||
* by ISO/ANSI C and C++. Some compilers support it without setting __STDC__ |
||||
* or __cplusplus so we need to carefully check for them too. |
||||
*/ |
||||
|
||||
#if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus) || \ |
||||
defined(__HP_aCC) || defined(__BORLANDC__) || defined(__LCC__) || \ |
||||
defined(__POCC__) || defined(__SALFORDC__) || defined(__HIGHC__) || \ |
||||
defined(__ILEC400__) |
||||
/* This compiler is believed to have an ISO compatible preprocessor */ |
||||
#define CURL_ISOCPP |
||||
#else |
||||
/* This compiler is believed NOT to have an ISO compatible preprocessor */ |
||||
#undef CURL_ISOCPP |
||||
#endif |
||||
|
||||
/*
|
||||
* Macros for minimum-width signed and unsigned curl_off_t integer constants. |
||||
*/ |
||||
|
||||
#if defined(__BORLANDC__) && (__BORLANDC__ == 0x0551) |
||||
# define __CURL_OFF_T_C_HLPR2(x) x |
||||
# define __CURL_OFF_T_C_HLPR1(x) __CURL_OFF_T_C_HLPR2(x) |
||||
# define CURL_OFF_T_C(Val) __CURL_OFF_T_C_HLPR1(Val) ## \ |
||||
__CURL_OFF_T_C_HLPR1(CURL_SUFFIX_CURL_OFF_T) |
||||
# define CURL_OFF_TU_C(Val) __CURL_OFF_T_C_HLPR1(Val) ## \ |
||||
__CURL_OFF_T_C_HLPR1(CURL_SUFFIX_CURL_OFF_TU) |
||||
#else |
||||
# ifdef CURL_ISOCPP |
||||
# define __CURL_OFF_T_C_HLPR2(Val,Suffix) Val ## Suffix |
||||
# else |
||||
# define __CURL_OFF_T_C_HLPR2(Val,Suffix) Val/**/Suffix |
||||
# endif |
||||
# define __CURL_OFF_T_C_HLPR1(Val,Suffix) __CURL_OFF_T_C_HLPR2(Val,Suffix) |
||||
# define CURL_OFF_T_C(Val) __CURL_OFF_T_C_HLPR1(Val,CURL_SUFFIX_CURL_OFF_T) |
||||
# define CURL_OFF_TU_C(Val) __CURL_OFF_T_C_HLPR1(Val,CURL_SUFFIX_CURL_OFF_TU) |
||||
#endif |
||||
|
||||
/*
|
||||
* Get rid of macros private to this header file. |
||||
*/ |
||||
|
||||
#undef CurlchkszEQ |
||||
#undef CurlchkszGE |
||||
|
||||
/*
|
||||
* Get rid of macros not intended to exist beyond this point. |
||||
*/ |
||||
|
||||
#undef CURL_PULL_WS2TCPIP_H |
||||
#undef CURL_PULL_SYS_TYPES_H |
||||
#undef CURL_PULL_SYS_SOCKET_H |
||||
#undef CURL_PULL_SYS_POLL_H |
||||
#undef CURL_PULL_STDINT_H |
||||
#undef CURL_PULL_INTTYPES_H |
||||
|
||||
#undef CURL_TYPEOF_CURL_SOCKLEN_T |
||||
#undef CURL_TYPEOF_CURL_OFF_T |
||||
|
||||
#ifdef CURL_NO_OLDIES |
||||
#undef CURL_FORMAT_OFF_T /* not required since 7.19.0 - obsoleted in 7.20.0 */ |
||||
#endif |
||||
|
||||
#endif /* __CURL_CURLRULES_H */ |
@ -0,0 +1,69 @@
@@ -0,0 +1,69 @@
|
||||
#ifndef __CURL_CURLVER_H |
||||
#define __CURL_CURLVER_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
/* This header file contains nothing but libcurl version info, generated by
|
||||
a script at release-time. This was made its own header file in 7.11.2 */ |
||||
|
||||
/* This is the global package copyright */ |
||||
#define LIBCURL_COPYRIGHT "1996 - 2014 Daniel Stenberg, <daniel@haxx.se>." |
||||
|
||||
/* This is the version number of the libcurl package from which this header
|
||||
file origins: */ |
||||
#define LIBCURL_VERSION "7.38.0" |
||||
|
||||
/* The numeric version number is also available "in parts" by using these
|
||||
defines: */ |
||||
#define LIBCURL_VERSION_MAJOR 7 |
||||
#define LIBCURL_VERSION_MINOR 38 |
||||
#define LIBCURL_VERSION_PATCH 0 |
||||
|
||||
/* This is the numeric version of the libcurl version number, meant for easier
|
||||
parsing and comparions by programs. The LIBCURL_VERSION_NUM define will |
||||
always follow this syntax: |
||||
|
||||
0xXXYYZZ |
||||
|
||||
Where XX, YY and ZZ are the main version, release and patch numbers in |
||||
hexadecimal (using 8 bits each). All three numbers are always represented |
||||
using two digits. 1.2 would appear as "0x010200" while version 9.11.7 |
||||
appears as "0x090b07". |
||||
|
||||
This 6-digit (24 bits) hexadecimal number does not show pre-release number, |
||||
and it is always a greater number in a more recent release. It makes |
||||
comparisons with greater than and less than work. |
||||
*/ |
||||
#define LIBCURL_VERSION_NUM 0x072600 |
||||
|
||||
/*
|
||||
* This is the date and time when the full source package was created. The |
||||
* timestamp is not stored in git, as the timestamp is properly set in the |
||||
* tarballs by the maketgz script. |
||||
* |
||||
* The format of the date should follow this template: |
||||
* |
||||
* "Mon Feb 12 11:35:33 UTC 2007" |
||||
*/ |
||||
#define LIBCURL_TIMESTAMP "Mon Nov 03 12:00:00 UTC 2014" |
||||
|
||||
#endif /* __CURL_CURLVER_H */ |
@ -0,0 +1,102 @@
@@ -0,0 +1,102 @@
|
||||
#ifndef __CURL_EASY_H |
||||
#define __CURL_EASY_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
CURL_EXTERN CURL *curl_easy_init(void); |
||||
CURL_EXTERN CURLcode curl_easy_setopt(CURL *curl, CURLoption option, ...); |
||||
CURL_EXTERN CURLcode curl_easy_perform(CURL *curl); |
||||
CURL_EXTERN void curl_easy_cleanup(CURL *curl); |
||||
|
||||
/*
|
||||
* NAME curl_easy_getinfo() |
||||
* |
||||
* DESCRIPTION |
||||
* |
||||
* Request internal information from the curl session with this function. The |
||||
* third argument MUST be a pointer to a long, a pointer to a char * or a |
||||
* pointer to a double (as the documentation describes elsewhere). The data |
||||
* pointed to will be filled in accordingly and can be relied upon only if the |
||||
* function returns CURLE_OK. This function is intended to get used *AFTER* a |
||||
* performed transfer, all results from this function are undefined until the |
||||
* transfer is completed. |
||||
*/ |
||||
CURL_EXTERN CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...); |
||||
|
||||
|
||||
/*
|
||||
* NAME curl_easy_duphandle() |
||||
* |
||||
* DESCRIPTION |
||||
* |
||||
* Creates a new curl session handle with the same options set for the handle |
||||
* passed in. Duplicating a handle could only be a matter of cloning data and |
||||
* options, internal state info and things like persistent connections cannot |
||||
* be transferred. It is useful in multithreaded applications when you can run |
||||
* curl_easy_duphandle() for each new thread to avoid a series of identical |
||||
* curl_easy_setopt() invokes in every thread. |
||||
*/ |
||||
CURL_EXTERN CURL* curl_easy_duphandle(CURL *curl); |
||||
|
||||
/*
|
||||
* NAME curl_easy_reset() |
||||
* |
||||
* DESCRIPTION |
||||
* |
||||
* Re-initializes a CURL handle to the default values. This puts back the |
||||
* handle to the same state as it was in when it was just created. |
||||
* |
||||
* It does keep: live connections, the Session ID cache, the DNS cache and the |
||||
* cookies. |
||||
*/ |
||||
CURL_EXTERN void curl_easy_reset(CURL *curl); |
||||
|
||||
/*
|
||||
* NAME curl_easy_recv() |
||||
* |
||||
* DESCRIPTION |
||||
* |
||||
* Receives data from the connected socket. Use after successful |
||||
* curl_easy_perform() with CURLOPT_CONNECT_ONLY option. |
||||
*/ |
||||
CURL_EXTERN CURLcode curl_easy_recv(CURL *curl, void *buffer, size_t buflen, |
||||
size_t *n); |
||||
|
||||
/*
|
||||
* NAME curl_easy_send() |
||||
* |
||||
* DESCRIPTION |
||||
* |
||||
* Sends data over the connected socket. Use after successful |
||||
* curl_easy_perform() with CURLOPT_CONNECT_ONLY option. |
||||
*/ |
||||
CURL_EXTERN CURLcode curl_easy_send(CURL *curl, const void *buffer, |
||||
size_t buflen, size_t *n); |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif |
@ -0,0 +1,81 @@
@@ -0,0 +1,81 @@
|
||||
#ifndef __CURL_MPRINTF_H |
||||
#define __CURL_MPRINTF_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
#include <stdarg.h> |
||||
#include <stdio.h> /* needed for FILE */ |
||||
|
||||
#include "curl.h" |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
CURL_EXTERN int curl_mprintf(const char *format, ...); |
||||
CURL_EXTERN int curl_mfprintf(FILE *fd, const char *format, ...); |
||||
CURL_EXTERN int curl_msprintf(char *buffer, const char *format, ...); |
||||
CURL_EXTERN int curl_msnprintf(char *buffer, size_t maxlength, |
||||
const char *format, ...); |
||||
CURL_EXTERN int curl_mvprintf(const char *format, va_list args); |
||||
CURL_EXTERN int curl_mvfprintf(FILE *fd, const char *format, va_list args); |
||||
CURL_EXTERN int curl_mvsprintf(char *buffer, const char *format, va_list args); |
||||
CURL_EXTERN int curl_mvsnprintf(char *buffer, size_t maxlength, |
||||
const char *format, va_list args); |
||||
CURL_EXTERN char *curl_maprintf(const char *format, ...); |
||||
CURL_EXTERN char *curl_mvaprintf(const char *format, va_list args); |
||||
|
||||
#ifdef _MPRINTF_REPLACE |
||||
# undef printf |
||||
# undef fprintf |
||||
# undef sprintf |
||||
# undef vsprintf |
||||
# undef snprintf |
||||
# undef vprintf |
||||
# undef vfprintf |
||||
# undef vsnprintf |
||||
# undef aprintf |
||||
# undef vaprintf |
||||
# define printf curl_mprintf |
||||
# define fprintf curl_mfprintf |
||||
#ifdef CURLDEBUG |
||||
/* When built with CURLDEBUG we define away the sprintf functions since we
|
||||
don't want internal code to be using them */ |
||||
# define sprintf sprintf_was_used |
||||
# define vsprintf vsprintf_was_used |
||||
#else |
||||
# define sprintf curl_msprintf |
||||
# define vsprintf curl_mvsprintf |
||||
#endif |
||||
# define snprintf curl_msnprintf |
||||
# define vprintf curl_mvprintf |
||||
# define vfprintf curl_mvfprintf |
||||
# define vsnprintf curl_mvsnprintf |
||||
# define aprintf curl_maprintf |
||||
# define vaprintf curl_mvaprintf |
||||
#endif |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* __CURL_MPRINTF_H */ |
@ -0,0 +1,399 @@
@@ -0,0 +1,399 @@
|
||||
#ifndef __CURL_MULTI_H |
||||
#define __CURL_MULTI_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
/*
|
||||
This is an "external" header file. Don't give away any internals here! |
||||
|
||||
GOALS |
||||
|
||||
o Enable a "pull" interface. The application that uses libcurl decides where |
||||
and when to ask libcurl to get/send data. |
||||
|
||||
o Enable multiple simultaneous transfers in the same thread without making it |
||||
complicated for the application. |
||||
|
||||
o Enable the application to select() on its own file descriptors and curl's |
||||
file descriptors simultaneous easily. |
||||
|
||||
*/ |
||||
|
||||
/*
|
||||
* This header file should not really need to include "curl.h" since curl.h |
||||
* itself includes this file and we expect user applications to do #include |
||||
* <curl/curl.h> without the need for especially including multi.h. |
||||
* |
||||
* For some reason we added this include here at one point, and rather than to |
||||
* break existing (wrongly written) libcurl applications, we leave it as-is |
||||
* but with this warning attached. |
||||
*/ |
||||
#include "curl.h" |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
typedef void CURLM; |
||||
|
||||
typedef enum { |
||||
CURLM_CALL_MULTI_PERFORM = -1, /* please call curl_multi_perform() or
|
||||
curl_multi_socket*() soon */ |
||||
CURLM_OK, |
||||
CURLM_BAD_HANDLE, /* the passed-in handle is not a valid CURLM handle */ |
||||
CURLM_BAD_EASY_HANDLE, /* an easy handle was not good/valid */ |
||||
CURLM_OUT_OF_MEMORY, /* if you ever get this, you're in deep sh*t */ |
||||
CURLM_INTERNAL_ERROR, /* this is a libcurl bug */ |
||||
CURLM_BAD_SOCKET, /* the passed in socket argument did not match */ |
||||
CURLM_UNKNOWN_OPTION, /* curl_multi_setopt() with unsupported option */ |
||||
CURLM_ADDED_ALREADY, /* an easy handle already added to a multi handle was
|
||||
attempted to get added - again */ |
||||
CURLM_LAST |
||||
} CURLMcode; |
||||
|
||||
/* just to make code nicer when using curl_multi_socket() you can now check
|
||||
for CURLM_CALL_MULTI_SOCKET too in the same style it works for |
||||
curl_multi_perform() and CURLM_CALL_MULTI_PERFORM */ |
||||
#define CURLM_CALL_MULTI_SOCKET CURLM_CALL_MULTI_PERFORM |
||||
|
||||
typedef enum { |
||||
CURLMSG_NONE, /* first, not used */ |
||||
CURLMSG_DONE, /* This easy handle has completed. 'result' contains
|
||||
the CURLcode of the transfer */ |
||||
CURLMSG_LAST /* last, not used */ |
||||
} CURLMSG; |
||||
|
||||
struct CURLMsg { |
||||
CURLMSG msg; /* what this message means */ |
||||
CURL *easy_handle; /* the handle it concerns */ |
||||
union { |
||||
void *whatever; /* message-specific data */ |
||||
CURLcode result; /* return code for transfer */ |
||||
} data; |
||||
}; |
||||
typedef struct CURLMsg CURLMsg; |
||||
|
||||
/* Based on poll(2) structure and values.
|
||||
* We don't use pollfd and POLL* constants explicitly |
||||
* to cover platforms without poll(). */ |
||||
#define CURL_WAIT_POLLIN 0x0001 |
||||
#define CURL_WAIT_POLLPRI 0x0002 |
||||
#define CURL_WAIT_POLLOUT 0x0004 |
||||
|
||||
struct curl_waitfd { |
||||
curl_socket_t fd; |
||||
short events; |
||||
short revents; /* not supported yet */ |
||||
}; |
||||
|
||||
/*
|
||||
* Name: curl_multi_init() |
||||
* |
||||
* Desc: inititalize multi-style curl usage |
||||
* |
||||
* Returns: a new CURLM handle to use in all 'curl_multi' functions. |
||||
*/ |
||||
CURL_EXTERN CURLM *curl_multi_init(void); |
||||
|
||||
/*
|
||||
* Name: curl_multi_add_handle() |
||||
* |
||||
* Desc: add a standard curl handle to the multi stack |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_add_handle(CURLM *multi_handle, |
||||
CURL *curl_handle); |
||||
|
||||
/*
|
||||
* Name: curl_multi_remove_handle() |
||||
* |
||||
* Desc: removes a curl handle from the multi stack again |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_remove_handle(CURLM *multi_handle, |
||||
CURL *curl_handle); |
||||
|
||||
/*
|
||||
* Name: curl_multi_fdset() |
||||
* |
||||
* Desc: Ask curl for its fd_set sets. The app can use these to select() or |
||||
* poll() on. We want curl_multi_perform() called as soon as one of |
||||
* them are ready. |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_fdset(CURLM *multi_handle, |
||||
fd_set *read_fd_set, |
||||
fd_set *write_fd_set, |
||||
fd_set *exc_fd_set, |
||||
int *max_fd); |
||||
|
||||
/*
|
||||
* Name: curl_multi_wait() |
||||
* |
||||
* Desc: Poll on all fds within a CURLM set as well as any |
||||
* additional fds passed to the function. |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_wait(CURLM *multi_handle, |
||||
struct curl_waitfd extra_fds[], |
||||
unsigned int extra_nfds, |
||||
int timeout_ms, |
||||
int *ret); |
||||
|
||||
/*
|
||||
* Name: curl_multi_perform() |
||||
* |
||||
* Desc: When the app thinks there's data available for curl it calls this |
||||
* function to read/write whatever there is right now. This returns |
||||
* as soon as the reads and writes are done. This function does not |
||||
* require that there actually is data available for reading or that |
||||
* data can be written, it can be called just in case. It returns |
||||
* the number of handles that still transfer data in the second |
||||
* argument's integer-pointer. |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. *NOTE* that this only |
||||
* returns errors etc regarding the whole multi stack. There might |
||||
* still have occurred problems on invidual transfers even when this |
||||
* returns OK. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_perform(CURLM *multi_handle, |
||||
int *running_handles); |
||||
|
||||
/*
|
||||
* Name: curl_multi_cleanup() |
||||
* |
||||
* Desc: Cleans up and removes a whole multi stack. It does not free or |
||||
* touch any individual easy handles in any way. We need to define |
||||
* in what state those handles will be if this function is called |
||||
* in the middle of a transfer. |
||||
* |
||||
* Returns: CURLMcode type, general multi error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_cleanup(CURLM *multi_handle); |
||||
|
||||
/*
|
||||
* Name: curl_multi_info_read() |
||||
* |
||||
* Desc: Ask the multi handle if there's any messages/informationals from |
||||
* the individual transfers. Messages include informationals such as |
||||
* error code from the transfer or just the fact that a transfer is |
||||
* completed. More details on these should be written down as well. |
||||
* |
||||
* Repeated calls to this function will return a new struct each |
||||
* time, until a special "end of msgs" struct is returned as a signal |
||||
* that there is no more to get at this point. |
||||
* |
||||
* The data the returned pointer points to will not survive calling |
||||
* curl_multi_cleanup(). |
||||
* |
||||
* The 'CURLMsg' struct is meant to be very simple and only contain |
||||
* very basic informations. If more involved information is wanted, |
||||
* we will provide the particular "transfer handle" in that struct |
||||
* and that should/could/would be used in subsequent |
||||
* curl_easy_getinfo() calls (or similar). The point being that we |
||||
* must never expose complex structs to applications, as then we'll |
||||
* undoubtably get backwards compatibility problems in the future. |
||||
* |
||||
* Returns: A pointer to a filled-in struct, or NULL if it failed or ran out |
||||
* of structs. It also writes the number of messages left in the |
||||
* queue (after this read) in the integer the second argument points |
||||
* to. |
||||
*/ |
||||
CURL_EXTERN CURLMsg *curl_multi_info_read(CURLM *multi_handle, |
||||
int *msgs_in_queue); |
||||
|
||||
/*
|
||||
* Name: curl_multi_strerror() |
||||
* |
||||
* Desc: The curl_multi_strerror function may be used to turn a CURLMcode |
||||
* value into the equivalent human readable error string. This is |
||||
* useful for printing meaningful error messages. |
||||
* |
||||
* Returns: A pointer to a zero-terminated error message. |
||||
*/ |
||||
CURL_EXTERN const char *curl_multi_strerror(CURLMcode); |
||||
|
||||
/*
|
||||
* Name: curl_multi_socket() and |
||||
* curl_multi_socket_all() |
||||
* |
||||
* Desc: An alternative version of curl_multi_perform() that allows the |
||||
* application to pass in one of the file descriptors that have been |
||||
* detected to have "action" on them and let libcurl perform. |
||||
* See man page for details. |
||||
*/ |
||||
#define CURL_POLL_NONE 0 |
||||
#define CURL_POLL_IN 1 |
||||
#define CURL_POLL_OUT 2 |
||||
#define CURL_POLL_INOUT 3 |
||||
#define CURL_POLL_REMOVE 4 |
||||
|
||||
#define CURL_SOCKET_TIMEOUT CURL_SOCKET_BAD |
||||
|
||||
#define CURL_CSELECT_IN 0x01 |
||||
#define CURL_CSELECT_OUT 0x02 |
||||
#define CURL_CSELECT_ERR 0x04 |
||||
|
||||
typedef int (*curl_socket_callback)(CURL *easy, /* easy handle */ |
||||
curl_socket_t s, /* socket */ |
||||
int what, /* see above */ |
||||
void *userp, /* private callback
|
||||
pointer */ |
||||
void *socketp); /* private socket
|
||||
pointer */ |
||||
/*
|
||||
* Name: curl_multi_timer_callback |
||||
* |
||||
* Desc: Called by libcurl whenever the library detects a change in the |
||||
* maximum number of milliseconds the app is allowed to wait before |
||||
* curl_multi_socket() or curl_multi_perform() must be called |
||||
* (to allow libcurl's timed events to take place). |
||||
* |
||||
* Returns: The callback should return zero. |
||||
*/ |
||||
typedef int (*curl_multi_timer_callback)(CURLM *multi, /* multi handle */ |
||||
long timeout_ms, /* see above */ |
||||
void *userp); /* private callback
|
||||
pointer */ |
||||
|
||||
CURL_EXTERN CURLMcode curl_multi_socket(CURLM *multi_handle, curl_socket_t s, |
||||
int *running_handles); |
||||
|
||||
CURL_EXTERN CURLMcode curl_multi_socket_action(CURLM *multi_handle, |
||||
curl_socket_t s, |
||||
int ev_bitmask, |
||||
int *running_handles); |
||||
|
||||
CURL_EXTERN CURLMcode curl_multi_socket_all(CURLM *multi_handle, |
||||
int *running_handles); |
||||
|
||||
#ifndef CURL_ALLOW_OLD_MULTI_SOCKET |
||||
/* This macro below was added in 7.16.3 to push users who recompile to use
|
||||
the new curl_multi_socket_action() instead of the old curl_multi_socket() |
||||
*/ |
||||
#define curl_multi_socket(x,y,z) curl_multi_socket_action(x,y,0,z) |
||||
#endif |
||||
|
||||
/*
|
||||
* Name: curl_multi_timeout() |
||||
* |
||||
* Desc: Returns the maximum number of milliseconds the app is allowed to |
||||
* wait before curl_multi_socket() or curl_multi_perform() must be |
||||
* called (to allow libcurl's timed events to take place). |
||||
* |
||||
* Returns: CURLM error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_timeout(CURLM *multi_handle, |
||||
long *milliseconds); |
||||
|
||||
#undef CINIT /* re-using the same name as in curl.h */ |
||||
|
||||
#ifdef CURL_ISOCPP |
||||
#define CINIT(name,type,num) CURLMOPT_ ## name = CURLOPTTYPE_ ## type + num |
||||
#else |
||||
/* The macro "##" is ISO C, we assume pre-ISO C doesn't support it. */ |
||||
#define LONG CURLOPTTYPE_LONG |
||||
#define OBJECTPOINT CURLOPTTYPE_OBJECTPOINT |
||||
#define FUNCTIONPOINT CURLOPTTYPE_FUNCTIONPOINT |
||||
#define OFF_T CURLOPTTYPE_OFF_T |
||||
#define CINIT(name,type,number) CURLMOPT_/**/name = type + number |
||||
#endif |
||||
|
||||
typedef enum { |
||||
/* This is the socket callback function pointer */ |
||||
CINIT(SOCKETFUNCTION, FUNCTIONPOINT, 1), |
||||
|
||||
/* This is the argument passed to the socket callback */ |
||||
CINIT(SOCKETDATA, OBJECTPOINT, 2), |
||||
|
||||
/* set to 1 to enable pipelining for this multi handle */ |
||||
CINIT(PIPELINING, LONG, 3), |
||||
|
||||
/* This is the timer callback function pointer */ |
||||
CINIT(TIMERFUNCTION, FUNCTIONPOINT, 4), |
||||
|
||||
/* This is the argument passed to the timer callback */ |
||||
CINIT(TIMERDATA, OBJECTPOINT, 5), |
||||
|
||||
/* maximum number of entries in the connection cache */ |
||||
CINIT(MAXCONNECTS, LONG, 6), |
||||
|
||||
/* maximum number of (pipelining) connections to one host */ |
||||
CINIT(MAX_HOST_CONNECTIONS, LONG, 7), |
||||
|
||||
/* maximum number of requests in a pipeline */ |
||||
CINIT(MAX_PIPELINE_LENGTH, LONG, 8), |
||||
|
||||
/* a connection with a content-length longer than this
|
||||
will not be considered for pipelining */ |
||||
CINIT(CONTENT_LENGTH_PENALTY_SIZE, OFF_T, 9), |
||||
|
||||
/* a connection with a chunk length longer than this
|
||||
will not be considered for pipelining */ |
||||
CINIT(CHUNK_LENGTH_PENALTY_SIZE, OFF_T, 10), |
||||
|
||||
/* a list of site names(+port) that are blacklisted from
|
||||
pipelining */ |
||||
CINIT(PIPELINING_SITE_BL, OBJECTPOINT, 11), |
||||
|
||||
/* a list of server types that are blacklisted from
|
||||
pipelining */ |
||||
CINIT(PIPELINING_SERVER_BL, OBJECTPOINT, 12), |
||||
|
||||
/* maximum number of open connections in total */ |
||||
CINIT(MAX_TOTAL_CONNECTIONS, LONG, 13), |
||||
|
||||
CURLMOPT_LASTENTRY /* the last unused */ |
||||
} CURLMoption; |
||||
|
||||
|
||||
/*
|
||||
* Name: curl_multi_setopt() |
||||
* |
||||
* Desc: Sets options for the multi handle. |
||||
* |
||||
* Returns: CURLM error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_setopt(CURLM *multi_handle, |
||||
CURLMoption option, ...); |
||||
|
||||
|
||||
/*
|
||||
* Name: curl_multi_assign() |
||||
* |
||||
* Desc: This function sets an association in the multi handle between the |
||||
* given socket and a private pointer of the application. This is |
||||
* (only) useful for curl_multi_socket uses. |
||||
* |
||||
* Returns: CURLM error code. |
||||
*/ |
||||
CURL_EXTERN CURLMcode curl_multi_assign(CURLM *multi_handle, |
||||
curl_socket_t sockfd, void *sockp); |
||||
|
||||
#ifdef __cplusplus |
||||
} /* end of extern "C" */ |
||||
#endif |
||||
|
||||
#endif |
@ -0,0 +1,33 @@
@@ -0,0 +1,33 @@
|
||||
#ifndef __STDC_HEADERS_H |
||||
#define __STDC_HEADERS_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
#include <sys/types.h> |
||||
|
||||
size_t fread (void *, size_t, size_t, FILE *); |
||||
size_t fwrite (const void *, size_t, size_t, FILE *); |
||||
|
||||
int strcasecmp(const char *, const char *); |
||||
int strncasecmp(const char *, const char *, size_t); |
||||
|
||||
#endif /* __STDC_HEADERS_H */ |
@ -0,0 +1,610 @@
@@ -0,0 +1,610 @@
|
||||
#ifndef __CURL_TYPECHECK_GCC_H |
||||
#define __CURL_TYPECHECK_GCC_H |
||||
/***************************************************************************
|
||||
* _ _ ____ _ |
||||
* Project ___| | | | _ \| | |
||||
* / __| | | | |_) | | |
||||
* | (__| |_| | _ <| |___ |
||||
* \___|\___/|_| \_\_____| |
||||
* |
||||
* Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. |
||||
* |
||||
* This software is licensed as described in the file COPYING, which |
||||
* you should have received as part of this distribution. The terms |
||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||
* |
||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell |
||||
* copies of the Software, and permit persons to whom the Software is |
||||
* furnished to do so, under the terms of the COPYING file. |
||||
* |
||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
||||
* KIND, either express or implied. |
||||
* |
||||
***************************************************************************/ |
||||
|
||||
/* wraps curl_easy_setopt() with typechecking */ |
||||
|
||||
/* To add a new kind of warning, add an
|
||||
* if(_curl_is_sometype_option(_curl_opt)) |
||||
* if(!_curl_is_sometype(value)) |
||||
* _curl_easy_setopt_err_sometype(); |
||||
* block and define _curl_is_sometype_option, _curl_is_sometype and |
||||
* _curl_easy_setopt_err_sometype below |
||||
* |
||||
* NOTE: We use two nested 'if' statements here instead of the && operator, in |
||||
* order to work around gcc bug #32061. It affects only gcc 4.3.x/4.4.x |
||||
* when compiling with -Wlogical-op. |
||||
* |
||||
* To add an option that uses the same type as an existing option, you'll just |
||||
* need to extend the appropriate _curl_*_option macro |
||||
*/ |
||||
#define curl_easy_setopt(handle, option, value) \ |
||||
__extension__ ({ \ |
||||
__typeof__ (option) _curl_opt = option; \ |
||||
if(__builtin_constant_p(_curl_opt)) { \ |
||||
if(_curl_is_long_option(_curl_opt)) \ |
||||
if(!_curl_is_long(value)) \ |
||||
_curl_easy_setopt_err_long(); \ |
||||
if(_curl_is_off_t_option(_curl_opt)) \ |
||||
if(!_curl_is_off_t(value)) \ |
||||
_curl_easy_setopt_err_curl_off_t(); \ |
||||
if(_curl_is_string_option(_curl_opt)) \ |
||||
if(!_curl_is_string(value)) \ |
||||
_curl_easy_setopt_err_string(); \ |
||||
if(_curl_is_write_cb_option(_curl_opt)) \ |
||||
if(!_curl_is_write_cb(value)) \ |
||||
_curl_easy_setopt_err_write_callback(); \ |
||||
if((_curl_opt) == CURLOPT_READFUNCTION) \ |
||||
if(!_curl_is_read_cb(value)) \ |
||||
_curl_easy_setopt_err_read_cb(); \ |
||||
if((_curl_opt) == CURLOPT_IOCTLFUNCTION) \ |
||||
if(!_curl_is_ioctl_cb(value)) \ |
||||
_curl_easy_setopt_err_ioctl_cb(); \ |
||||
if((_curl_opt) == CURLOPT_SOCKOPTFUNCTION) \ |
||||
if(!_curl_is_sockopt_cb(value)) \ |
||||
_curl_easy_setopt_err_sockopt_cb(); \ |
||||
if((_curl_opt) == CURLOPT_OPENSOCKETFUNCTION) \ |
||||
if(!_curl_is_opensocket_cb(value)) \ |
||||
_curl_easy_setopt_err_opensocket_cb(); \ |
||||
if((_curl_opt) == CURLOPT_PROGRESSFUNCTION) \ |
||||
if(!_curl_is_progress_cb(value)) \ |
||||
_curl_easy_setopt_err_progress_cb(); \ |
||||
if((_curl_opt) == CURLOPT_DEBUGFUNCTION) \ |
||||
if(!_curl_is_debug_cb(value)) \ |
||||
_curl_easy_setopt_err_debug_cb(); \ |
||||
if((_curl_opt) == CURLOPT_SSL_CTX_FUNCTION) \ |
||||
if(!_curl_is_ssl_ctx_cb(value)) \ |
||||
_curl_easy_setopt_err_ssl_ctx_cb(); \ |
||||
if(_curl_is_conv_cb_option(_curl_opt)) \ |
||||
if(!_curl_is_conv_cb(value)) \ |
||||
_curl_easy_setopt_err_conv_cb(); \ |
||||
if((_curl_opt) == CURLOPT_SEEKFUNCTION) \ |
||||
if(!_curl_is_seek_cb(value)) \ |
||||
_curl_easy_setopt_err_seek_cb(); \ |
||||
if(_curl_is_cb_data_option(_curl_opt)) \ |
||||
if(!_curl_is_cb_data(value)) \ |
||||
_curl_easy_setopt_err_cb_data(); \ |
||||
if((_curl_opt) == CURLOPT_ERRORBUFFER) \ |
||||
if(!_curl_is_error_buffer(value)) \ |
||||
_curl_easy_setopt_err_error_buffer(); \ |
||||
if((_curl_opt) == CURLOPT_STDERR) \ |
||||
if(!_curl_is_FILE(value)) \ |
||||
_curl_easy_setopt_err_FILE(); \ |
||||
if(_curl_is_postfields_option(_curl_opt)) \ |
||||
if(!_curl_is_postfields(value)) \ |
||||
_curl_easy_setopt_err_postfields(); \ |
||||
if((_curl_opt) == CURLOPT_HTTPPOST) \ |
||||
if(!_curl_is_arr((value), struct curl_httppost)) \ |
||||
_curl_easy_setopt_err_curl_httpost(); \ |
||||
if(_curl_is_slist_option(_curl_opt)) \ |
||||
if(!_curl_is_arr((value), struct curl_slist)) \ |
||||
_curl_easy_setopt_err_curl_slist(); \ |
||||
if((_curl_opt) == CURLOPT_SHARE) \ |
||||
if(!_curl_is_ptr((value), CURLSH)) \ |
||||
_curl_easy_setopt_err_CURLSH(); \ |
||||
} \ |
||||
curl_easy_setopt(handle, _curl_opt, value); \ |
||||
}) |
||||
|
||||
/* wraps curl_easy_getinfo() with typechecking */ |
||||
/* FIXME: don't allow const pointers */ |
||||
#define curl_easy_getinfo(handle, info, arg) \ |
||||
__extension__ ({ \ |
||||
__typeof__ (info) _curl_info = info; \ |
||||
if(__builtin_constant_p(_curl_info)) { \ |
||||
if(_curl_is_string_info(_curl_info)) \ |
||||
if(!_curl_is_arr((arg), char *)) \ |
||||
_curl_easy_getinfo_err_string(); \ |
||||
if(_curl_is_long_info(_curl_info)) \ |
||||
if(!_curl_is_arr((arg), long)) \ |
||||
_curl_easy_getinfo_err_long(); \ |
||||
if(_curl_is_double_info(_curl_info)) \ |
||||
if(!_curl_is_arr((arg), double)) \ |
||||
_curl_easy_getinfo_err_double(); \ |
||||
if(_curl_is_slist_info(_curl_info)) \ |
||||
if(!_curl_is_arr((arg), struct curl_slist *)) \ |
||||
_curl_easy_getinfo_err_curl_slist(); \ |
||||
} \ |
||||
curl_easy_getinfo(handle, _curl_info, arg); \ |
||||
}) |
||||
|
||||
/* TODO: typechecking for curl_share_setopt() and curl_multi_setopt(),
|
||||
* for now just make sure that the functions are called with three |
||||
* arguments |
||||
*/ |
||||
#define curl_share_setopt(share,opt,param) curl_share_setopt(share,opt,param) |
||||
#define curl_multi_setopt(handle,opt,param) curl_multi_setopt(handle,opt,param) |
||||
|
||||
|
||||
/* the actual warnings, triggered by calling the _curl_easy_setopt_err*
|
||||
* functions */ |
||||
|
||||
/* To define a new warning, use _CURL_WARNING(identifier, "message") */ |
||||
#define _CURL_WARNING(id, message) \ |
||||
static void __attribute__((__warning__(message))) \ |
||||
__attribute__((__unused__)) __attribute__((__noinline__)) \ |
||||
id(void) { __asm__(""); } |
||||
|
||||
_CURL_WARNING(_curl_easy_setopt_err_long, |
||||
"curl_easy_setopt expects a long argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_curl_off_t, |
||||
"curl_easy_setopt expects a curl_off_t argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_string, |
||||
"curl_easy_setopt expects a " |
||||
"string (char* or char[]) argument for this option" |
||||
) |
||||
_CURL_WARNING(_curl_easy_setopt_err_write_callback, |
||||
"curl_easy_setopt expects a curl_write_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_read_cb, |
||||
"curl_easy_setopt expects a curl_read_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_ioctl_cb, |
||||
"curl_easy_setopt expects a curl_ioctl_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_sockopt_cb, |
||||
"curl_easy_setopt expects a curl_sockopt_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_opensocket_cb, |
||||
"curl_easy_setopt expects a " |
||||
"curl_opensocket_callback argument for this option" |
||||
) |
||||
_CURL_WARNING(_curl_easy_setopt_err_progress_cb, |
||||
"curl_easy_setopt expects a curl_progress_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_debug_cb, |
||||
"curl_easy_setopt expects a curl_debug_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_ssl_ctx_cb, |
||||
"curl_easy_setopt expects a curl_ssl_ctx_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_conv_cb, |
||||
"curl_easy_setopt expects a curl_conv_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_seek_cb, |
||||
"curl_easy_setopt expects a curl_seek_callback argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_cb_data, |
||||
"curl_easy_setopt expects a " |
||||
"private data pointer as argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_error_buffer, |
||||
"curl_easy_setopt expects a " |
||||
"char buffer of CURL_ERROR_SIZE as argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_FILE, |
||||
"curl_easy_setopt expects a FILE* argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_postfields, |
||||
"curl_easy_setopt expects a void* or char* argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_curl_httpost, |
||||
"curl_easy_setopt expects a struct curl_httppost* argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_curl_slist, |
||||
"curl_easy_setopt expects a struct curl_slist* argument for this option") |
||||
_CURL_WARNING(_curl_easy_setopt_err_CURLSH, |
||||
"curl_easy_setopt expects a CURLSH* argument for this option") |
||||
|
||||
_CURL_WARNING(_curl_easy_getinfo_err_string, |
||||
"curl_easy_getinfo expects a pointer to char * for this info") |
||||
_CURL_WARNING(_curl_easy_getinfo_err_long, |
||||
"curl_easy_getinfo expects a pointer to long for this info") |
||||
_CURL_WARNING(_curl_easy_getinfo_err_double, |
||||
"curl_easy_getinfo expects a pointer to double for this info") |
||||
_CURL_WARNING(_curl_easy_getinfo_err_curl_slist, |
||||
"curl_easy_getinfo expects a pointer to struct curl_slist * for this info") |
||||
|
||||
/* groups of curl_easy_setops options that take the same type of argument */ |
||||
|
||||
/* To add a new option to one of the groups, just add
|
||||
* (option) == CURLOPT_SOMETHING |
||||
* to the or-expression. If the option takes a long or curl_off_t, you don't |
||||
* have to do anything |
||||
*/ |
||||
|
||||
/* evaluates to true if option takes a long argument */ |
||||
#define _curl_is_long_option(option) \ |
||||
(0 < (option) && (option) < CURLOPTTYPE_OBJECTPOINT) |
||||
|
||||
#define _curl_is_off_t_option(option) \ |
||||
((option) > CURLOPTTYPE_OFF_T) |
||||
|
||||
/* evaluates to true if option takes a char* argument */ |
||||
#define _curl_is_string_option(option) \ |
||||
((option) == CURLOPT_URL || \ |
||||
(option) == CURLOPT_PROXY || \ |
||||
(option) == CURLOPT_INTERFACE || \ |
||||
(option) == CURLOPT_NETRC_FILE || \ |
||||
(option) == CURLOPT_USERPWD || \ |
||||
(option) == CURLOPT_USERNAME || \ |
||||
(option) == CURLOPT_PASSWORD || \ |
||||
(option) == CURLOPT_PROXYUSERPWD || \ |
||||
(option) == CURLOPT_PROXYUSERNAME || \ |
||||
(option) == CURLOPT_PROXYPASSWORD || \ |
||||
(option) == CURLOPT_NOPROXY || \ |
||||
(option) == CURLOPT_ACCEPT_ENCODING || \ |
||||
(option) == CURLOPT_REFERER || \ |
||||
(option) == CURLOPT_USERAGENT || \ |
||||
(option) == CURLOPT_COOKIE || \ |
||||
(option) == CURLOPT_COOKIEFILE || \ |
||||
(option) == CURLOPT_COOKIEJAR || \ |
||||
(option) == CURLOPT_COOKIELIST || \ |
||||
(option) == CURLOPT_FTPPORT || \ |
||||
(option) == CURLOPT_FTP_ALTERNATIVE_TO_USER || \ |
||||
(option) == CURLOPT_FTP_ACCOUNT || \ |
||||
(option) == CURLOPT_RANGE || \ |
||||
(option) == CURLOPT_CUSTOMREQUEST || \ |
||||
(option) == CURLOPT_SSLCERT || \ |
||||
(option) == CURLOPT_SSLCERTTYPE || \ |
||||
(option) == CURLOPT_SSLKEY || \ |
||||
(option) == CURLOPT_SSLKEYTYPE || \ |
||||
(option) == CURLOPT_KEYPASSWD || \ |
||||
(option) == CURLOPT_SSLENGINE || \ |
||||
(option) == CURLOPT_CAINFO || \ |
||||
(option) == CURLOPT_CAPATH || \ |
||||
(option) == CURLOPT_RANDOM_FILE || \ |
||||
(option) == CURLOPT_EGDSOCKET || \ |
||||
(option) == CURLOPT_SSL_CIPHER_LIST || \ |
||||
(option) == CURLOPT_KRBLEVEL || \ |
||||
(option) == CURLOPT_SSH_HOST_PUBLIC_KEY_MD5 || \ |
||||
(option) == CURLOPT_SSH_PUBLIC_KEYFILE || \ |
||||
(option) == CURLOPT_SSH_PRIVATE_KEYFILE || \ |
||||
(option) == CURLOPT_CRLFILE || \ |
||||
(option) == CURLOPT_ISSUERCERT || \ |
||||
(option) == CURLOPT_SOCKS5_GSSAPI_SERVICE || \ |
||||
(option) == CURLOPT_SSH_KNOWNHOSTS || \ |
||||
(option) == CURLOPT_MAIL_FROM || \ |
||||
(option) == CURLOPT_RTSP_SESSION_ID || \ |
||||
(option) == CURLOPT_RTSP_STREAM_URI || \ |
||||
(option) == CURLOPT_RTSP_TRANSPORT || \ |
||||
(option) == CURLOPT_XOAUTH2_BEARER || \ |
||||
(option) == CURLOPT_DNS_SERVERS || \ |
||||
(option) == CURLOPT_DNS_INTERFACE || \ |
||||
(option) == CURLOPT_DNS_LOCAL_IP4 || \ |
||||
(option) == CURLOPT_DNS_LOCAL_IP6 || \ |
||||
(option) == CURLOPT_LOGIN_OPTIONS || \ |
||||
0) |
||||
|
||||
/* evaluates to true if option takes a curl_write_callback argument */ |
||||
#define _curl_is_write_cb_option(option) \ |
||||
((option) == CURLOPT_HEADERFUNCTION || \ |
||||
(option) == CURLOPT_WRITEFUNCTION) |
||||
|
||||
/* evaluates to true if option takes a curl_conv_callback argument */ |
||||
#define _curl_is_conv_cb_option(option) \ |
||||
((option) == CURLOPT_CONV_TO_NETWORK_FUNCTION || \ |
||||
(option) == CURLOPT_CONV_FROM_NETWORK_FUNCTION || \ |
||||
(option) == CURLOPT_CONV_FROM_UTF8_FUNCTION) |
||||
|
||||
/* evaluates to true if option takes a data argument to pass to a callback */ |
||||
#define _curl_is_cb_data_option(option) \ |
||||
((option) == CURLOPT_WRITEDATA || \ |
||||
(option) == CURLOPT_READDATA || \ |
||||
(option) == CURLOPT_IOCTLDATA || \ |
||||
(option) == CURLOPT_SOCKOPTDATA || \ |
||||
(option) == CURLOPT_OPENSOCKETDATA || \ |
||||
(option) == CURLOPT_PROGRESSDATA || \ |
||||
(option) == CURLOPT_HEADERDATA || \ |
||||
(option) == CURLOPT_DEBUGDATA || \ |
||||
(option) == CURLOPT_SSL_CTX_DATA || \ |
||||
(option) == CURLOPT_SEEKDATA || \ |
||||
(option) == CURLOPT_PRIVATE || \ |
||||
(option) == CURLOPT_SSH_KEYDATA || \ |
||||
(option) == CURLOPT_INTERLEAVEDATA || \ |
||||
(option) == CURLOPT_CHUNK_DATA || \ |
||||
(option) == CURLOPT_FNMATCH_DATA || \ |
||||
0) |
||||
|
||||
/* evaluates to true if option takes a POST data argument (void* or char*) */ |
||||
#define _curl_is_postfields_option(option) \ |
||||
((option) == CURLOPT_POSTFIELDS || \ |
||||
(option) == CURLOPT_COPYPOSTFIELDS || \ |
||||
0) |
||||
|
||||
/* evaluates to true if option takes a struct curl_slist * argument */ |
||||
#define _curl_is_slist_option(option) \ |
||||
((option) == CURLOPT_HTTPHEADER || \ |
||||
(option) == CURLOPT_HTTP200ALIASES || \ |
||||
(option) == CURLOPT_QUOTE || \ |
||||
(option) == CURLOPT_POSTQUOTE || \ |
||||
(option) == CURLOPT_PREQUOTE || \ |
||||
(option) == CURLOPT_TELNETOPTIONS || \ |
||||
(option) == CURLOPT_MAIL_RCPT || \ |
||||
0) |
||||
|
||||
/* groups of curl_easy_getinfo infos that take the same type of argument */ |
||||
|
||||
/* evaluates to true if info expects a pointer to char * argument */ |
||||
#define _curl_is_string_info(info) \ |
||||
(CURLINFO_STRING < (info) && (info) < CURLINFO_LONG) |
||||
|
||||
/* evaluates to true if info expects a pointer to long argument */ |
||||
#define _curl_is_long_info(info) \ |
||||
(CURLINFO_LONG < (info) && (info) < CURLINFO_DOUBLE) |
||||
|
||||
/* evaluates to true if info expects a pointer to double argument */ |
||||
#define _curl_is_double_info(info) \ |
||||
(CURLINFO_DOUBLE < (info) && (info) < CURLINFO_SLIST) |
||||
|
||||
/* true if info expects a pointer to struct curl_slist * argument */ |
||||
#define _curl_is_slist_info(info) \ |
||||
(CURLINFO_SLIST < (info)) |
||||
|
||||
|
||||
/* typecheck helpers -- check whether given expression has requested type*/ |
||||
|
||||
/* For pointers, you can use the _curl_is_ptr/_curl_is_arr macros,
|
||||
* otherwise define a new macro. Search for __builtin_types_compatible_p |
||||
* in the GCC manual. |
||||
* NOTE: these macros MUST NOT EVALUATE their arguments! The argument is |
||||
* the actual expression passed to the curl_easy_setopt macro. This |
||||
* means that you can only apply the sizeof and __typeof__ operators, no |
||||
* == or whatsoever. |
||||
*/ |
||||
|
||||
/* XXX: should evaluate to true iff expr is a pointer */ |
||||
#define _curl_is_any_ptr(expr) \ |
||||
(sizeof(expr) == sizeof(void*)) |
||||
|
||||
/* evaluates to true if expr is NULL */ |
||||
/* XXX: must not evaluate expr, so this check is not accurate */ |
||||
#define _curl_is_NULL(expr) \ |
||||
(__builtin_types_compatible_p(__typeof__(expr), __typeof__(NULL))) |
||||
|
||||
/* evaluates to true if expr is type*, const type* or NULL */ |
||||
#define _curl_is_ptr(expr, type) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), type *) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), const type *)) |
||||
|
||||
/* evaluates to true if expr is one of type[], type*, NULL or const type* */ |
||||
#define _curl_is_arr(expr, type) \ |
||||
(_curl_is_ptr((expr), type) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), type [])) |
||||
|
||||
/* evaluates to true if expr is a string */ |
||||
#define _curl_is_string(expr) \ |
||||
(_curl_is_arr((expr), char) || \ |
||||
_curl_is_arr((expr), signed char) || \ |
||||
_curl_is_arr((expr), unsigned char)) |
||||
|
||||
/* evaluates to true if expr is a long (no matter the signedness)
|
||||
* XXX: for now, int is also accepted (and therefore short and char, which |
||||
* are promoted to int when passed to a variadic function) */ |
||||
#define _curl_is_long(expr) \ |
||||
(__builtin_types_compatible_p(__typeof__(expr), long) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), signed long) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), unsigned long) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), int) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), signed int) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), unsigned int) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), short) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), signed short) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), unsigned short) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), char) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), signed char) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), unsigned char)) |
||||
|
||||
/* evaluates to true if expr is of type curl_off_t */ |
||||
#define _curl_is_off_t(expr) \ |
||||
(__builtin_types_compatible_p(__typeof__(expr), curl_off_t)) |
||||
|
||||
/* evaluates to true if expr is abuffer suitable for CURLOPT_ERRORBUFFER */ |
||||
/* XXX: also check size of an char[] array? */ |
||||
#define _curl_is_error_buffer(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), char *) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), char[])) |
||||
|
||||
/* evaluates to true if expr is of type (const) void* or (const) FILE* */ |
||||
#if 0 |
||||
#define _curl_is_cb_data(expr) \ |
||||
(_curl_is_ptr((expr), void) || \ |
||||
_curl_is_ptr((expr), FILE)) |
||||
#else /* be less strict */ |
||||
#define _curl_is_cb_data(expr) \ |
||||
_curl_is_any_ptr(expr) |
||||
#endif |
||||
|
||||
/* evaluates to true if expr is of type FILE* */ |
||||
#define _curl_is_FILE(expr) \ |
||||
(__builtin_types_compatible_p(__typeof__(expr), FILE *)) |
||||
|
||||
/* evaluates to true if expr can be passed as POST data (void* or char*) */ |
||||
#define _curl_is_postfields(expr) \ |
||||
(_curl_is_ptr((expr), void) || \ |
||||
_curl_is_arr((expr), char)) |
||||
|
||||
/* FIXME: the whole callback checking is messy...
|
||||
* The idea is to tolerate char vs. void and const vs. not const |
||||
* pointers in arguments at least |
||||
*/ |
||||
/* helper: __builtin_types_compatible_p distinguishes between functions and
|
||||
* function pointers, hide it */ |
||||
#define _curl_callback_compatible(func, type) \ |
||||
(__builtin_types_compatible_p(__typeof__(func), type) || \ |
||||
__builtin_types_compatible_p(__typeof__(func), type*)) |
||||
|
||||
/* evaluates to true if expr is of type curl_read_callback or "similar" */ |
||||
#define _curl_is_read_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), __typeof__(fread)) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_read_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback4) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback5) || \ |
||||
_curl_callback_compatible((expr), _curl_read_callback6)) |
||||
typedef size_t (_curl_read_callback1)(char *, size_t, size_t, void*); |
||||
typedef size_t (_curl_read_callback2)(char *, size_t, size_t, const void*); |
||||
typedef size_t (_curl_read_callback3)(char *, size_t, size_t, FILE*); |
||||
typedef size_t (_curl_read_callback4)(void *, size_t, size_t, void*); |
||||
typedef size_t (_curl_read_callback5)(void *, size_t, size_t, const void*); |
||||
typedef size_t (_curl_read_callback6)(void *, size_t, size_t, FILE*); |
||||
|
||||
/* evaluates to true if expr is of type curl_write_callback or "similar" */ |
||||
#define _curl_is_write_cb(expr) \ |
||||
(_curl_is_read_cb(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), __typeof__(fwrite)) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_write_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback4) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback5) || \ |
||||
_curl_callback_compatible((expr), _curl_write_callback6)) |
||||
typedef size_t (_curl_write_callback1)(const char *, size_t, size_t, void*); |
||||
typedef size_t (_curl_write_callback2)(const char *, size_t, size_t, |
||||
const void*); |
||||
typedef size_t (_curl_write_callback3)(const char *, size_t, size_t, FILE*); |
||||
typedef size_t (_curl_write_callback4)(const void *, size_t, size_t, void*); |
||||
typedef size_t (_curl_write_callback5)(const void *, size_t, size_t, |
||||
const void*); |
||||
typedef size_t (_curl_write_callback6)(const void *, size_t, size_t, FILE*); |
||||
|
||||
/* evaluates to true if expr is of type curl_ioctl_callback or "similar" */ |
||||
#define _curl_is_ioctl_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_ioctl_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_ioctl_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_ioctl_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_ioctl_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_ioctl_callback4)) |
||||
typedef curlioerr (_curl_ioctl_callback1)(CURL *, int, void*); |
||||
typedef curlioerr (_curl_ioctl_callback2)(CURL *, int, const void*); |
||||
typedef curlioerr (_curl_ioctl_callback3)(CURL *, curliocmd, void*); |
||||
typedef curlioerr (_curl_ioctl_callback4)(CURL *, curliocmd, const void*); |
||||
|
||||
/* evaluates to true if expr is of type curl_sockopt_callback or "similar" */ |
||||
#define _curl_is_sockopt_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_sockopt_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_sockopt_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_sockopt_callback2)) |
||||
typedef int (_curl_sockopt_callback1)(void *, curl_socket_t, curlsocktype); |
||||
typedef int (_curl_sockopt_callback2)(const void *, curl_socket_t, |
||||
curlsocktype); |
||||
|
||||
/* evaluates to true if expr is of type curl_opensocket_callback or
|
||||
"similar" */ |
||||
#define _curl_is_opensocket_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_opensocket_callback) ||\ |
||||
_curl_callback_compatible((expr), _curl_opensocket_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_opensocket_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_opensocket_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_opensocket_callback4)) |
||||
typedef curl_socket_t (_curl_opensocket_callback1) |
||||
(void *, curlsocktype, struct curl_sockaddr *); |
||||
typedef curl_socket_t (_curl_opensocket_callback2) |
||||
(void *, curlsocktype, const struct curl_sockaddr *); |
||||
typedef curl_socket_t (_curl_opensocket_callback3) |
||||
(const void *, curlsocktype, struct curl_sockaddr *); |
||||
typedef curl_socket_t (_curl_opensocket_callback4) |
||||
(const void *, curlsocktype, const struct curl_sockaddr *); |
||||
|
||||
/* evaluates to true if expr is of type curl_progress_callback or "similar" */ |
||||
#define _curl_is_progress_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_progress_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_progress_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_progress_callback2)) |
||||
typedef int (_curl_progress_callback1)(void *, |
||||
double, double, double, double); |
||||
typedef int (_curl_progress_callback2)(const void *, |
||||
double, double, double, double); |
||||
|
||||
/* evaluates to true if expr is of type curl_debug_callback or "similar" */ |
||||
#define _curl_is_debug_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_debug_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback4) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback5) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback6) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback7) || \ |
||||
_curl_callback_compatible((expr), _curl_debug_callback8)) |
||||
typedef int (_curl_debug_callback1) (CURL *, |
||||
curl_infotype, char *, size_t, void *); |
||||
typedef int (_curl_debug_callback2) (CURL *, |
||||
curl_infotype, char *, size_t, const void *); |
||||
typedef int (_curl_debug_callback3) (CURL *, |
||||
curl_infotype, const char *, size_t, void *); |
||||
typedef int (_curl_debug_callback4) (CURL *, |
||||
curl_infotype, const char *, size_t, const void *); |
||||
typedef int (_curl_debug_callback5) (CURL *, |
||||
curl_infotype, unsigned char *, size_t, void *); |
||||
typedef int (_curl_debug_callback6) (CURL *, |
||||
curl_infotype, unsigned char *, size_t, const void *); |
||||
typedef int (_curl_debug_callback7) (CURL *, |
||||
curl_infotype, const unsigned char *, size_t, void *); |
||||
typedef int (_curl_debug_callback8) (CURL *, |
||||
curl_infotype, const unsigned char *, size_t, const void *); |
||||
|
||||
/* evaluates to true if expr is of type curl_ssl_ctx_callback or "similar" */ |
||||
/* this is getting even messier... */ |
||||
#define _curl_is_ssl_ctx_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_ssl_ctx_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback4) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback5) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback6) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback7) || \ |
||||
_curl_callback_compatible((expr), _curl_ssl_ctx_callback8)) |
||||
typedef CURLcode (_curl_ssl_ctx_callback1)(CURL *, void *, void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback2)(CURL *, void *, const void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback3)(CURL *, const void *, void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback4)(CURL *, const void *, const void *); |
||||
#ifdef HEADER_SSL_H |
||||
/* hack: if we included OpenSSL's ssl.h, we know about SSL_CTX
|
||||
* this will of course break if we're included before OpenSSL headers... |
||||
*/ |
||||
typedef CURLcode (_curl_ssl_ctx_callback5)(CURL *, SSL_CTX, void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback6)(CURL *, SSL_CTX, const void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback7)(CURL *, const SSL_CTX, void *); |
||||
typedef CURLcode (_curl_ssl_ctx_callback8)(CURL *, const SSL_CTX, |
||||
const void *); |
||||
#else |
||||
typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback5; |
||||
typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback6; |
||||
typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback7; |
||||
typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback8; |
||||
#endif |
||||
|
||||
/* evaluates to true if expr is of type curl_conv_callback or "similar" */ |
||||
#define _curl_is_conv_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_conv_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_conv_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_conv_callback2) || \ |
||||
_curl_callback_compatible((expr), _curl_conv_callback3) || \ |
||||
_curl_callback_compatible((expr), _curl_conv_callback4)) |
||||
typedef CURLcode (*_curl_conv_callback1)(char *, size_t length); |
||||
typedef CURLcode (*_curl_conv_callback2)(const char *, size_t length); |
||||
typedef CURLcode (*_curl_conv_callback3)(void *, size_t length); |
||||
typedef CURLcode (*_curl_conv_callback4)(const void *, size_t length); |
||||
|
||||
/* evaluates to true if expr is of type curl_seek_callback or "similar" */ |
||||
#define _curl_is_seek_cb(expr) \ |
||||
(_curl_is_NULL(expr) || \ |
||||
__builtin_types_compatible_p(__typeof__(expr), curl_seek_callback) || \ |
||||
_curl_callback_compatible((expr), _curl_seek_callback1) || \ |
||||
_curl_callback_compatible((expr), _curl_seek_callback2)) |
||||
typedef CURLcode (*_curl_seek_callback1)(void *, curl_off_t, int); |
||||
typedef CURLcode (*_curl_seek_callback2)(const void *, curl_off_t, int); |
||||
|
||||
|
||||
#endif /* __CURL_TYPECHECK_GCC_H */ |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in new issue